Project import generated by Copybara.

NOKEYCHECK=True
GitOrigin-RevId: c27c052b1f1ae88b0da1c390de93c87b10351dfe
diff --git a/FreeRTOS/License/license.txt b/FreeRTOS/License/license.txt
new file mode 100644
index 0000000..2e32746
--- /dev/null
+++ b/FreeRTOS/License/license.txt
@@ -0,0 +1,440 @@
+The FreeRTOS.org source code is licensed by the *modified* GNU General Public

+License (GPL), text provided below.  A special exception to the GPL is 

+included to allow you to distribute a combined work that includes FreeRTOS 

+without being obliged to provide the source code for any proprietary 

+components.  See the licensing section of http://www.FreeRTOS.org for full 

+details.  The exception text is also included at the bottom of this file.

+

+The FreeRTOS download also includes demo application source code, some of 

+which is provided by third parties AND IS LICENSED SEPARATELY FROM FREERTOS.

+

+For the avoidance of any doubt refer to the comment included at the top

+of each source and header file for license and copyright information.

+

+This is a list of files for which Real Time Engineers Ltd are not the 

+copyright owner and are NOT COVERED BY THE GPL.

+

+

+1) Various header files provided by silicon manufacturers and tool vendors

+   that define processor specific memory addresses and utility macros.

+   Permission has been granted by the various copyright holders for these

+   files to be included in the FreeRTOS download.  Users must ensure license

+   conditions are adhered to for any use other than compilation of the 

+   FreeRTOS demo applications.

+

+2) The uIP TCP/IP stack the copyright of which is held by Adam Dunkels.

+   Users must ensure the open source license conditions stated at the top 

+   of each uIP source file is understood and adhered to.

+

+3) The lwIP TCP/IP stack the copyright of which is held by the Swedish 

+   Institute of Computer Science.  Users must ensure the open source license 

+   conditions stated at the top  of each lwIP source file is understood and 

+   adhered to.

+

+4) Various peripheral driver source files and binaries provided by silicon

+   manufacturers and tool vendors.  Permission has been granted by the

+   various copyright holders for these files to be included in the FreeRTOS

+   download.  Users must ensure license conditions are adhered to for any

+   use other than compilation of the FreeRTOS demo applications.

+

+5) The files contained within FreeRTOS\Demo\WizNET_DEMO_TERN_186\tern_code,

+   which are slightly modified versions of code provided by and copyright to

+   Tern Inc.

+

+Errors and omissions should be reported to Richard Barry, contact details for

+whom can be obtained from http://www.FreeRTOS.org.

+

+

+

+

+

+The GPL license text follows.

+

+A special exception to the GPL is included to allow you to distribute a 

+combined work that includes FreeRTOS without being obliged to provide

+the source code for any proprietary components.  See the licensing section

+of http://www.FreeRTOS.org for full details.  The exception text is also

+included at the bottom of this file.

+

+--------------------------------------------------------------------

+

+

+

+		    GNU GENERAL PUBLIC LICENSE

+		       Version 2, June 1991

+

+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.

+                       59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

+ Everyone is permitted to copy and distribute verbatim copies

+ of this license document, but changing it is not allowed.

+

+			    Preamble

+

+  The licenses for most software are designed to take away your

+freedom to share and change it.  By contrast, the GNU General Public

+License is intended to guarantee your freedom to share and change free

+software--to make sure the software is free for all its users.  This

+General Public License applies to most of the Free Software

+Foundation's software and to any other program whose authors commit to

+using it.  (Some other Free Software Foundation software is covered by

+the GNU Library General Public License instead.)  You can apply it to

+your programs, too.

+

+  When we speak of free software, we are referring to freedom, not

+price.  Our General Public Licenses are designed to make sure that you

+have the freedom to distribute copies of free software (and charge for

+this service if you wish), that you receive source code or can get it

+if you want it, that you can change the software or use pieces of it

+in new free programs; and that you know you can do these things.

+

+  To protect your rights, we need to make restrictions that forbid

+anyone to deny you these rights or to ask you to surrender the rights.

+These restrictions translate to certain responsibilities for you if you

+distribute copies of the software, or if you modify it.

+

+  For example, if you distribute copies of such a program, whether

+gratis or for a fee, you must give the recipients all the rights that

+you have.  You must make sure that they, too, receive or can get the

+source code.  And you must show them these terms so they know their

+rights.

+

+  We protect your rights with two steps: (1) copyright the software, and

+(2) offer you this license which gives you legal permission to copy,

+distribute and/or modify the software.

+

+  Also, for each author's protection and ours, we want to make certain

+that everyone understands that there is no warranty for this free

+software.  If the software is modified by someone else and passed on, we

+want its recipients to know that what they have is not the original, so

+that any problems introduced by others will not reflect on the original

+authors' reputations.

+

+  Finally, any free program is threatened constantly by software

+patents.  We wish to avoid the danger that redistributors of a free

+program will individually obtain patent licenses, in effect making the

+program proprietary.  To prevent this, we have made it clear that any

+patent must be licensed for everyone's free use or not licensed at all.

+

+  The precise terms and conditions for copying, distribution and

+modification follow.

+

+		    GNU GENERAL PUBLIC LICENSE

+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION

+

+  0. This License applies to any program or other work which contains

+a notice placed by the copyright holder saying it may be distributed

+under the terms of this General Public License.  The "Program", below,

+refers to any such program or work, and a "work based on the Program"

+means either the Program or any derivative work under copyright law:

+that is to say, a work containing the Program or a portion of it,

+either verbatim or with modifications and/or translated into another

+language.  (Hereinafter, translation is included without limitation in

+the term "modification".)  Each licensee is addressed as "you".

+

+Activities other than copying, distribution and modification are not

+covered by this License; they are outside its scope.  The act of

+running the Program is not restricted, and the output from the Program

+is covered only if its contents constitute a work based on the

+Program (independent of having been made by running the Program).

+Whether that is true depends on what the Program does.

+

+  1. You may copy and distribute verbatim copies of the Program's

+source code as you receive it, in any medium, provided that you

+conspicuously and appropriately publish on each copy an appropriate

+copyright notice and disclaimer of warranty; keep intact all the

+notices that refer to this License and to the absence of any warranty;

+and give any other recipients of the Program a copy of this License

+along with the Program.

+

+You may charge a fee for the physical act of transferring a copy, and

+you may at your option offer warranty protection in exchange for a fee.

+

+  2. You may modify your copy or copies of the Program or any portion

+of it, thus forming a work based on the Program, and copy and

+distribute such modifications or work under the terms of Section 1

+above, provided that you also meet all of these conditions:

+

+    a) You must cause the modified files to carry prominent notices

+    stating that you changed the files and the date of any change.

+

+    b) You must cause any work that you distribute or publish, that in

+    whole or in part contains or is derived from the Program or any

+    part thereof, to be licensed as a whole at no charge to all third

+    parties under the terms of this License.

+

+    c) If the modified program normally reads commands interactively

+    when run, you must cause it, when started running for such

+    interactive use in the most ordinary way, to print or display an

+    announcement including an appropriate copyright notice and a

+    notice that there is no warranty (or else, saying that you provide

+    a warranty) and that users may redistribute the program under

+    these conditions, and telling the user how to view a copy of this

+    License.  (Exception: if the Program itself is interactive but

+    does not normally print such an announcement, your work based on

+    the Program is not required to print an announcement.)

+

+These requirements apply to the modified work as a whole.  If

+identifiable sections of that work are not derived from the Program,

+and can be reasonably considered independent and separate works in

+themselves, then this License, and its terms, do not apply to those

+sections when you distribute them as separate works.  But when you

+distribute the same sections as part of a whole which is a work based

+on the Program, the distribution of the whole must be on the terms of

+this License, whose permissions for other licensees extend to the

+entire whole, and thus to each and every part regardless of who wrote it.

+

+Thus, it is not the intent of this section to claim rights or contest

+your rights to work written entirely by you; rather, the intent is to

+exercise the right to control the distribution of derivative or

+collective works based on the Program.

+

+In addition, mere aggregation of another work not based on the Program

+with the Program (or with a work based on the Program) on a volume of

+a storage or distribution medium does not bring the other work under

+the scope of this License.

+

+  3. You may copy and distribute the Program (or a work based on it,

+under Section 2) in object code or executable form under the terms of

+Sections 1 and 2 above provided that you also do one of the following:

+

+    a) Accompany it with the complete corresponding machine-readable

+    source code, which must be distributed under the terms of Sections

+    1 and 2 above on a medium customarily used for software interchange; or,

+

+    b) Accompany it with a written offer, valid for at least three

+    years, to give any third party, for a charge no more than your

+    cost of physically performing source distribution, a complete

+    machine-readable copy of the corresponding source code, to be

+    distributed under the terms of Sections 1 and 2 above on a medium

+    customarily used for software interchange; or,

+

+    c) Accompany it with the information you received as to the offer

+    to distribute corresponding source code.  (This alternative is

+    allowed only for noncommercial distribution and only if you

+    received the program in object code or executable form with such

+    an offer, in accord with Subsection b above.)

+

+The source code for a work means the preferred form of the work for

+making modifications to it.  For an executable work, complete source

+code means all the source code for all modules it contains, plus any

+associated interface definition files, plus the scripts used to

+control compilation and installation of the executable.  However, as a

+special exception, the source code distributed need not include

+anything that is normally distributed (in either source or binary

+form) with the major components (compiler, kernel, and so on) of the

+operating system on which the executable runs, unless that component

+itself accompanies the executable.

+

+If distribution of executable or object code is made by offering

+access to copy from a designated place, then offering equivalent

+access to copy the source code from the same place counts as

+distribution of the source code, even though third parties are not

+compelled to copy the source along with the object code.

+

+  4. You may not copy, modify, sublicense, or distribute the Program

+except as expressly provided under this License.  Any attempt

+otherwise to copy, modify, sublicense or distribute the Program is

+void, and will automatically terminate your rights under this License.

+However, parties who have received copies, or rights, from you under

+this License will not have their licenses terminated so long as such

+parties remain in full compliance.

+

+  5. You are not required to accept this License, since you have not

+signed it.  However, nothing else grants you permission to modify or

+distribute the Program or its derivative works.  These actions are

+prohibited by law if you do not accept this License.  Therefore, by

+modifying or distributing the Program (or any work based on the

+Program), you indicate your acceptance of this License to do so, and

+all its terms and conditions for copying, distributing or modifying

+the Program or works based on it.

+

+  6. Each time you redistribute the Program (or any work based on the

+Program), the recipient automatically receives a license from the

+original licensor to copy, distribute or modify the Program subject to

+these terms and conditions.  You may not impose any further

+restrictions on the recipients' exercise of the rights granted herein.

+You are not responsible for enforcing compliance by third parties to

+this License.

+

+  7. If, as a consequence of a court judgment or allegation of patent

+infringement or for any other reason (not limited to patent issues),

+conditions are imposed on you (whether by court order, agreement or

+otherwise) that contradict the conditions of this License, they do not

+excuse you from the conditions of this License.  If you cannot

+distribute so as to satisfy simultaneously your obligations under this

+License and any other pertinent obligations, then as a consequence you

+may not distribute the Program at all.  For example, if a patent

+license would not permit royalty-free redistribution of the Program by

+all those who receive copies directly or indirectly through you, then

+the only way you could satisfy both it and this License would be to

+refrain entirely from distribution of the Program.

+

+If any portion of this section is held invalid or unenforceable under

+any particular circumstance, the balance of the section is intended to

+apply and the section as a whole is intended to apply in other

+circumstances.

+

+It is not the purpose of this section to induce you to infringe any

+patents or other property right claims or to contest validity of any

+such claims; this section has the sole purpose of protecting the

+integrity of the free software distribution system, which is

+implemented by public license practices.  Many people have made

+generous contributions to the wide range of software distributed

+through that system in reliance on consistent application of that

+system; it is up to the author/donor to decide if he or she is willing

+to distribute software through any other system and a licensee cannot

+impose that choice.

+

+This section is intended to make thoroughly clear what is believed to

+be a consequence of the rest of this License.

+

+  8. If the distribution and/or use of the Program is restricted in

+certain countries either by patents or by copyrighted interfaces, the

+original copyright holder who places the Program under this License

+may add an explicit geographical distribution limitation excluding

+those countries, so that distribution is permitted only in or among

+countries not thus excluded.  In such case, this License incorporates

+the limitation as if written in the body of this License.

+

+  9. The Free Software Foundation may publish revised and/or new versions

+of the General Public License from time to time.  Such new versions will

+be similar in spirit to the present version, but may differ in detail to

+address new problems or concerns.

+

+Each version is given a distinguishing version number.  If the Program

+specifies a version number of this License which applies to it and "any

+later version", you have the option of following the terms and conditions

+either of that version or of any later version published by the Free

+Software Foundation.  If the Program does not specify a version number of

+this License, you may choose any version ever published by the Free Software

+Foundation.

+

+  10. If you wish to incorporate parts of the Program into other free

+programs whose distribution conditions are different, write to the author

+to ask for permission.  For software which is copyrighted by the Free

+Software Foundation, write to the Free Software Foundation; we sometimes

+make exceptions for this.  Our decision will be guided by the two goals

+of preserving the free status of all derivatives of our free software and

+of promoting the sharing and reuse of software generally.

+

+			    NO WARRANTY

+

+  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY

+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN

+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES

+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED

+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS

+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE

+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,

+REPAIR OR CORRECTION.

+

+  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING

+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR

+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,

+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING

+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED

+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY

+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER

+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE

+POSSIBILITY OF SUCH DAMAGES.

+

+		     END OF TERMS AND CONDITIONS

+

+	    How to Apply These Terms to Your New Programs

+

+  If you develop a new program, and you want it to be of the greatest

+possible use to the public, the best way to achieve this is to make it

+free software which everyone can redistribute and change under these terms.

+

+  To do so, attach the following notices to the program.  It is safest

+to attach them to the start of each source file to most effectively

+convey the exclusion of warranty; and each file should have at least

+the "copyright" line and a pointer to where the full notice is found.

+

+    <one line to give the program's name and a brief idea of what it does.>

+    Copyright (C) <year>  <name of author>

+

+    This program is free software; you can redistribute it and/or modify

+    it under the terms of the GNU General Public License** as published by

+    the Free Software Foundation; either version 2 of the License, or

+    (at your option) any later version.

+

+    This program is distributed in the hope that it will be useful,

+    but WITHOUT ANY WARRANTY; without even the implied warranty of

+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the

+    GNU General Public License for more details.

+

+    You should have received a copy of the GNU General Public License

+    along with this program; if not, write to the Free Software

+    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

+

+

+Also add information on how to contact you by electronic and paper mail.

+

+If the program is interactive, make it output a short notice like this

+when it starts in an interactive mode:

+

+    Gnomovision version 69, Copyright (C) year name of author

+    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.

+    This is free software, and you are welcome to redistribute it

+    under certain conditions; type `show c' for details.

+

+The hypothetical commands `show w' and `show c' should show the appropriate

+parts of the General Public License.  Of course, the commands you use may

+be called something other than `show w' and `show c'; they could even be

+mouse-clicks or menu items--whatever suits your program.

+

+You should also get your employer (if you work as a programmer) or your

+school, if any, to sign a "copyright disclaimer" for the program, if

+necessary.  Here is a sample; alter the names:

+

+  Yoyodyne, Inc., hereby disclaims all copyright interest in the program

+  `Gnomovision' (which makes passes at compilers) written by James Hacker.

+

+  <signature of Ty Coon>, 1 April 1989

+  Ty Coon, President of Vice

+

+This General Public License does not permit incorporating your program into

+proprietary programs.  If your program is a subroutine library, you may

+consider it more useful to permit linking proprietary applications with the

+library.  If this is what you want to do, use the GNU Library General

+Public License instead of this License.

+

+----------------------------------------------------------------------------

+

+The FreeRTOS GPL Exception Text:

+

+Any FreeRTOS source code, whether modified or in it's original release form, 

+or whether in whole or in part, can only be distributed by you under the terms 

+of the GNU General Public License plus this exception. An independent module is 

+a module which is not derived from or based on FreeRTOS.

+

+Clause 1:

+

+Linking FreeRTOS statically or dynamically with other modules is making a 

+combined work based on FreeRTOS. Thus, the terms and conditions of the GNU 

+General Public License cover the whole combination.

+

+As a special exception, the copyright holder of FreeRTOS gives you permission 

+to link FreeRTOS with independent modules that communicate with FreeRTOS 

+solely through the FreeRTOS API interface, regardless of the license terms of 

+these independent modules, and to copy and distribute the resulting combined 

+work under terms of your choice, provided that

+

+  + Every copy of the combined work is accompanied by a written statement that 

+  details to the recipient the version of FreeRTOS used and an offer by yourself 

+  to provide the FreeRTOS source code (including any modifications you may have 

+  made) should the recipient request it.

+

+  + The combined work is not itself an RTOS, scheduler, kernel or related product.

+

+  + The independent modules add significant and primary functionality to FreeRTOS 

+  and do not merely extend the existing functionality already present in FreeRTOS.

+

+Clause 2:

+

+FreeRTOS may not be used for any competitive or comparative purpose, including the 

+publication of any form of run time or compile time metric, without the express 

+permission of Real Time Engineers Ltd. (this is the norm within the industry and 

+is intended to ensure information accuracy).

diff --git a/FreeRTOS/Source/croutine.c b/FreeRTOS/Source/croutine.c
new file mode 100644
index 0000000..0d62ca0
--- /dev/null
+++ b/FreeRTOS/Source/croutine.c
@@ -0,0 +1,387 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "croutine.h"

+

+/*

+ * Some kernel aware debuggers require data to be viewed to be global, rather

+ * than file scope.

+ */

+#ifdef portREMOVE_STATIC_QUALIFIER

+	#define static

+#endif

+

+

+/* Lists for ready and blocked co-routines. --------------------*/

+static xList pxReadyCoRoutineLists[ configMAX_CO_ROUTINE_PRIORITIES ];	/*< Prioritised ready co-routines. */

+static xList xDelayedCoRoutineList1;									/*< Delayed co-routines. */

+static xList xDelayedCoRoutineList2;									/*< Delayed co-routines (two lists are used - one for delays that have overflowed the current tick count. */

+static xList * pxDelayedCoRoutineList;									/*< Points to the delayed co-routine list currently being used. */

+static xList * pxOverflowDelayedCoRoutineList;							/*< Points to the delayed co-routine list currently being used to hold co-routines that have overflowed the current tick count. */

+static xList xPendingReadyCoRoutineList;											/*< Holds co-routines that have been readied by an external event.  They cannot be added directly to the ready lists as the ready lists cannot be accessed by interrupts. */

+

+/* Other file private variables. --------------------------------*/

+corCRCB * pxCurrentCoRoutine = NULL;

+static unsigned portBASE_TYPE uxTopCoRoutineReadyPriority = 0;

+static portTickType xCoRoutineTickCount = 0, xLastTickCount = 0, xPassedTicks = 0;

+

+/* The initial state of the co-routine when it is created. */

+#define corINITIAL_STATE	( 0 )

+

+/*

+ * Place the co-routine represented by pxCRCB into the appropriate ready queue

+ * for the priority.  It is inserted at the end of the list.

+ *

+ * This macro accesses the co-routine ready lists and therefore must not be

+ * used from within an ISR.

+ */

+#define prvAddCoRoutineToReadyQueue( pxCRCB )																		\

+{																													\

+	if( pxCRCB->uxPriority > uxTopCoRoutineReadyPriority )															\

+	{																												\

+		uxTopCoRoutineReadyPriority = pxCRCB->uxPriority;															\

+	}																												\

+	vListInsertEnd( ( xList * ) &( pxReadyCoRoutineLists[ pxCRCB->uxPriority ] ), &( pxCRCB->xGenericListItem ) );	\

+}	

+

+/*

+ * Utility to ready all the lists used by the scheduler.  This is called

+ * automatically upon the creation of the first co-routine.

+ */

+static void prvInitialiseCoRoutineLists( void );

+

+/*

+ * Co-routines that are readied by an interrupt cannot be placed directly into

+ * the ready lists (there is no mutual exclusion).  Instead they are placed in

+ * in the pending ready list in order that they can later be moved to the ready

+ * list by the co-routine scheduler.

+ */

+static void prvCheckPendingReadyList( void );

+

+/*

+ * Macro that looks at the list of co-routines that are currently delayed to

+ * see if any require waking.

+ *

+ * Co-routines are stored in the queue in the order of their wake time -

+ * meaning once one co-routine has been found whose timer has not expired

+ * we need not look any further down the list.

+ */

+static void prvCheckDelayedList( void );

+

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xCoRoutineCreate( crCOROUTINE_CODE pxCoRoutineCode, unsigned portBASE_TYPE uxPriority, unsigned portBASE_TYPE uxIndex )

+{

+signed portBASE_TYPE xReturn;

+corCRCB *pxCoRoutine;

+

+	/* Allocate the memory that will store the co-routine control block. */

+	pxCoRoutine = ( corCRCB * ) pvPortMalloc( sizeof( corCRCB ) );

+	if( pxCoRoutine )

+	{

+		/* If pxCurrentCoRoutine is NULL then this is the first co-routine to

+		be created and the co-routine data structures need initialising. */

+		if( pxCurrentCoRoutine == NULL )

+		{

+			pxCurrentCoRoutine = pxCoRoutine;

+			prvInitialiseCoRoutineLists();

+		}

+

+		/* Check the priority is within limits. */

+		if( uxPriority >= configMAX_CO_ROUTINE_PRIORITIES )

+		{

+			uxPriority = configMAX_CO_ROUTINE_PRIORITIES - 1;

+		}

+

+		/* Fill out the co-routine control block from the function parameters. */

+		pxCoRoutine->uxState = corINITIAL_STATE;

+		pxCoRoutine->uxPriority = uxPriority;

+		pxCoRoutine->uxIndex = uxIndex;

+		pxCoRoutine->pxCoRoutineFunction = pxCoRoutineCode;

+

+		/* Initialise all the other co-routine control block parameters. */

+		vListInitialiseItem( &( pxCoRoutine->xGenericListItem ) );

+		vListInitialiseItem( &( pxCoRoutine->xEventListItem ) );

+

+		/* Set the co-routine control block as a link back from the xListItem.

+		This is so we can get back to the containing CRCB from a generic item

+		in a list. */

+		listSET_LIST_ITEM_OWNER( &( pxCoRoutine->xGenericListItem ), pxCoRoutine );

+		listSET_LIST_ITEM_OWNER( &( pxCoRoutine->xEventListItem ), pxCoRoutine );

+	

+		/* Event lists are always in priority order. */

+		listSET_LIST_ITEM_VALUE( &( pxCoRoutine->xEventListItem ), configMAX_PRIORITIES - ( portTickType ) uxPriority );

+		

+		/* Now the co-routine has been initialised it can be added to the ready

+		list at the correct priority. */

+		prvAddCoRoutineToReadyQueue( pxCoRoutine );

+

+		xReturn = pdPASS;

+	}

+	else

+	{		

+		xReturn = errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY;

+	}

+	

+	return xReturn;	

+}

+/*-----------------------------------------------------------*/

+

+void vCoRoutineAddToDelayedList( portTickType xTicksToDelay, xList *pxEventList )

+{

+portTickType xTimeToWake;

+

+	/* Calculate the time to wake - this may overflow but this is

+	not a problem. */

+	xTimeToWake = xCoRoutineTickCount + xTicksToDelay;

+

+	/* We must remove ourselves from the ready list before adding

+	ourselves to the blocked list as the same list item is used for

+	both lists. */

+	vListRemove( ( xListItem * ) &( pxCurrentCoRoutine->xGenericListItem ) );

+

+	/* The list item will be inserted in wake time order. */

+	listSET_LIST_ITEM_VALUE( &( pxCurrentCoRoutine->xGenericListItem ), xTimeToWake );

+

+	if( xTimeToWake < xCoRoutineTickCount )

+	{

+		/* Wake time has overflowed.  Place this item in the

+		overflow list. */

+		vListInsert( ( xList * ) pxOverflowDelayedCoRoutineList, ( xListItem * ) &( pxCurrentCoRoutine->xGenericListItem ) );

+	}

+	else

+	{

+		/* The wake time has not overflowed, so we can use the

+		current block list. */

+		vListInsert( ( xList * ) pxDelayedCoRoutineList, ( xListItem * ) &( pxCurrentCoRoutine->xGenericListItem ) );

+	}

+

+	if( pxEventList )

+	{

+		/* Also add the co-routine to an event list.  If this is done then the

+		function must be called with interrupts disabled. */

+		vListInsert( pxEventList, &( pxCurrentCoRoutine->xEventListItem ) );

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvCheckPendingReadyList( void )

+{

+	/* Are there any co-routines waiting to get moved to the ready list?  These

+	are co-routines that have been readied by an ISR.  The ISR cannot access

+	the	ready lists itself. */

+	while( listLIST_IS_EMPTY( &xPendingReadyCoRoutineList ) == pdFALSE )

+	{

+		corCRCB *pxUnblockedCRCB;

+

+		/* The pending ready list can be accessed by an ISR. */

+		portDISABLE_INTERRUPTS();

+		{	

+			pxUnblockedCRCB = ( corCRCB * ) listGET_OWNER_OF_HEAD_ENTRY( (&xPendingReadyCoRoutineList) );			

+			vListRemove( &( pxUnblockedCRCB->xEventListItem ) );

+		}

+		portENABLE_INTERRUPTS();

+

+		vListRemove( &( pxUnblockedCRCB->xGenericListItem ) );

+		prvAddCoRoutineToReadyQueue( pxUnblockedCRCB );	

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvCheckDelayedList( void )

+{

+corCRCB *pxCRCB;

+

+	xPassedTicks = xTaskGetTickCount() - xLastTickCount;

+	while( xPassedTicks )

+	{

+		xCoRoutineTickCount++;

+		xPassedTicks--;

+

+		/* If the tick count has overflowed we need to swap the ready lists. */

+		if( xCoRoutineTickCount == 0 )

+		{

+			xList * pxTemp;

+

+			/* Tick count has overflowed so we need to swap the delay lists.  If there are

+			any items in pxDelayedCoRoutineList here then there is an error! */

+			pxTemp = pxDelayedCoRoutineList;

+			pxDelayedCoRoutineList = pxOverflowDelayedCoRoutineList;

+			pxOverflowDelayedCoRoutineList = pxTemp;

+		}

+

+		/* See if this tick has made a timeout expire. */

+		while( listLIST_IS_EMPTY( pxDelayedCoRoutineList ) == pdFALSE )

+		{

+			pxCRCB = ( corCRCB * ) listGET_OWNER_OF_HEAD_ENTRY( pxDelayedCoRoutineList );

+

+			if( xCoRoutineTickCount < listGET_LIST_ITEM_VALUE( &( pxCRCB->xGenericListItem ) ) )				

+			{			

+				/* Timeout not yet expired. */																			

+				break;																				

+			}																						

+

+			portDISABLE_INTERRUPTS();

+			{

+				/* The event could have occurred just before this critical

+				section.  If this is the case then the generic list item will

+				have been moved to the pending ready list and the following

+				line is still valid.  Also the pvContainer parameter will have

+				been set to NULL so the following lines are also valid. */

+				vListRemove( &( pxCRCB->xGenericListItem ) );											

+

+				/* Is the co-routine waiting on an event also? */												

+				if( pxCRCB->xEventListItem.pvContainer )													

+				{															

+					vListRemove( &( pxCRCB->xEventListItem ) );											

+				}

+			}

+			portENABLE_INTERRUPTS();

+

+			prvAddCoRoutineToReadyQueue( pxCRCB );													

+		}																									

+	}

+

+	xLastTickCount = xCoRoutineTickCount;

+}

+/*-----------------------------------------------------------*/

+

+void vCoRoutineSchedule( void )

+{

+	/* See if any co-routines readied by events need moving to the ready lists. */

+	prvCheckPendingReadyList();

+

+	/* See if any delayed co-routines have timed out. */

+	prvCheckDelayedList();

+

+	/* Find the highest priority queue that contains ready co-routines. */

+	while( listLIST_IS_EMPTY( &( pxReadyCoRoutineLists[ uxTopCoRoutineReadyPriority ] ) ) )

+	{

+		if( uxTopCoRoutineReadyPriority == 0 )

+		{

+			/* No more co-routines to check. */

+			return;

+		}

+		--uxTopCoRoutineReadyPriority;

+	}

+

+	/* listGET_OWNER_OF_NEXT_ENTRY walks through the list, so the co-routines

+	 of the	same priority get an equal share of the processor time. */

+	listGET_OWNER_OF_NEXT_ENTRY( pxCurrentCoRoutine, &( pxReadyCoRoutineLists[ uxTopCoRoutineReadyPriority ] ) );

+

+	/* Call the co-routine. */

+	( pxCurrentCoRoutine->pxCoRoutineFunction )( pxCurrentCoRoutine, pxCurrentCoRoutine->uxIndex );

+

+	return;

+}

+/*-----------------------------------------------------------*/

+

+static void prvInitialiseCoRoutineLists( void )

+{

+unsigned portBASE_TYPE uxPriority;

+

+	for( uxPriority = 0; uxPriority < configMAX_CO_ROUTINE_PRIORITIES; uxPriority++ )

+	{

+		vListInitialise( ( xList * ) &( pxReadyCoRoutineLists[ uxPriority ] ) );

+	}

+

+	vListInitialise( ( xList * ) &xDelayedCoRoutineList1 );

+	vListInitialise( ( xList * ) &xDelayedCoRoutineList2 );

+	vListInitialise( ( xList * ) &xPendingReadyCoRoutineList );

+

+	/* Start with pxDelayedCoRoutineList using list1 and the

+	pxOverflowDelayedCoRoutineList using list2. */

+	pxDelayedCoRoutineList = &xDelayedCoRoutineList1;

+	pxOverflowDelayedCoRoutineList = &xDelayedCoRoutineList2;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xCoRoutineRemoveFromEventList( const xList *pxEventList )

+{

+corCRCB *pxUnblockedCRCB;

+signed portBASE_TYPE xReturn;

+

+	/* This function is called from within an interrupt.  It can only access

+	event lists and the pending ready list.  This function assumes that a

+	check has already been made to ensure pxEventList is not empty. */

+	pxUnblockedCRCB = ( corCRCB * ) listGET_OWNER_OF_HEAD_ENTRY( pxEventList );

+	vListRemove( &( pxUnblockedCRCB->xEventListItem ) );

+	vListInsertEnd( ( xList * ) &( xPendingReadyCoRoutineList ), &( pxUnblockedCRCB->xEventListItem ) );

+

+	if( pxUnblockedCRCB->uxPriority >= pxCurrentCoRoutine->uxPriority )

+	{

+		xReturn = pdTRUE;

+	}

+	else

+	{

+		xReturn = pdFALSE;

+	}

+

+	return xReturn;

+}

+

diff --git a/FreeRTOS/Source/include/FreeRTOS.h b/FreeRTOS/Source/include/FreeRTOS.h
new file mode 100644
index 0000000..fd9027d
--- /dev/null
+++ b/FreeRTOS/Source/include/FreeRTOS.h
@@ -0,0 +1,528 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef INC_FREERTOS_H

+#define INC_FREERTOS_H

+

+

+/*

+ * Include the generic headers required for the FreeRTOS port being used.

+ */

+#include <stddef.h>

+

+/* Basic FreeRTOS definitions. */

+#include "projdefs.h"

+

+/* Application specific configuration options. */

+#include "FreeRTOSConfig.h"

+

+/* Definitions specific to the port being used. */

+#include "portable.h"

+

+#ifdef __cplusplus

+#define cast_to_freeRTOS_string(s) (reinterpret_cast<const signed char*>(s))

+#else

+#define cast_to_freeRTOS_string(s) ((const signed char *)(s))

+#endif

+

+

+/* Defines the prototype to which the application task hook function must

+conform. */

+typedef portBASE_TYPE (*pdTASK_HOOK_CODE)( void * );

+

+

+

+

+

+/*

+ * Check all the required application specific macros have been defined.

+ * These macros are application specific and (as downloaded) are defined

+ * within FreeRTOSConfig.h.

+ */

+

+#ifndef configUSE_PREEMPTION

+	#error Missing definition:  configUSE_PREEMPTION should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef configUSE_IDLE_HOOK

+	#error Missing definition:  configUSE_IDLE_HOOK should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef configUSE_TICK_HOOK

+	#error Missing definition:  configUSE_TICK_HOOK should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef configUSE_CO_ROUTINES

+	#error  Missing definition:  configUSE_CO_ROUTINES should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_vTaskPrioritySet

+	#error Missing definition:  INCLUDE_vTaskPrioritySet should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_uxTaskPriorityGet

+	#error Missing definition:  INCLUDE_uxTaskPriorityGet should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_vTaskDelete		

+	#error Missing definition:  INCLUDE_vTaskDelete		 should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_vTaskSuspend	

+	#error Missing definition:  INCLUDE_vTaskSuspend	 should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_vTaskDelayUntil

+	#error Missing definition:  INCLUDE_vTaskDelayUntil should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_vTaskDelay

+	#error Missing definition:  INCLUDE_vTaskDelay should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef configUSE_16_BIT_TICKS

+	#error Missing definition:  configUSE_16_BIT_TICKS should be defined in FreeRTOSConfig.h as either 1 or 0.  See the Configuration section of the FreeRTOS API documentation for details.

+#endif

+

+#ifndef INCLUDE_xTaskGetIdleTaskHandle

+	#define INCLUDE_xTaskGetIdleTaskHandle 0

+#endif

+

+#ifndef INCLUDE_xTimerGetTimerDaemonTaskHandle

+	#define INCLUDE_xTimerGetTimerDaemonTaskHandle 0

+#endif

+

+#ifndef INCLUDE_xQueueGetMutexHolder

+	#define INCLUDE_xQueueGetMutexHolder 0

+#endif

+

+#ifndef INCLUDE_pcTaskGetTaskName

+	#define INCLUDE_pcTaskGetTaskName 0

+#endif

+

+#ifndef configUSE_APPLICATION_TASK_TAG

+	#define configUSE_APPLICATION_TASK_TAG 0

+#endif

+

+#ifndef INCLUDE_uxTaskGetStackHighWaterMark

+	#define INCLUDE_uxTaskGetStackHighWaterMark 0

+#endif

+

+#ifndef configUSE_RECURSIVE_MUTEXES

+	#define configUSE_RECURSIVE_MUTEXES 0

+#endif

+

+#ifndef configUSE_MUTEXES

+	#define configUSE_MUTEXES 0

+#endif

+

+#ifndef configUSE_TIMERS

+	#define configUSE_TIMERS 0

+#endif

+

+#ifndef configUSE_COUNTING_SEMAPHORES

+	#define configUSE_COUNTING_SEMAPHORES 0

+#endif

+

+#ifndef configUSE_ALTERNATIVE_API

+	#define configUSE_ALTERNATIVE_API 0

+#endif

+

+#ifndef portCRITICAL_NESTING_IN_TCB

+	#define portCRITICAL_NESTING_IN_TCB 0

+#endif

+

+#ifndef configMAX_TASK_NAME_LEN

+	#define configMAX_TASK_NAME_LEN 16

+#endif

+

+#ifndef configIDLE_SHOULD_YIELD

+	#define configIDLE_SHOULD_YIELD		1

+#endif

+

+#if configMAX_TASK_NAME_LEN < 1

+	#error configMAX_TASK_NAME_LEN must be set to a minimum of 1 in FreeRTOSConfig.h

+#endif

+

+#ifndef INCLUDE_xTaskResumeFromISR

+	#define INCLUDE_xTaskResumeFromISR 1

+#endif

+

+#ifndef configASSERT

+	#define configASSERT( x )

+#endif

+

+#ifndef portALIGNMENT_ASSERT_pxCurrentTCB

+	#define portALIGNMENT_ASSERT_pxCurrentTCB configASSERT

+#endif

+

+/* The timers module relies on xTaskGetSchedulerState(). */

+#if configUSE_TIMERS == 1

+

+	#ifndef configTIMER_TASK_PRIORITY

+		#error If configUSE_TIMERS is set to 1 then configTIMER_TASK_PRIORITY must also be defined.

+	#endif /* configTIMER_TASK_PRIORITY */

+

+	#ifndef configTIMER_QUEUE_LENGTH

+		#error If configUSE_TIMERS is set to 1 then configTIMER_QUEUE_LENGTH must also be defined.

+	#endif /* configTIMER_QUEUE_LENGTH */

+

+	#ifndef configTIMER_TASK_STACK_DEPTH

+		#error If configUSE_TIMERS is set to 1 then configTIMER_TASK_STACK_DEPTH must also be defined.

+	#endif /* configTIMER_TASK_STACK_DEPTH */

+

+#endif /* configUSE_TIMERS */

+

+#ifndef INCLUDE_xTaskGetSchedulerState

+	#define INCLUDE_xTaskGetSchedulerState 0

+#endif

+

+#ifndef INCLUDE_xTaskGetCurrentTaskHandle

+	#define INCLUDE_xTaskGetCurrentTaskHandle 0

+#endif

+

+

+#ifndef portSET_INTERRUPT_MASK_FROM_ISR

+	#define portSET_INTERRUPT_MASK_FROM_ISR() 0

+#endif

+

+#ifndef portCLEAR_INTERRUPT_MASK_FROM_ISR

+	#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusValue ) ( void ) uxSavedStatusValue

+#endif

+

+#ifndef portCLEAN_UP_TCB

+	#define portCLEAN_UP_TCB( pxTCB ) ( void ) pxTCB

+#endif

+

+#ifndef portSETUP_TCB

+	#define portSETUP_TCB( pxTCB ) ( void ) pxTCB

+#endif

+

+#ifndef configQUEUE_REGISTRY_SIZE

+	#define configQUEUE_REGISTRY_SIZE 0U

+#endif

+

+#if ( configQUEUE_REGISTRY_SIZE < 1 )

+	#define vQueueAddToRegistry( xQueue, pcName )

+	#define vQueueUnregisterQueue( xQueue )

+#endif

+

+#ifndef portPOINTER_SIZE_TYPE

+	#define portPOINTER_SIZE_TYPE unsigned long

+#endif

+

+/* Remove any unused trace macros. */

+#ifndef traceSTART

+	/* Used to perform any necessary initialisation - for example, open a file

+	into which trace is to be written. */

+	#define traceSTART()

+#endif

+

+#ifndef traceEND

+	/* Use to close a trace, for example close a file into which trace has been

+	written. */

+	#define traceEND()

+#endif

+

+#ifndef traceTASK_SWITCHED_IN

+	/* Called after a task has been selected to run.  pxCurrentTCB holds a pointer

+	to the task control block of the selected task. */

+	#define traceTASK_SWITCHED_IN()

+#endif

+

+#ifndef traceTASK_SWITCHED_OUT

+	/* Called before a task has been selected to run.  pxCurrentTCB holds a pointer

+	to the task control block of the task being switched out. */

+	#define traceTASK_SWITCHED_OUT()

+#endif

+

+#ifndef traceTASK_PRIORITY_INHERIT

+	/* Called when a task attempts to take a mutex that is already held by a

+	lower priority task.  pxTCBOfMutexHolder is a pointer to the TCB of the task

+	that holds the mutex.  uxInheritedPriority is the priority the mutex holder

+	will inherit (the priority of the task that is attempting to obtain the

+	muted. */

+	#define traceTASK_PRIORITY_INHERIT( pxTCBOfMutexHolder, uxInheritedPriority )

+#endif

+

+#ifndef traceTASK_PRIORITY_DISINHERIT

+	/* Called when a task releases a mutex, the holding of which had resulted in

+	the task inheriting the priority of a higher priority task.  

+	pxTCBOfMutexHolder is a pointer to the TCB of the task that is releasing the

+	mutex.  uxOriginalPriority is the task's configured (base) priority. */

+	#define traceTASK_PRIORITY_DISINHERIT( pxTCBOfMutexHolder, uxOriginalPriority )

+#endif

+

+#ifndef traceBLOCKING_ON_QUEUE_RECEIVE

+	/* Task is about to block because it cannot read from a

+	queue/mutex/semaphore.  pxQueue is a pointer to the queue/mutex/semaphore

+	upon which the read was attempted.  pxCurrentTCB points to the TCB of the

+	task that attempted the read. */

+	#define traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue )

+#endif

+

+#ifndef traceBLOCKING_ON_QUEUE_SEND

+	/* Task is about to block because it cannot write to a

+	queue/mutex/semaphore.  pxQueue is a pointer to the queue/mutex/semaphore

+	upon which the write was attempted.  pxCurrentTCB points to the TCB of the

+	task that attempted the write. */

+	#define traceBLOCKING_ON_QUEUE_SEND( pxQueue )

+#endif

+

+#ifndef configCHECK_FOR_STACK_OVERFLOW

+	#define configCHECK_FOR_STACK_OVERFLOW 0

+#endif

+

+/* The following event macros are embedded in the kernel API calls. */

+

+#ifndef traceMOVED_TASK_TO_READY_STATE

+	#define traceMOVED_TASK_TO_READY_STATE( pxTCB )

+#endif

+

+#ifndef traceQUEUE_CREATE	

+	#define traceQUEUE_CREATE( pxNewQueue )

+#endif

+

+#ifndef traceQUEUE_CREATE_FAILED

+	#define traceQUEUE_CREATE_FAILED( ucQueueType )

+#endif

+

+#ifndef traceCREATE_MUTEX

+	#define traceCREATE_MUTEX( pxNewQueue )

+#endif

+

+#ifndef traceCREATE_MUTEX_FAILED

+	#define traceCREATE_MUTEX_FAILED()

+#endif

+

+#ifndef traceGIVE_MUTEX_RECURSIVE

+	#define traceGIVE_MUTEX_RECURSIVE( pxMutex )

+#endif

+

+#ifndef traceGIVE_MUTEX_RECURSIVE_FAILED

+	#define traceGIVE_MUTEX_RECURSIVE_FAILED( pxMutex )

+#endif

+

+#ifndef traceTAKE_MUTEX_RECURSIVE

+	#define traceTAKE_MUTEX_RECURSIVE( pxMutex )

+#endif

+

+#ifndef traceTAKE_MUTEX_RECURSIVE_FAILED

+	#define traceTAKE_MUTEX_RECURSIVE_FAILED( pxMutex )

+#endif

+

+#ifndef traceCREATE_COUNTING_SEMAPHORE

+	#define traceCREATE_COUNTING_SEMAPHORE()

+#endif

+

+#ifndef traceCREATE_COUNTING_SEMAPHORE_FAILED

+	#define traceCREATE_COUNTING_SEMAPHORE_FAILED()

+#endif

+

+#ifndef traceQUEUE_SEND

+	#define traceQUEUE_SEND( pxQueue )

+#endif

+

+#ifndef traceQUEUE_SEND_FAILED

+	#define traceQUEUE_SEND_FAILED( pxQueue )

+#endif

+

+#ifndef traceQUEUE_RECEIVE

+	#define traceQUEUE_RECEIVE( pxQueue )

+#endif

+

+#ifndef traceQUEUE_PEEK

+	#define traceQUEUE_PEEK( pxQueue )

+#endif

+

+#ifndef traceQUEUE_RECEIVE_FAILED

+	#define traceQUEUE_RECEIVE_FAILED( pxQueue )

+#endif

+

+#ifndef traceQUEUE_SEND_FROM_ISR

+	#define traceQUEUE_SEND_FROM_ISR( pxQueue )

+#endif

+

+#ifndef traceQUEUE_SEND_FROM_ISR_FAILED

+	#define traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue )

+#endif

+

+#ifndef traceQUEUE_RECEIVE_FROM_ISR

+	#define traceQUEUE_RECEIVE_FROM_ISR( pxQueue )

+#endif

+

+#ifndef traceQUEUE_RECEIVE_FROM_ISR_FAILED

+	#define traceQUEUE_RECEIVE_FROM_ISR_FAILED( pxQueue )

+#endif

+

+#ifndef traceQUEUE_DELETE

+	#define traceQUEUE_DELETE( pxQueue )

+#endif

+

+#ifndef traceTASK_CREATE

+	#define traceTASK_CREATE( pxNewTCB )

+#endif

+

+#ifndef traceTASK_CREATE_FAILED

+	#define traceTASK_CREATE_FAILED()

+#endif

+

+#ifndef traceTASK_DELETE

+	#define traceTASK_DELETE( pxTaskToDelete )

+#endif

+

+#ifndef traceTASK_DELAY_UNTIL

+	#define traceTASK_DELAY_UNTIL()

+#endif

+

+#ifndef traceTASK_DELAY

+	#define traceTASK_DELAY()

+#endif

+

+#ifndef traceTASK_PRIORITY_SET

+	#define traceTASK_PRIORITY_SET( pxTask, uxNewPriority )

+#endif

+

+#ifndef traceTASK_SUSPEND

+	#define traceTASK_SUSPEND( pxTaskToSuspend )

+#endif

+

+#ifndef traceTASK_RESUME

+	#define traceTASK_RESUME( pxTaskToResume )

+#endif

+

+#ifndef traceTASK_RESUME_FROM_ISR

+	#define traceTASK_RESUME_FROM_ISR( pxTaskToResume )

+#endif

+

+#ifndef traceTASK_INCREMENT_TICK

+	#define traceTASK_INCREMENT_TICK( xTickCount )

+#endif

+

+#ifndef traceTIMER_CREATE

+	#define traceTIMER_CREATE( pxNewTimer )

+#endif

+

+#ifndef traceTIMER_CREATE_FAILED

+	#define traceTIMER_CREATE_FAILED()

+#endif

+

+#ifndef traceTIMER_COMMAND_SEND

+	#define traceTIMER_COMMAND_SEND( xTimer, xMessageID, xMessageValueValue, xReturn )

+#endif

+

+#ifndef traceTIMER_EXPIRED

+	#define traceTIMER_EXPIRED( pxTimer )

+#endif

+

+#ifndef traceTIMER_COMMAND_RECEIVED

+	#define traceTIMER_COMMAND_RECEIVED( pxTimer, xMessageID, xMessageValue )

+#endif

+

+#ifndef configGENERATE_RUN_TIME_STATS

+	#define configGENERATE_RUN_TIME_STATS 0

+#endif

+

+#if ( configGENERATE_RUN_TIME_STATS == 1 )

+

+	#ifndef portCONFIGURE_TIMER_FOR_RUN_TIME_STATS

+		#error If configGENERATE_RUN_TIME_STATS is defined then portCONFIGURE_TIMER_FOR_RUN_TIME_STATS must also be defined.  portCONFIGURE_TIMER_FOR_RUN_TIME_STATS should call a port layer function to setup a peripheral timer/counter that can then be used as the run time counter time base.

+	#endif /* portCONFIGURE_TIMER_FOR_RUN_TIME_STATS */

+

+	#ifndef portGET_RUN_TIME_COUNTER_VALUE

+		#ifndef portALT_GET_RUN_TIME_COUNTER_VALUE

+			#error If configGENERATE_RUN_TIME_STATS is defined then either portGET_RUN_TIME_COUNTER_VALUE or portALT_GET_RUN_TIME_COUNTER_VALUE must also be defined.  See the examples provided and the FreeRTOS web site for more information.

+		#endif /* portALT_GET_RUN_TIME_COUNTER_VALUE */

+	#endif /* portGET_RUN_TIME_COUNTER_VALUE */

+

+#endif /* configGENERATE_RUN_TIME_STATS */

+

+#ifndef portCONFIGURE_TIMER_FOR_RUN_TIME_STATS

+	#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS()

+#endif

+

+#ifndef configUSE_MALLOC_FAILED_HOOK

+	#define configUSE_MALLOC_FAILED_HOOK 0

+#endif

+

+#ifndef portPRIVILEGE_BIT

+	#define portPRIVILEGE_BIT ( ( unsigned portBASE_TYPE ) 0x00 )

+#endif

+

+#ifndef portYIELD_WITHIN_API

+	#define portYIELD_WITHIN_API portYIELD

+#endif

+

+#ifndef pvPortMallocAligned

+	#define pvPortMallocAligned( x, puxStackBuffer ) ( ( ( puxStackBuffer ) == NULL ) ? ( pvPortMalloc( ( x ) ) ) : ( puxStackBuffer ) )

+#endif

+

+#ifndef vPortFreeAligned

+	#define vPortFreeAligned( pvBlockToFree ) vPortFree( pvBlockToFree )

+#endif

+

+#endif /* INC_FREERTOS_H */

+

diff --git a/FreeRTOS/Source/include/StackMacros.h b/FreeRTOS/Source/include/StackMacros.h
new file mode 100644
index 0000000..daf3ce4
--- /dev/null
+++ b/FreeRTOS/Source/include/StackMacros.h
@@ -0,0 +1,181 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef STACK_MACROS_H

+#define STACK_MACROS_H

+

+/*

+ * Call the stack overflow hook function if the stack of the task being swapped

+ * out is currently overflowed, or looks like it might have overflowed in the

+ * past.

+ *

+ * Setting configCHECK_FOR_STACK_OVERFLOW to 1 will cause the macro to check

+ * the current stack state only - comparing the current top of stack value to

+ * the stack limit.  Setting configCHECK_FOR_STACK_OVERFLOW to greater than 1

+ * will also cause the last few stack bytes to be checked to ensure the value

+ * to which the bytes were set when the task was created have not been

+ * overwritten.  Note this second test does not guarantee that an overflowed

+ * stack will always be recognised.

+ */

+

+/*-----------------------------------------------------------*/

+

+#if( configCHECK_FOR_STACK_OVERFLOW == 0 )

+

+	/* FreeRTOSConfig.h is not set to check for stack overflows. */

+	#define taskFIRST_CHECK_FOR_STACK_OVERFLOW()

+	#define taskSECOND_CHECK_FOR_STACK_OVERFLOW()

+

+#endif /* configCHECK_FOR_STACK_OVERFLOW == 0 */

+/*-----------------------------------------------------------*/

+

+#if( configCHECK_FOR_STACK_OVERFLOW == 1 )

+

+	/* FreeRTOSConfig.h is only set to use the first method of

+	overflow checking. */

+	#define taskSECOND_CHECK_FOR_STACK_OVERFLOW()

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if( ( configCHECK_FOR_STACK_OVERFLOW > 0 ) && ( portSTACK_GROWTH < 0 ) )

+

+	/* Only the current stack state is to be checked. */

+	#define taskFIRST_CHECK_FOR_STACK_OVERFLOW()														\

+	{																									\

+		/* Is the currently saved stack pointer within the stack limit? */								\

+		if( pxCurrentTCB->pxTopOfStack <= pxCurrentTCB->pxStack )										\

+		{																								\

+			vApplicationStackOverflowHook( ( xTaskHandle ) pxCurrentTCB, pxCurrentTCB->pcTaskName );	\

+		}																								\

+	}

+

+#endif /* configCHECK_FOR_STACK_OVERFLOW > 0 */

+/*-----------------------------------------------------------*/

+

+#if( ( configCHECK_FOR_STACK_OVERFLOW > 0 ) && ( portSTACK_GROWTH > 0 ) )

+

+	/* Only the current stack state is to be checked. */

+	#define taskFIRST_CHECK_FOR_STACK_OVERFLOW()														\

+	{																									\

+																										\

+		/* Is the currently saved stack pointer within the stack limit? */								\

+		if( pxCurrentTCB->pxTopOfStack >= pxCurrentTCB->pxEndOfStack )									\

+		{																								\

+			vApplicationStackOverflowHook( ( xTaskHandle ) pxCurrentTCB, pxCurrentTCB->pcTaskName );	\

+		}																								\

+	}

+

+#endif /* configCHECK_FOR_STACK_OVERFLOW == 1 */

+/*-----------------------------------------------------------*/

+

+#if( ( configCHECK_FOR_STACK_OVERFLOW > 1 ) && ( portSTACK_GROWTH < 0 ) )

+

+	#define taskSECOND_CHECK_FOR_STACK_OVERFLOW()																								\

+	{																																			\

+	static const unsigned char ucExpectedStackBytes[] = {	tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE };	\

+																																				\

+																																				\

+		/* Has the extremity of the task stack ever been written over? */																		\

+		if( memcmp( ( void * ) pxCurrentTCB->pxStack, ( void * ) ucExpectedStackBytes, sizeof( ucExpectedStackBytes ) ) != 0 )					\

+		{																																		\

+			vApplicationStackOverflowHook( ( xTaskHandle ) pxCurrentTCB, pxCurrentTCB->pcTaskName );											\

+		}																																		\

+	}

+

+#endif /* #if( configCHECK_FOR_STACK_OVERFLOW > 1 ) */

+/*-----------------------------------------------------------*/

+

+#if( ( configCHECK_FOR_STACK_OVERFLOW > 1 ) && ( portSTACK_GROWTH > 0 ) )

+

+	#define taskSECOND_CHECK_FOR_STACK_OVERFLOW()																								\

+	{																																			\

+	char *pcEndOfStack = ( char * ) pxCurrentTCB->pxEndOfStack;																					\

+	static const unsigned char ucExpectedStackBytes[] = {	tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE,		\

+															tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE, tskSTACK_FILL_BYTE };	\

+																																				\

+																																				\

+		pcEndOfStack -= sizeof( ucExpectedStackBytes );																							\

+																																				\

+		/* Has the extremity of the task stack ever been written over? */																		\

+		if( memcmp( ( void * ) pcEndOfStack, ( void * ) ucExpectedStackBytes, sizeof( ucExpectedStackBytes ) ) != 0 )							\

+		{																																		\

+			vApplicationStackOverflowHook( ( xTaskHandle ) pxCurrentTCB, pxCurrentTCB->pcTaskName );											\

+		}																																		\

+	}

+

+#endif /* #if( configCHECK_FOR_STACK_OVERFLOW > 1 ) */

+/*-----------------------------------------------------------*/

+

+#endif /* STACK_MACROS_H */

+

diff --git a/FreeRTOS/Source/include/croutine.h b/FreeRTOS/Source/include/croutine.h
new file mode 100644
index 0000000..f2843cd
--- /dev/null
+++ b/FreeRTOS/Source/include/croutine.h
@@ -0,0 +1,759 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef CO_ROUTINE_H

+#define CO_ROUTINE_H

+

+#ifndef INC_FREERTOS_H

+	#error "include FreeRTOS.h must appear in source files before include croutine.h"

+#endif

+

+#include "list.h"

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* Used to hide the implementation of the co-routine control block.  The

+control block structure however has to be included in the header due to

+the macro implementation of the co-routine functionality. */

+typedef void * xCoRoutineHandle;

+

+/* Defines the prototype to which co-routine functions must conform. */

+typedef void (*crCOROUTINE_CODE)( xCoRoutineHandle, unsigned portBASE_TYPE );

+

+typedef struct corCoRoutineControlBlock

+{

+	crCOROUTINE_CODE 		pxCoRoutineFunction;

+	xListItem				xGenericListItem;	/*< List item used to place the CRCB in ready and blocked queues. */

+	xListItem				xEventListItem;		/*< List item used to place the CRCB in event lists. */

+	unsigned portBASE_TYPE 	uxPriority;			/*< The priority of the co-routine in relation to other co-routines. */

+	unsigned portBASE_TYPE 	uxIndex;			/*< Used to distinguish between co-routines when multiple co-routines use the same co-routine function. */

+	unsigned short 		uxState;			/*< Used internally by the co-routine implementation. */

+} corCRCB; /* Co-routine control block.  Note must be identical in size down to uxPriority with tskTCB. */

+

+/**

+ * croutine. h

+ *<pre>

+ portBASE_TYPE xCoRoutineCreate(

+                                 crCOROUTINE_CODE pxCoRoutineCode,

+                                 unsigned portBASE_TYPE uxPriority,

+                                 unsigned portBASE_TYPE uxIndex

+                               );</pre>

+ *

+ * Create a new co-routine and add it to the list of co-routines that are

+ * ready to run.

+ *

+ * @param pxCoRoutineCode Pointer to the co-routine function.  Co-routine

+ * functions require special syntax - see the co-routine section of the WEB

+ * documentation for more information.

+ *

+ * @param uxPriority The priority with respect to other co-routines at which

+ *  the co-routine will run.

+ *

+ * @param uxIndex Used to distinguish between different co-routines that

+ * execute the same function.  See the example below and the co-routine section

+ * of the WEB documentation for further information.

+ *

+ * @return pdPASS if the co-routine was successfully created and added to a ready

+ * list, otherwise an error code defined with ProjDefs.h.

+ *

+ * Example usage:

+   <pre>

+ // Co-routine to be created.

+ void vFlashCoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ // This may not be necessary for const variables.

+ static const char cLedToFlash[ 2 ] = { 5, 6 };

+ static const portTickType uxFlashRates[ 2 ] = { 200, 400 };

+

+     // Must start every co-routine with a call to crSTART();

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+         // This co-routine just delays for a fixed period, then toggles

+         // an LED.  Two co-routines are created using this function, so

+         // the uxIndex parameter is used to tell the co-routine which

+         // LED to flash and how long to delay.  This assumes xQueue has

+         // already been created.

+         vParTestToggleLED( cLedToFlash[ uxIndex ] );

+         crDELAY( xHandle, uxFlashRates[ uxIndex ] );

+     }

+

+     // Must end every co-routine with a call to crEND();

+     crEND();

+ }

+

+ // Function that creates two co-routines.

+ void vOtherFunction( void )

+ {

+ unsigned char ucParameterToPass;

+ xTaskHandle xHandle;

+		

+     // Create two co-routines at priority 0.  The first is given index 0

+     // so (from the code above) toggles LED 5 every 200 ticks.  The second

+     // is given index 1 so toggles LED 6 every 400 ticks.

+     for( uxIndex = 0; uxIndex < 2; uxIndex++ )

+     {

+         xCoRoutineCreate( vFlashCoRoutine, 0, uxIndex );

+     }

+ }

+   </pre>

+ * \defgroup xCoRoutineCreate xCoRoutineCreate

+ * \ingroup Tasks

+ */

+signed portBASE_TYPE xCoRoutineCreate( crCOROUTINE_CODE pxCoRoutineCode, unsigned portBASE_TYPE uxPriority, unsigned portBASE_TYPE uxIndex );

+

+

+/**

+ * croutine. h

+ *<pre>

+ void vCoRoutineSchedule( void );</pre>

+ *

+ * Run a co-routine.

+ *

+ * vCoRoutineSchedule() executes the highest priority co-routine that is able

+ * to run.  The co-routine will execute until it either blocks, yields or is

+ * preempted by a task.  Co-routines execute cooperatively so one

+ * co-routine cannot be preempted by another, but can be preempted by a task.

+ *

+ * If an application comprises of both tasks and co-routines then

+ * vCoRoutineSchedule should be called from the idle task (in an idle task

+ * hook).

+ *

+ * Example usage:

+   <pre>

+ // This idle task hook will schedule a co-routine each time it is called.

+ // The rest of the idle task will execute between co-routine calls.

+ void vApplicationIdleHook( void )

+ {

+	vCoRoutineSchedule();

+ }

+

+ // Alternatively, if you do not require any other part of the idle task to

+ // execute, the idle task hook can call vCoRoutineScheduler() within an

+ // infinite loop.

+ void vApplicationIdleHook( void )

+ {

+    for( ;; )

+    {

+        vCoRoutineSchedule();

+    }

+ }

+ </pre>

+ * \defgroup vCoRoutineSchedule vCoRoutineSchedule

+ * \ingroup Tasks

+ */

+void vCoRoutineSchedule( void );

+

+/**

+ * croutine. h

+ * <pre>

+ crSTART( xCoRoutineHandle xHandle );</pre>

+ *

+ * This macro MUST always be called at the start of a co-routine function.

+ *

+ * Example usage:

+   <pre>

+ // Co-routine to be created.

+ void vACoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ static long ulAVariable;

+

+     // Must start every co-routine with a call to crSTART();

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+          // Co-routine functionality goes here.

+     }

+

+     // Must end every co-routine with a call to crEND();

+     crEND();

+ }</pre>

+ * \defgroup crSTART crSTART

+ * \ingroup Tasks

+ */

+#define crSTART( pxCRCB ) switch( ( ( corCRCB * )( pxCRCB ) )->uxState ) { case 0:

+

+/**

+ * croutine. h

+ * <pre>

+ crEND();</pre>

+ *

+ * This macro MUST always be called at the end of a co-routine function.

+ *

+ * Example usage:

+   <pre>

+ // Co-routine to be created.

+ void vACoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ static long ulAVariable;

+

+     // Must start every co-routine with a call to crSTART();

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+          // Co-routine functionality goes here.

+     }

+

+     // Must end every co-routine with a call to crEND();

+     crEND();

+ }</pre>

+ * \defgroup crSTART crSTART

+ * \ingroup Tasks

+ */

+#define crEND() }

+

+/*

+ * These macros are intended for internal use by the co-routine implementation

+ * only.  The macros should not be used directly by application writers.

+ */

+#define crSET_STATE0( xHandle ) ( ( corCRCB * )( xHandle ) )->uxState = (__LINE__ * 2); return; case (__LINE__ * 2):

+#define crSET_STATE1( xHandle ) ( ( corCRCB * )( xHandle ) )->uxState = ((__LINE__ * 2)+1); return; case ((__LINE__ * 2)+1):

+

+/**

+ * croutine. h

+ *<pre>

+ crDELAY( xCoRoutineHandle xHandle, portTickType xTicksToDelay );</pre>

+ *

+ * Delay a co-routine for a fixed period of time.

+ *

+ * crDELAY can only be called from the co-routine function itself - not

+ * from within a function called by the co-routine function.  This is because

+ * co-routines do not maintain their own stack.

+ *

+ * @param xHandle The handle of the co-routine to delay.  This is the xHandle

+ * parameter of the co-routine function.

+ *

+ * @param xTickToDelay The number of ticks that the co-routine should delay

+ * for.  The actual amount of time this equates to is defined by

+ * configTICK_RATE_HZ (set in FreeRTOSConfig.h).  The constant portTICK_RATE_MS

+ * can be used to convert ticks to milliseconds.

+ *

+ * Example usage:

+   <pre>

+ // Co-routine to be created.

+ void vACoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ // This may not be necessary for const variables.

+ // We are to delay for 200ms.

+ static const xTickType xDelayTime = 200 / portTICK_RATE_MS;

+

+     // Must start every co-routine with a call to crSTART();

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+        // Delay for 200ms.

+        crDELAY( xHandle, xDelayTime );

+

+        // Do something here.

+     }

+

+     // Must end every co-routine with a call to crEND();

+     crEND();

+ }</pre>

+ * \defgroup crDELAY crDELAY

+ * \ingroup Tasks

+ */

+#define crDELAY( xHandle, xTicksToDelay )												\

+	if( ( xTicksToDelay ) > 0 )															\

+	{																					\

+		vCoRoutineAddToDelayedList( ( xTicksToDelay ), NULL );							\

+	}																					\

+	crSET_STATE0( ( xHandle ) );

+

+/**

+ * <pre>

+ crQUEUE_SEND(

+                  xCoRoutineHandle xHandle,

+                  xQueueHandle pxQueue,

+                  void *pvItemToQueue,

+                  portTickType xTicksToWait,

+                  portBASE_TYPE *pxResult

+             )</pre>

+ *

+ * The macro's crQUEUE_SEND() and crQUEUE_RECEIVE() are the co-routine

+ * equivalent to the xQueueSend() and xQueueReceive() functions used by tasks.

+ *

+ * crQUEUE_SEND and crQUEUE_RECEIVE can only be used from a co-routine whereas

+ * xQueueSend() and xQueueReceive() can only be used from tasks.

+ *

+ * crQUEUE_SEND can only be called from the co-routine function itself - not

+ * from within a function called by the co-routine function.  This is because

+ * co-routines do not maintain their own stack.

+ *

+ * See the co-routine section of the WEB documentation for information on

+ * passing data between tasks and co-routines and between ISR's and

+ * co-routines.

+ *

+ * @param xHandle The handle of the calling co-routine.  This is the xHandle

+ * parameter of the co-routine function.

+ *

+ * @param pxQueue The handle of the queue on which the data will be posted.

+ * The handle is obtained as the return value when the queue is created using

+ * the xQueueCreate() API function.

+ *

+ * @param pvItemToQueue A pointer to the data being posted onto the queue.

+ * The number of bytes of each queued item is specified when the queue is

+ * created.  This number of bytes is copied from pvItemToQueue into the queue

+ * itself.

+ *

+ * @param xTickToDelay The number of ticks that the co-routine should block

+ * to wait for space to become available on the queue, should space not be

+ * available immediately. The actual amount of time this equates to is defined

+ * by configTICK_RATE_HZ (set in FreeRTOSConfig.h).  The constant

+ * portTICK_RATE_MS can be used to convert ticks to milliseconds (see example

+ * below).

+ *

+ * @param pxResult The variable pointed to by pxResult will be set to pdPASS if

+ * data was successfully posted onto the queue, otherwise it will be set to an

+ * error defined within ProjDefs.h.

+ *

+ * Example usage:

+   <pre>

+ // Co-routine function that blocks for a fixed period then posts a number onto

+ // a queue.

+ static void prvCoRoutineFlashTask( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ static portBASE_TYPE xNumberToPost = 0;

+ static portBASE_TYPE xResult;

+

+    // Co-routines must begin with a call to crSTART().

+    crSTART( xHandle );

+

+    for( ;; )

+    {

+        // This assumes the queue has already been created.

+        crQUEUE_SEND( xHandle, xCoRoutineQueue, &xNumberToPost, NO_DELAY, &xResult );

+

+        if( xResult != pdPASS )

+        {

+            // The message was not posted!

+        }

+

+        // Increment the number to be posted onto the queue.

+        xNumberToPost++;

+

+        // Delay for 100 ticks.

+        crDELAY( xHandle, 100 );

+    }

+

+    // Co-routines must end with a call to crEND().

+    crEND();

+ }</pre>

+ * \defgroup crQUEUE_SEND crQUEUE_SEND

+ * \ingroup Tasks

+ */

+#define crQUEUE_SEND( xHandle, pxQueue, pvItemToQueue, xTicksToWait, pxResult )			\

+{																						\

+	*( pxResult ) = xQueueCRSend( ( pxQueue) , ( pvItemToQueue) , ( xTicksToWait ) );	\

+	if( *( pxResult ) == errQUEUE_BLOCKED )												\

+	{																					\

+		crSET_STATE0( ( xHandle ) );													\

+		*pxResult = xQueueCRSend( ( pxQueue ), ( pvItemToQueue ), 0 );					\

+	}																					\

+	if( *pxResult == errQUEUE_YIELD )													\

+	{																					\

+		crSET_STATE1( ( xHandle ) );													\

+		*pxResult = pdPASS;																\

+	}																					\

+}

+

+/**

+ * croutine. h

+ * <pre>

+  crQUEUE_RECEIVE(

+                     xCoRoutineHandle xHandle,

+                     xQueueHandle pxQueue,

+                     void *pvBuffer,

+                     portTickType xTicksToWait,

+                     portBASE_TYPE *pxResult

+                 )</pre>

+ *

+ * The macro's crQUEUE_SEND() and crQUEUE_RECEIVE() are the co-routine

+ * equivalent to the xQueueSend() and xQueueReceive() functions used by tasks.

+ *

+ * crQUEUE_SEND and crQUEUE_RECEIVE can only be used from a co-routine whereas

+ * xQueueSend() and xQueueReceive() can only be used from tasks.

+ *

+ * crQUEUE_RECEIVE can only be called from the co-routine function itself - not

+ * from within a function called by the co-routine function.  This is because

+ * co-routines do not maintain their own stack.

+ *

+ * See the co-routine section of the WEB documentation for information on

+ * passing data between tasks and co-routines and between ISR's and

+ * co-routines.

+ *

+ * @param xHandle The handle of the calling co-routine.  This is the xHandle

+ * parameter of the co-routine function.

+ *

+ * @param pxQueue The handle of the queue from which the data will be received.

+ * The handle is obtained as the return value when the queue is created using

+ * the xQueueCreate() API function.

+ *

+ * @param pvBuffer The buffer into which the received item is to be copied.

+ * The number of bytes of each queued item is specified when the queue is

+ * created.  This number of bytes is copied into pvBuffer.

+ *

+ * @param xTickToDelay The number of ticks that the co-routine should block

+ * to wait for data to become available from the queue, should data not be

+ * available immediately. The actual amount of time this equates to is defined

+ * by configTICK_RATE_HZ (set in FreeRTOSConfig.h).  The constant

+ * portTICK_RATE_MS can be used to convert ticks to milliseconds (see the

+ * crQUEUE_SEND example).

+ *

+ * @param pxResult The variable pointed to by pxResult will be set to pdPASS if

+ * data was successfully retrieved from the queue, otherwise it will be set to

+ * an error code as defined within ProjDefs.h.

+ *

+ * Example usage:

+ <pre>

+ // A co-routine receives the number of an LED to flash from a queue.  It

+ // blocks on the queue until the number is received.

+ static void prvCoRoutineFlashWorkTask( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // Variables in co-routines must be declared static if they must maintain value across a blocking call.

+ static portBASE_TYPE xResult;

+ static unsigned portBASE_TYPE uxLEDToFlash;

+

+    // All co-routines must start with a call to crSTART().

+    crSTART( xHandle );

+

+    for( ;; )

+    {

+        // Wait for data to become available on the queue.

+        crQUEUE_RECEIVE( xHandle, xCoRoutineQueue, &uxLEDToFlash, portMAX_DELAY, &xResult );

+

+        if( xResult == pdPASS )

+        {

+            // We received the LED to flash - flash it!

+            vParTestToggleLED( uxLEDToFlash );

+        }

+    }

+

+    crEND();

+ }</pre>

+ * \defgroup crQUEUE_RECEIVE crQUEUE_RECEIVE

+ * \ingroup Tasks

+ */

+#define crQUEUE_RECEIVE( xHandle, pxQueue, pvBuffer, xTicksToWait, pxResult )			\

+{																						\

+	*( pxResult ) = xQueueCRReceive( ( pxQueue) , ( pvBuffer ), ( xTicksToWait ) );		\

+	if( *( pxResult ) == errQUEUE_BLOCKED ) 											\

+	{																					\

+		crSET_STATE0( ( xHandle ) );													\

+		*( pxResult ) = xQueueCRReceive( ( pxQueue) , ( pvBuffer ), 0 );				\

+	}																					\

+	if( *( pxResult ) == errQUEUE_YIELD )												\

+	{																					\

+		crSET_STATE1( ( xHandle ) );													\

+		*( pxResult ) = pdPASS;															\

+	}																					\

+}

+

+/**

+ * croutine. h

+ * <pre>

+  crQUEUE_SEND_FROM_ISR(

+                            xQueueHandle pxQueue,

+                            void *pvItemToQueue,

+                            portBASE_TYPE xCoRoutinePreviouslyWoken

+                       )</pre>

+ *

+ * The macro's crQUEUE_SEND_FROM_ISR() and crQUEUE_RECEIVE_FROM_ISR() are the

+ * co-routine equivalent to the xQueueSendFromISR() and xQueueReceiveFromISR()

+ * functions used by tasks.

+ *

+ * crQUEUE_SEND_FROM_ISR() and crQUEUE_RECEIVE_FROM_ISR() can only be used to

+ * pass data between a co-routine and and ISR, whereas xQueueSendFromISR() and

+ * xQueueReceiveFromISR() can only be used to pass data between a task and and

+ * ISR.

+ *

+ * crQUEUE_SEND_FROM_ISR can only be called from an ISR to send data to a queue

+ * that is being used from within a co-routine.

+ *

+ * See the co-routine section of the WEB documentation for information on

+ * passing data between tasks and co-routines and between ISR's and

+ * co-routines.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param xCoRoutinePreviouslyWoken This is included so an ISR can post onto

+ * the same queue multiple times from a single interrupt.  The first call

+ * should always pass in pdFALSE.  Subsequent calls should pass in

+ * the value returned from the previous call.

+ *

+ * @return pdTRUE if a co-routine was woken by posting onto the queue.  This is

+ * used by the ISR to determine if a context switch may be required following

+ * the ISR.

+ *

+ * Example usage:

+ <pre>

+ // A co-routine that blocks on a queue waiting for characters to be received.

+ static void vReceivingCoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ char cRxedChar;

+ portBASE_TYPE xResult;

+

+     // All co-routines must start with a call to crSTART().

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+         // Wait for data to become available on the queue.  This assumes the

+         // queue xCommsRxQueue has already been created!

+         crQUEUE_RECEIVE( xHandle, xCommsRxQueue, &uxLEDToFlash, portMAX_DELAY, &xResult );

+

+         // Was a character received?

+         if( xResult == pdPASS )

+         {

+             // Process the character here.

+         }

+     }

+

+     // All co-routines must end with a call to crEND().

+     crEND();

+ }

+

+ // An ISR that uses a queue to send characters received on a serial port to

+ // a co-routine.

+ void vUART_ISR( void )

+ {

+ char cRxedChar;

+ portBASE_TYPE xCRWokenByPost = pdFALSE;

+

+     // We loop around reading characters until there are none left in the UART.

+     while( UART_RX_REG_NOT_EMPTY() )

+     {

+         // Obtain the character from the UART.

+         cRxedChar = UART_RX_REG;

+

+         // Post the character onto a queue.  xCRWokenByPost will be pdFALSE

+         // the first time around the loop.  If the post causes a co-routine

+         // to be woken (unblocked) then xCRWokenByPost will be set to pdTRUE.

+         // In this manner we can ensure that if more than one co-routine is

+         // blocked on the queue only one is woken by this ISR no matter how

+         // many characters are posted to the queue.

+         xCRWokenByPost = crQUEUE_SEND_FROM_ISR( xCommsRxQueue, &cRxedChar, xCRWokenByPost );

+     }

+ }</pre>

+ * \defgroup crQUEUE_SEND_FROM_ISR crQUEUE_SEND_FROM_ISR

+ * \ingroup Tasks

+ */

+#define crQUEUE_SEND_FROM_ISR( pxQueue, pvItemToQueue, xCoRoutinePreviouslyWoken ) xQueueCRSendFromISR( ( pxQueue ), ( pvItemToQueue ), ( xCoRoutinePreviouslyWoken ) )

+

+

+/**

+ * croutine. h

+ * <pre>

+  crQUEUE_SEND_FROM_ISR(

+                            xQueueHandle pxQueue,

+                            void *pvBuffer,

+                            portBASE_TYPE * pxCoRoutineWoken

+                       )</pre>

+ *

+ * The macro's crQUEUE_SEND_FROM_ISR() and crQUEUE_RECEIVE_FROM_ISR() are the

+ * co-routine equivalent to the xQueueSendFromISR() and xQueueReceiveFromISR()

+ * functions used by tasks.

+ *

+ * crQUEUE_SEND_FROM_ISR() and crQUEUE_RECEIVE_FROM_ISR() can only be used to

+ * pass data between a co-routine and and ISR, whereas xQueueSendFromISR() and

+ * xQueueReceiveFromISR() can only be used to pass data between a task and and

+ * ISR.

+ *

+ * crQUEUE_RECEIVE_FROM_ISR can only be called from an ISR to receive data

+ * from a queue that is being used from within a co-routine (a co-routine

+ * posted to the queue).

+ *

+ * See the co-routine section of the WEB documentation for information on

+ * passing data between tasks and co-routines and between ISR's and

+ * co-routines.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvBuffer A pointer to a buffer into which the received item will be

+ * placed.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from the queue into

+ * pvBuffer.

+ *

+ * @param pxCoRoutineWoken A co-routine may be blocked waiting for space to become

+ * available on the queue.  If crQUEUE_RECEIVE_FROM_ISR causes such a

+ * co-routine to unblock *pxCoRoutineWoken will get set to pdTRUE, otherwise

+ * *pxCoRoutineWoken will remain unchanged.

+ *

+ * @return pdTRUE an item was successfully received from the queue, otherwise

+ * pdFALSE.

+ *

+ * Example usage:

+ <pre>

+ // A co-routine that posts a character to a queue then blocks for a fixed

+ // period.  The character is incremented each time.

+ static void vSendingCoRoutine( xCoRoutineHandle xHandle, unsigned portBASE_TYPE uxIndex )

+ {

+ // cChar holds its value while this co-routine is blocked and must therefore

+ // be declared static.

+ static char cCharToTx = 'a';

+ portBASE_TYPE xResult;

+

+     // All co-routines must start with a call to crSTART().

+     crSTART( xHandle );

+

+     for( ;; )

+     {

+         // Send the next character to the queue.

+         crQUEUE_SEND( xHandle, xCoRoutineQueue, &cCharToTx, NO_DELAY, &xResult );

+

+         if( xResult == pdPASS )

+         {

+             // The character was successfully posted to the queue.

+         }

+		 else

+		 {

+			// Could not post the character to the queue.

+		 }

+

+         // Enable the UART Tx interrupt to cause an interrupt in this

+		 // hypothetical UART.  The interrupt will obtain the character

+		 // from the queue and send it.

+		 ENABLE_RX_INTERRUPT();

+

+		 // Increment to the next character then block for a fixed period.

+		 // cCharToTx will maintain its value across the delay as it is

+		 // declared static.

+		 cCharToTx++;

+		 if( cCharToTx > 'x' )

+		 {

+			cCharToTx = 'a';

+		 }

+		 crDELAY( 100 );

+     }

+

+     // All co-routines must end with a call to crEND().

+     crEND();

+ }

+

+ // An ISR that uses a queue to receive characters to send on a UART.

+ void vUART_ISR( void )

+ {

+ char cCharToTx;

+ portBASE_TYPE xCRWokenByPost = pdFALSE;

+

+     while( UART_TX_REG_EMPTY() )

+     {

+         // Are there any characters in the queue waiting to be sent?

+		 // xCRWokenByPost will automatically be set to pdTRUE if a co-routine

+		 // is woken by the post - ensuring that only a single co-routine is

+		 // woken no matter how many times we go around this loop.

+         if( crQUEUE_RECEIVE_FROM_ISR( pxQueue, &cCharToTx, &xCRWokenByPost ) )

+		 {

+			 SEND_CHARACTER( cCharToTx );

+		 }

+     }

+ }</pre>

+ * \defgroup crQUEUE_RECEIVE_FROM_ISR crQUEUE_RECEIVE_FROM_ISR

+ * \ingroup Tasks

+ */

+#define crQUEUE_RECEIVE_FROM_ISR( pxQueue, pvBuffer, pxCoRoutineWoken ) xQueueCRReceiveFromISR( ( pxQueue ), ( pvBuffer ), ( pxCoRoutineWoken ) )

+

+/*

+ * This function is intended for internal use by the co-routine macros only.

+ * The macro nature of the co-routine implementation requires that the

+ * prototype appears here.  The function should not be used by application

+ * writers.

+ *

+ * Removes the current co-routine from its ready list and places it in the

+ * appropriate delayed list.

+ */

+void vCoRoutineAddToDelayedList( portTickType xTicksToDelay, xList *pxEventList );

+

+/*

+ * This function is intended for internal use by the queue implementation only.

+ * The function should not be used by application writers.

+ *

+ * Removes the highest priority co-routine from the event list and places it in

+ * the pending ready list.

+ */

+signed portBASE_TYPE xCoRoutineRemoveFromEventList( const xList *pxEventList );

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* CO_ROUTINE_H */

diff --git a/FreeRTOS/Source/include/init.h b/FreeRTOS/Source/include/init.h
new file mode 100644
index 0000000..6010967
--- /dev/null
+++ b/FreeRTOS/Source/include/init.h
@@ -0,0 +1,21 @@
+
+#ifndef __FREE_RTOS_INIT_H
+#define __FREE_RTOS_INIT_H
+
+#ifndef INC_FREERTOS_H
+	#error "include FreeRTOS.h" must appear in source files before "include queue.h"
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+void xInitRTOS(void);
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __FREE_RTOS_INIT_H */
+
diff --git a/FreeRTOS/Source/include/list.h b/FreeRTOS/Source/include/list.h
new file mode 100644
index 0000000..28d4f24
--- /dev/null
+++ b/FreeRTOS/Source/include/list.h
@@ -0,0 +1,337 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * This is the list implementation used by the scheduler.  While it is tailored

+ * heavily for the schedulers needs, it is also available for use by

+ * application code.

+ *

+ * xLists can only store pointers to xListItems.  Each xListItem contains a

+ * numeric value (xItemValue).  Most of the time the lists are sorted in

+ * descending item value order.

+ *

+ * Lists are created already containing one list item.  The value of this

+ * item is the maximum possible that can be stored, it is therefore always at

+ * the end of the list and acts as a marker.  The list member pxHead always

+ * points to this marker - even though it is at the tail of the list.  This

+ * is because the tail contains a wrap back pointer to the true head of

+ * the list.

+ *

+ * In addition to it's value, each list item contains a pointer to the next

+ * item in the list (pxNext), a pointer to the list it is in (pxContainer)

+ * and a pointer to back to the object that contains it.  These later two

+ * pointers are included for efficiency of list manipulation.  There is

+ * effectively a two way link between the object containing the list item and

+ * the list item itself.

+ *

+ *

+ * \page ListIntroduction List Implementation

+ * \ingroup FreeRTOSIntro

+ */

+

+

+#ifndef LIST_H

+#define LIST_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+/*

+ * Definition of the only type of object that a list can contain.

+ */

+struct xLIST_ITEM

+{

+	portTickType xItemValue;				/*< The value being listed.  In most cases this is used to sort the list in descending order. */

+	volatile struct xLIST_ITEM * pxNext;	/*< Pointer to the next xListItem in the list. */

+	volatile struct xLIST_ITEM * pxPrevious;/*< Pointer to the previous xListItem in the list. */

+	void * pvOwner;							/*< Pointer to the object (normally a TCB) that contains the list item.  There is therefore a two way link between the object containing the list item and the list item itself. */

+	void * pvContainer;						/*< Pointer to the list in which this list item is placed (if any). */

+};

+typedef struct xLIST_ITEM xListItem;		/* For some reason lint wants this as two separate definitions. */

+

+struct xMINI_LIST_ITEM

+{

+	portTickType xItemValue;

+	volatile struct xLIST_ITEM *pxNext;

+	volatile struct xLIST_ITEM *pxPrevious;

+};

+typedef struct xMINI_LIST_ITEM xMiniListItem;

+

+/*

+ * Definition of the type of queue used by the scheduler.

+ */

+typedef struct xLIST

+{

+	volatile unsigned portBASE_TYPE uxNumberOfItems;

+	volatile xListItem * pxIndex;			/*< Used to walk through the list.  Points to the last item returned by a call to pvListGetOwnerOfNextEntry (). */

+	volatile xMiniListItem xListEnd;		/*< List item that contains the maximum possible item value meaning it is always at the end of the list and is therefore used as a marker. */

+} xList;

+

+/*

+ * Access macro to set the owner of a list item.  The owner of a list item

+ * is the object (usually a TCB) that contains the list item.

+ *

+ * \page listSET_LIST_ITEM_OWNER listSET_LIST_ITEM_OWNER

+ * \ingroup LinkedList

+ */

+#define listSET_LIST_ITEM_OWNER( pxListItem, pxOwner )		( pxListItem )->pvOwner = ( void * ) ( pxOwner )

+

+/*

+ * Access macro to get the owner of a list item.  The owner of a list item

+ * is the object (usually a TCB) that contains the list item.

+ *

+ * \page listSET_LIST_ITEM_OWNER listSET_LIST_ITEM_OWNER

+ * \ingroup LinkedList

+ */

+#define listGET_LIST_ITEM_OWNER( pxListItem )		( pxListItem )->pvOwner

+

+/*

+ * Access macro to set the value of the list item.  In most cases the value is

+ * used to sort the list in descending order.

+ *

+ * \page listSET_LIST_ITEM_VALUE listSET_LIST_ITEM_VALUE

+ * \ingroup LinkedList

+ */

+#define listSET_LIST_ITEM_VALUE( pxListItem, xValue )		( pxListItem )->xItemValue = ( xValue )

+

+/*

+ * Access macro to retrieve the value of the list item.  The value can

+ * represent anything - for example a the priority of a task, or the time at

+ * which a task should be unblocked.

+ *

+ * \page listGET_LIST_ITEM_VALUE listGET_LIST_ITEM_VALUE

+ * \ingroup LinkedList

+ */

+#define listGET_LIST_ITEM_VALUE( pxListItem )				( ( pxListItem )->xItemValue )

+

+/*

+ * Access macro the retrieve the value of the list item at the head of a given

+ * list.

+ *

+ * \page listGET_LIST_ITEM_VALUE listGET_LIST_ITEM_VALUE

+ * \ingroup LinkedList

+ */

+#define listGET_ITEM_VALUE_OF_HEAD_ENTRY( pxList )			( (&( ( pxList )->xListEnd ))->pxNext->xItemValue )

+

+/*

+ * Access macro to determine if a list contains any items.  The macro will

+ * only have the value true if the list is empty.

+ *

+ * \page listLIST_IS_EMPTY listLIST_IS_EMPTY

+ * \ingroup LinkedList

+ */

+#define listLIST_IS_EMPTY( pxList )				( ( pxList )->uxNumberOfItems == ( unsigned portBASE_TYPE ) 0 )

+

+/*

+ * Access macro to return the number of items in the list.

+ */

+#define listCURRENT_LIST_LENGTH( pxList )		( ( pxList )->uxNumberOfItems )

+

+/*

+ * Access function to obtain the owner of the next entry in a list.

+ *

+ * The list member pxIndex is used to walk through a list.  Calling

+ * listGET_OWNER_OF_NEXT_ENTRY increments pxIndex to the next item in the list

+ * and returns that entries pxOwner parameter.  Using multiple calls to this

+ * function it is therefore possible to move through every item contained in

+ * a list.

+ *

+ * The pxOwner parameter of a list item is a pointer to the object that owns

+ * the list item.  In the scheduler this is normally a task control block.

+ * The pxOwner parameter effectively creates a two way link between the list

+ * item and its owner.

+ *

+ * @param pxList The list from which the next item owner is to be returned.

+ *

+ * \page listGET_OWNER_OF_NEXT_ENTRY listGET_OWNER_OF_NEXT_ENTRY

+ * \ingroup LinkedList

+ */

+#define listGET_OWNER_OF_NEXT_ENTRY( pxTCB, pxList )									\

+{																						\

+xList * const pxConstList = ( pxList );													\

+	/* Increment the index to the next item and return the item, ensuring */			\

+	/* we don't return the marker used at the end of the list.  */						\

+	( pxConstList )->pxIndex = ( pxConstList )->pxIndex->pxNext;						\

+	if( ( pxConstList )->pxIndex == ( xListItem * ) &( ( pxConstList )->xListEnd ) )	\

+	{																					\

+		( pxConstList )->pxIndex = ( pxConstList )->pxIndex->pxNext;					\

+	}																					\

+	( pxTCB ) = ( pxConstList )->pxIndex->pvOwner;										\

+}

+

+

+/*

+ * Access function to obtain the owner of the first entry in a list.  Lists

+ * are normally sorted in ascending item value order.

+ *

+ * This function returns the pxOwner member of the first item in the list.

+ * The pxOwner parameter of a list item is a pointer to the object that owns

+ * the list item.  In the scheduler this is normally a task control block.

+ * The pxOwner parameter effectively creates a two way link between the list

+ * item and its owner.

+ *

+ * @param pxList The list from which the owner of the head item is to be

+ * returned.

+ *

+ * \page listGET_OWNER_OF_HEAD_ENTRY listGET_OWNER_OF_HEAD_ENTRY

+ * \ingroup LinkedList

+ */

+#define listGET_OWNER_OF_HEAD_ENTRY( pxList )  ( (&( ( pxList )->xListEnd ))->pxNext->pvOwner )

+

+/*

+ * Check to see if a list item is within a list.  The list item maintains a

+ * "container" pointer that points to the list it is in.  All this macro does

+ * is check to see if the container and the list match.

+ *

+ * @param pxList The list we want to know if the list item is within.

+ * @param pxListItem The list item we want to know if is in the list.

+ * @return pdTRUE is the list item is in the list, otherwise pdFALSE.

+ * pointer against

+ */

+#define listIS_CONTAINED_WITHIN( pxList, pxListItem ) ( ( pxListItem )->pvContainer == ( void * ) ( pxList ) )

+

+/*

+ * This provides a crude means of knowing if a list has been initialised, as

+ * pxList->xListEnd.xItemValue is set to portMAX_DELAY by the vListInitialise()

+ * function.

+ */

+#define listLIST_IS_INITIALISED( pxList ) ( ( pxList )->xListEnd.xItemValue == portMAX_DELAY )

+

+/*

+ * Must be called before a list is used!  This initialises all the members

+ * of the list structure and inserts the xListEnd item into the list as a

+ * marker to the back of the list.

+ *

+ * @param pxList Pointer to the list being initialised.

+ *

+ * \page vListInitialise vListInitialise

+ * \ingroup LinkedList

+ */

+void vListInitialise( xList *pxList );

+

+/*

+ * Must be called before a list item is used.  This sets the list container to

+ * null so the item does not think that it is already contained in a list.

+ *

+ * @param pxItem Pointer to the list item being initialised.

+ *

+ * \page vListInitialiseItem vListInitialiseItem

+ * \ingroup LinkedList

+ */

+void vListInitialiseItem( xListItem *pxItem );

+

+/*

+ * Insert a list item into a list.  The item will be inserted into the list in

+ * a position determined by its item value (descending item value order).

+ *

+ * @param pxList The list into which the item is to be inserted.

+ *

+ * @param pxNewListItem The item to that is to be placed in the list.

+ *

+ * \page vListInsert vListInsert

+ * \ingroup LinkedList

+ */

+void vListInsert( xList *pxList, xListItem *pxNewListItem );

+

+/*

+ * Insert a list item into a list.  The item will be inserted in a position

+ * such that it will be the last item within the list returned by multiple

+ * calls to listGET_OWNER_OF_NEXT_ENTRY.

+ *

+ * The list member pvIndex is used to walk through a list.  Calling

+ * listGET_OWNER_OF_NEXT_ENTRY increments pvIndex to the next item in the list.

+ * Placing an item in a list using vListInsertEnd effectively places the item

+ * in the list position pointed to by pvIndex.  This means that every other

+ * item within the list will be returned by listGET_OWNER_OF_NEXT_ENTRY before

+ * the pvIndex parameter again points to the item being inserted.

+ *

+ * @param pxList The list into which the item is to be inserted.

+ *

+ * @param pxNewListItem The list item to be inserted into the list.

+ *

+ * \page vListInsertEnd vListInsertEnd

+ * \ingroup LinkedList

+ */

+void vListInsertEnd( xList *pxList, xListItem *pxNewListItem );

+

+/*

+ * Remove an item from a list.  The list item has a pointer to the list that

+ * it is in, so only the list item need be passed into the function.

+ *

+ * @param vListRemove The item to be removed.  The item will remove itself from

+ * the list pointed to by it's pxContainer parameter.

+ *

+ * \page vListRemove vListRemove

+ * \ingroup LinkedList

+ */

+void vListRemove( xListItem *pxItemToRemove );

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif

+

diff --git a/FreeRTOS/Source/include/mpu_wrappers.h b/FreeRTOS/Source/include/mpu_wrappers.h
new file mode 100644
index 0000000..be49c3d
--- /dev/null
+++ b/FreeRTOS/Source/include/mpu_wrappers.h
@@ -0,0 +1,146 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef MPU_WRAPPERS_H

+#define MPU_WRAPPERS_H

+

+/* This file redefines API functions to be called through a wrapper macro, but

+only for ports that are using the MPU. */

+#ifdef portUSING_MPU_WRAPPERS

+

+	/* MPU_WRAPPERS_INCLUDED_FROM_API_FILE will be defined when this file is

+	included from queue.c or task.c to prevent it from having an effect within

+	those files. */

+	#ifndef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+		#define xTaskGenericCreate				MPU_xTaskGenericCreate

+		#define vTaskAllocateMPURegions			MPU_vTaskAllocateMPURegions

+		#define vTaskDelete						MPU_vTaskDelete

+		#define vTaskDelayUntil					MPU_vTaskDelayUntil

+		#define vTaskDelay						MPU_vTaskDelay

+		#define uxTaskPriorityGet				MPU_uxTaskPriorityGet

+		#define vTaskPrioritySet				MPU_vTaskPrioritySet

+		#define vTaskSuspend					MPU_vTaskSuspend

+		#define xTaskIsTaskSuspended			MPU_xTaskIsTaskSuspended

+		#define vTaskResume						MPU_vTaskResume

+		#define vTaskSuspendAll					MPU_vTaskSuspendAll

+		#define xTaskResumeAll					MPU_xTaskResumeAll

+		#define xTaskGetTickCount				MPU_xTaskGetTickCount

+		#define uxTaskGetNumberOfTasks			MPU_uxTaskGetNumberOfTasks

+		#define vTaskList						MPU_vTaskList

+		#define vTaskGetRunTimeStats			MPU_vTaskGetRunTimeStats

+		#define vTaskSetApplicationTaskTag		MPU_vTaskSetApplicationTaskTag

+		#define xTaskGetApplicationTaskTag		MPU_xTaskGetApplicationTaskTag

+		#define xTaskCallApplicationTaskHook	MPU_xTaskCallApplicationTaskHook

+		#define uxTaskGetStackHighWaterMark		MPU_uxTaskGetStackHighWaterMark

+		#define xTaskGetCurrentTaskHandle		MPU_xTaskGetCurrentTaskHandle

+		#define xTaskGetSchedulerState			MPU_xTaskGetSchedulerState

+

+		#define xQueueGenericCreate				MPU_xQueueGenericCreate

+		#define xQueueCreateMutex				MPU_xQueueCreateMutex

+		#define xQueueGiveMutexRecursive		MPU_xQueueGiveMutexRecursive

+		#define xQueueTakeMutexRecursive		MPU_xQueueTakeMutexRecursive

+		#define xQueueCreateCountingSemaphore	MPU_xQueueCreateCountingSemaphore

+		#define xQueueGenericSend				MPU_xQueueGenericSend

+		#define xQueueAltGenericSend			MPU_xQueueAltGenericSend

+		#define xQueueAltGenericReceive			MPU_xQueueAltGenericReceive

+		#define xQueueGenericReceive			MPU_xQueueGenericReceive

+		#define uxQueueMessagesWaiting			MPU_uxQueueMessagesWaiting

+		#define vQueueDelete					MPU_vQueueDelete

+

+		#define pvPortMalloc					MPU_pvPortMalloc

+		#define vPortFree						MPU_vPortFree

+		#define xPortGetFreeHeapSize			MPU_xPortGetFreeHeapSize

+		#define vPortInitialiseBlocks			MPU_vPortInitialiseBlocks

+

+		#if configQUEUE_REGISTRY_SIZE > 0

+			#define vQueueAddToRegistry				MPU_vQueueAddToRegistry

+			#define vQueueUnregisterQueue			MPU_vQueueUnregisterQueue

+		#endif

+

+		/* Remove the privileged function macro. */

+		#define PRIVILEGED_FUNCTION

+

+	#else /* MPU_WRAPPERS_INCLUDED_FROM_API_FILE */

+

+		/* Ensure API functions go in the privileged execution section. */

+		#define PRIVILEGED_FUNCTION __attribute__((section("privileged_functions")))

+		#define PRIVILEGED_DATA __attribute__((section("privileged_data")))

+        //#define PRIVILEGED_DATA

+

+	#endif /* MPU_WRAPPERS_INCLUDED_FROM_API_FILE */

+

+#else /* portUSING_MPU_WRAPPERS */

+

+	#define PRIVILEGED_FUNCTION

+	#define PRIVILEGED_DATA

+	#define portUSING_MPU_WRAPPERS 0

+

+#endif /* portUSING_MPU_WRAPPERS */

+

+

+#endif /* MPU_WRAPPERS_H */

+

diff --git a/FreeRTOS/Source/include/portable.h b/FreeRTOS/Source/include/portable.h
new file mode 100644
index 0000000..88cfbb2
--- /dev/null
+++ b/FreeRTOS/Source/include/portable.h
@@ -0,0 +1,403 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Portable layer API.  Each function must be defined for each port.

+ *----------------------------------------------------------*/

+

+#ifndef PORTABLE_H

+#define PORTABLE_H

+

+/* Include the macro file relevant to the port being used. */

+

+#ifdef OPEN_WATCOM_INDUSTRIAL_PC_PORT

+	#include "..\..\Source\portable\owatcom\16bitdos\pc\portmacro.h"

+	typedef void ( __interrupt __far *pxISR )();

+#endif

+

+#ifdef OPEN_WATCOM_FLASH_LITE_186_PORT

+	#include "..\..\Source\portable\owatcom\16bitdos\flsh186\portmacro.h"

+	typedef void ( __interrupt __far *pxISR )();

+#endif

+

+#ifdef GCC_MEGA_AVR

+	#include "../portable/GCC/ATMega323/portmacro.h"

+#endif

+

+#ifdef IAR_MEGA_AVR

+	#include "../portable/IAR/ATMega323/portmacro.h"

+#endif

+

+#ifdef MPLAB_PIC24_PORT

+	#include "..\..\Source\portable\MPLAB\PIC24_dsPIC\portmacro.h"

+#endif

+

+#ifdef MPLAB_DSPIC_PORT

+	#include "..\..\Source\portable\MPLAB\PIC24_dsPIC\portmacro.h"

+#endif

+

+#ifdef MPLAB_PIC18F_PORT

+	#include "..\..\Source\portable\MPLAB\PIC18F\portmacro.h"

+#endif

+

+#ifdef MPLAB_PIC32MX_PORT

+	#include "..\..\Source\portable\MPLAB\PIC32MX\portmacro.h"

+#endif

+

+#ifdef _FEDPICC

+	#include "libFreeRTOS/Include/portmacro.h"

+#endif

+

+#ifdef SDCC_CYGNAL

+	#include "../../Source/portable/SDCC/Cygnal/portmacro.h"

+#endif

+

+#ifdef GCC_ARM7

+	#include "../../Source/portable/GCC/ARM7_LPC2000/portmacro.h"

+#endif

+

+#ifdef GCC_ARM7_ECLIPSE

+	#include "portmacro.h"

+#endif

+

+#ifdef ROWLEY_LPC23xx

+	#include "../../Source/portable/GCC/ARM7_LPC23xx/portmacro.h"

+#endif

+

+#ifdef IAR_MSP430

+	#include "..\..\Source\portable\IAR\MSP430\portmacro.h"	

+#endif

+	

+#ifdef GCC_MSP430

+	#include "../../Source/portable/GCC/MSP430F449/portmacro.h"

+#endif

+

+#ifdef ROWLEY_MSP430

+	#include "../../Source/portable/Rowley/MSP430F449/portmacro.h"

+#endif

+

+#ifdef ARM7_LPC21xx_KEIL_RVDS

+	#include "..\..\Source\portable\RVDS\ARM7_LPC21xx\portmacro.h"

+#endif

+

+#ifdef SAM7_GCC

+	#include "../../Source/portable/GCC/ARM7_AT91SAM7S/portmacro.h"

+#endif

+

+#ifdef SAM7_IAR

+	#include "..\..\Source\portable\IAR\AtmelSAM7S64\portmacro.h"

+#endif

+

+#ifdef SAM9XE_IAR

+	#include "..\..\Source\portable\IAR\AtmelSAM9XE\portmacro.h"

+#endif

+

+#ifdef LPC2000_IAR

+	#include "..\..\Source\portable\IAR\LPC2000\portmacro.h"

+#endif

+

+#ifdef STR71X_IAR

+	#include "..\..\Source\portable\IAR\STR71x\portmacro.h"

+#endif

+

+#ifdef STR75X_IAR

+	#include "..\..\Source\portable\IAR\STR75x\portmacro.h"

+#endif

+	

+#ifdef STR75X_GCC

+	#include "..\..\Source\portable\GCC\STR75x\portmacro.h"

+#endif

+

+#ifdef STR91X_IAR

+	#include "..\..\Source\portable\IAR\STR91x\portmacro.h"

+#endif

+	

+#ifdef GCC_H8S

+	#include "../../Source/portable/GCC/H8S2329/portmacro.h"

+#endif

+

+#ifdef GCC_AT91FR40008

+	#include "../../Source/portable/GCC/ARM7_AT91FR40008/portmacro.h"

+#endif

+

+#ifdef RVDS_ARMCM3_LM3S102

+	#include "../../Source/portable/RVDS/ARM_CM3/portmacro.h"

+#endif

+

+#ifdef GCC_ARMCM3_LM3S102

+	#include "../../Source/portable/GCC/ARM_CM3/portmacro.h"

+#endif

+

+#ifdef GCC_ARMCM3

+	#include "../../Source/portable/GCC/ARM_CM3/portmacro.h"

+#endif

+

+#ifdef IAR_ARM_CM3

+	#include "../../Source/portable/IAR/ARM_CM3/portmacro.h"

+#endif

+

+#ifdef IAR_ARMCM3_LM

+	#include "../../Source/portable/IAR/ARM_CM3/portmacro.h"

+#endif

+	

+#ifdef HCS12_CODE_WARRIOR

+	#include "../../Source/portable/CodeWarrior/HCS12/portmacro.h"

+#endif	

+

+#ifdef MICROBLAZE_GCC

+	#include "../../Source/portable/GCC/MicroBlaze/portmacro.h"

+#endif

+

+#ifdef TERN_EE

+	#include "..\..\Source\portable\Paradigm\Tern_EE\small\portmacro.h"

+#endif

+

+#ifdef GCC_HCS12

+	#include "../../Source/portable/GCC/HCS12/portmacro.h"

+#endif

+

+#ifdef GCC_MCF5235

+    #include "../../Source/portable/GCC/MCF5235/portmacro.h"

+#endif

+

+#ifdef COLDFIRE_V2_GCC

+	#include "../../../Source/portable/GCC/ColdFire_V2/portmacro.h"

+#endif

+

+#ifdef COLDFIRE_V2_CODEWARRIOR

+	#include "../../Source/portable/CodeWarrior/ColdFire_V2/portmacro.h"

+#endif

+

+#ifdef GCC_PPC405

+	#include "../../Source/portable/GCC/PPC405_Xilinx/portmacro.h"

+#endif

+

+#ifdef GCC_PPC440

+	#include "../../Source/portable/GCC/PPC440_Xilinx/portmacro.h"

+#endif

+

+#ifdef _16FX_SOFTUNE

+	#include "..\..\Source\portable\Softune\MB96340\portmacro.h"

+#endif

+

+#ifdef BCC_INDUSTRIAL_PC_PORT

+	/* A short file name has to be used in place of the normal

+	FreeRTOSConfig.h when using the Borland compiler. */

+	#include "frconfig.h"

+	#include "..\portable\BCC\16BitDOS\PC\prtmacro.h"

+    typedef void ( __interrupt __far *pxISR )();

+#endif

+

+#ifdef BCC_FLASH_LITE_186_PORT

+	/* A short file name has to be used in place of the normal

+	FreeRTOSConfig.h when using the Borland compiler. */

+	#include "frconfig.h"

+	#include "..\portable\BCC\16BitDOS\flsh186\prtmacro.h"

+    typedef void ( __interrupt __far *pxISR )();

+#endif

+

+#ifdef __GNUC__

+   #ifdef __AVR32_AVR32A__

+	   #include "portmacro.h"

+   #endif

+#endif

+

+#ifdef __ICCAVR32__

+   #ifdef __CORE__

+      #if __CORE__ == __AVR32A__

+	      #include "portmacro.h"

+      #endif

+   #endif

+#endif

+

+#ifdef __91467D

+	#include "portmacro.h"

+#endif

+

+#ifdef __96340

+	#include "portmacro.h"

+#endif

+

+

+#ifdef __IAR_V850ES_Fx3__

+	#include "../../Source/portable/IAR/V850ES/portmacro.h"

+#endif

+

+#ifdef __IAR_V850ES_Jx3__

+	#include "../../Source/portable/IAR/V850ES/portmacro.h"

+#endif

+

+#ifdef __IAR_V850ES_Jx3_L__

+	#include "../../Source/portable/IAR/V850ES/portmacro.h"

+#endif

+

+#ifdef __IAR_V850ES_Jx2__

+	#include "../../Source/portable/IAR/V850ES/portmacro.h"

+#endif

+

+#ifdef __IAR_V850ES_Hx2__

+	#include "../../Source/portable/IAR/V850ES/portmacro.h"

+#endif

+

+#ifdef __IAR_78K0R_Kx3__

+	#include "../../Source/portable/IAR/78K0R/portmacro.h"

+#endif

+	

+#ifdef __IAR_78K0R_Kx3L__

+	#include "../../Source/portable/IAR/78K0R/portmacro.h"

+#endif

+	

+/* Catch all to ensure portmacro.h is included in the build.  Newer demos

+have the path as part of the project options, rather than as relative from

+the project location.  If portENTER_CRITICAL() has not been defined then

+portmacro.h has not yet been included - as every portmacro.h provides a

+portENTER_CRITICAL() definition.  Check the demo application for your demo

+to find the path to the correct portmacro.h file. */

+#ifndef portENTER_CRITICAL

+	#include "portmacro.h"	

+#endif

+	

+#if portBYTE_ALIGNMENT == 8

+	#define portBYTE_ALIGNMENT_MASK ( 0x0007 )

+#endif

+

+#if portBYTE_ALIGNMENT == 4

+	#define portBYTE_ALIGNMENT_MASK	( 0x0003 )

+#endif

+

+#if portBYTE_ALIGNMENT == 2

+	#define portBYTE_ALIGNMENT_MASK	( 0x0001 )

+#endif

+

+#if portBYTE_ALIGNMENT == 1

+	#define portBYTE_ALIGNMENT_MASK	( 0x0000 )

+#endif

+

+#ifndef portBYTE_ALIGNMENT_MASK

+	#error "Invalid portBYTE_ALIGNMENT definition"

+#endif

+

+#ifndef portNUM_CONFIGURABLE_REGIONS

+	#define portNUM_CONFIGURABLE_REGIONS 1

+#endif

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+#include "mpu_wrappers.h"

+

+/*

+ * Setup the stack of a new task so it is ready to be placed under the

+ * scheduler control.  The registers have to be placed on the stack in

+ * the order that the port expects to find them.

+ *

+ */

+#if( portUSING_MPU_WRAPPERS == 1 )

+	portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters, portBASE_TYPE xRunPrivileged ) PRIVILEGED_FUNCTION;

+#else

+	portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters );

+#endif

+

+/*

+ * Map to the memory management routines required for the port.

+ */

+void *pvPortMalloc( size_t xSize ) PRIVILEGED_FUNCTION;

+void vPortFree( void *pv ) PRIVILEGED_FUNCTION;

+void vPortInitialiseBlocks( void ) PRIVILEGED_FUNCTION;

+size_t xPortGetFreeHeapSize( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Setup the hardware ready for the scheduler to take control.  This generally

+ * sets up a tick interrupt and sets timers for the correct tick frequency.

+ */

+portBASE_TYPE xPortStartScheduler( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Undo any hardware/ISR setup that was performed by xPortStartScheduler() so

+ * the hardware is left in its original condition after the scheduler stops

+ * executing.

+ */

+void vPortEndScheduler( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * The structures and methods of manipulating the MPU are contained within the

+ * port layer.

+ *

+ * Fills the xMPUSettings structure with the memory region information

+ * contained in xRegions.

+ */

+#if( portUSING_MPU_WRAPPERS == 1 ) 

+	struct xMEMORY_REGION;

+	void vPortStoreTaskMPUSettings( xMPU_SETTINGS *xMPUSettings, const struct xMEMORY_REGION * const xRegions, portSTACK_TYPE *pxBottomOfStack, unsigned short usStackDepth ) PRIVILEGED_FUNCTION;

+#endif

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTABLE_H */

+

diff --git a/FreeRTOS/Source/include/projdefs.h b/FreeRTOS/Source/include/projdefs.h
new file mode 100644
index 0000000..c69db92
--- /dev/null
+++ b/FreeRTOS/Source/include/projdefs.h
@@ -0,0 +1,90 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PROJDEFS_H

+#define PROJDEFS_H

+

+/* Defines the prototype to which task functions must conform. */

+typedef void (*pdTASK_CODE)( void * );

+

+#define pdTRUE		( 1 )

+#define pdFALSE		( 0 )

+

+#define pdPASS									( 1 )

+#define pdFAIL									( 0 )

+#define errQUEUE_EMPTY							( 0 )

+#define errQUEUE_FULL							( 0 )

+

+/* Error definitions. */

+#define errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY	( -1 )

+#define errNO_TASK_TO_RUN						( -2 )

+#define errQUEUE_BLOCKED						( -4 )

+#define errQUEUE_YIELD							( -5 )

+

+#endif /* PROJDEFS_H */

+

+

+

diff --git a/FreeRTOS/Source/include/queue.h b/FreeRTOS/Source/include/queue.h
new file mode 100644
index 0000000..c3efc64
--- /dev/null
+++ b/FreeRTOS/Source/include/queue.h
@@ -0,0 +1,1302 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef QUEUE_H

+#define QUEUE_H

+

+#ifndef INC_FREERTOS_H

+	#error "include FreeRTOS.h" must appear in source files before "include queue.h"

+#endif

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+

+#include "mpu_wrappers.h"

+

+/**

+ * Type by which queues are referenced.  For example, a call to xQueueCreate

+ * returns (via a pointer parameter) an xQueueHandle variable that can then

+ * be used as a parameter to xQueueSend(), xQueueReceive(), etc.

+ */

+typedef void * xQueueHandle;

+

+

+/* For internal use only. */

+#define	queueSEND_TO_BACK	( 0 )

+#define	queueSEND_TO_FRONT	( 1 )

+

+/* For internal use only.  These definitions *must* match those in queue.c. */

+#define queueQUEUE_TYPE_BASE				( 0U )

+#define queueQUEUE_TYPE_MUTEX 				( 1U )

+#define queueQUEUE_TYPE_COUNTING_SEMAPHORE	( 2U )

+#define queueQUEUE_TYPE_BINARY_SEMAPHORE	( 3U )

+#define queueQUEUE_TYPE_RECURSIVE_MUTEX		( 4U )

+

+void xInitQueues(void);

+

+/**

+ * queue. h

+ * <pre>

+ xQueueHandle xQueueCreate(

+							  unsigned portBASE_TYPE uxQueueLength,

+							  unsigned portBASE_TYPE uxItemSize

+						  );

+ * </pre>

+ *

+ * Creates a new queue instance.  This allocates the storage required by the

+ * new queue and returns a handle for the queue.

+ *

+ * @param uxQueueLength The maximum number of items that the queue can contain.

+ *

+ * @param uxItemSize The number of bytes each item in the queue will require.

+ * Items are queued by copy, not by reference, so this is the number of bytes

+ * that will be copied for each posted item.  Each item on the queue must be

+ * the same size.

+ *

+ * @return If the queue is successfully create then a handle to the newly

+ * created queue is returned.  If the queue cannot be created then 0 is

+ * returned.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ };

+

+ void vATask( void *pvParameters )

+ {

+ xQueueHandle xQueue1, xQueue2;

+

+	// Create a queue capable of containing 10 unsigned long values.

+	xQueue1 = xQueueCreate( 10, sizeof( unsigned long ) );

+	if( xQueue1 == 0 )

+	{

+		// Queue was not created and must not be used.

+	}

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue2 = xQueueCreate( 10, sizeof( struct AMessage * ) );

+	if( xQueue2 == 0 )

+	{

+		// Queue was not created and must not be used.

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueCreate xQueueCreate

+ * \ingroup QueueManagement

+ */

+#define xQueueCreate( buffer, uxQueueLength, uxItemSize ) xQueueGenericCreate( buffer, uxQueueLength, uxItemSize, queueQUEUE_TYPE_BASE )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSendToToFront(

+								   xQueueHandle	xQueue,

+								   const void	*	pvItemToQueue,

+								   portTickType	xTicksToWait

+							   );

+ * </pre>

+ *

+ * This is a macro that calls xQueueGenericSend().

+ *

+ * Post an item to the front of a queue.  The item is queued by copy, not by

+ * reference.  This function must not be called from an interrupt service

+ * routine.  See xQueueSendFromISR () for an alternative which may be used

+ * in an ISR.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for space to become available on the queue, should it already

+ * be full.  The call will return immediately if this is set to 0 and the

+ * queue is full.  The time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ *

+ * @return pdTRUE if the item was successfully posted, otherwise errQUEUE_FULL.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ unsigned long ulVar = 10UL;

+

+ void vATask( void *pvParameters )

+ {

+ xQueueHandle xQueue1, xQueue2;

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 unsigned long values.

+	xQueue1 = xQueueCreate( 10, sizeof( unsigned long ) );

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue2 = xQueueCreate( 10, sizeof( struct AMessage * ) );

+

+	// ...

+

+	if( xQueue1 != 0 )

+	{

+		// Send an unsigned long.  Wait for 10 ticks for space to become

+		// available if necessary.

+		if( xQueueSendToFront( xQueue1, ( void * ) &ulVar, ( portTickType ) 10 ) != pdPASS )

+		{

+			// Failed to post the message, even after 10 ticks.

+		}

+	}

+

+	if( xQueue2 != 0 )

+	{

+		// Send a pointer to a struct AMessage object.  Don't block if the

+		// queue is already full.

+		pxMessage = & xMessage;

+		xQueueSendToFront( xQueue2, ( void * ) &pxMessage, ( portTickType ) 0 );

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueSend xQueueSend

+ * \ingroup QueueManagement

+ */

+#define xQueueSendToFront( xQueue, pvItemToQueue, xTicksToWait ) xQueueGenericSend( ( xQueue ), ( pvItemToQueue ), ( xTicksToWait ), queueSEND_TO_FRONT )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSendToBack(

+								   xQueueHandle	xQueue,

+								   const	void	*	pvItemToQueue,

+								   portTickType	xTicksToWait

+							   );

+ * </pre>

+ *

+ * This is a macro that calls xQueueGenericSend().

+ *

+ * Post an item to the back of a queue.  The item is queued by copy, not by

+ * reference.  This function must not be called from an interrupt service

+ * routine.  See xQueueSendFromISR () for an alternative which may be used

+ * in an ISR.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for space to become available on the queue, should it already

+ * be full.  The call will return immediately if this is set to 0 and the queue

+ * is full.  The  time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ *

+ * @return pdTRUE if the item was successfully posted, otherwise errQUEUE_FULL.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ unsigned long ulVar = 10UL;

+

+ void vATask( void *pvParameters )

+ {

+ xQueueHandle xQueue1, xQueue2;

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 unsigned long values.

+	xQueue1 = xQueueCreate( 10, sizeof( unsigned long ) );

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue2 = xQueueCreate( 10, sizeof( struct AMessage * ) );

+

+	// ...

+

+	if( xQueue1 != 0 )

+	{

+		// Send an unsigned long.  Wait for 10 ticks for space to become

+		// available if necessary.

+		if( xQueueSendToBack( xQueue1, ( void * ) &ulVar, ( portTickType ) 10 ) != pdPASS )

+		{

+			// Failed to post the message, even after 10 ticks.

+		}

+	}

+

+	if( xQueue2 != 0 )

+	{

+		// Send a pointer to a struct AMessage object.  Don't block if the

+		// queue is already full.

+		pxMessage = & xMessage;

+		xQueueSendToBack( xQueue2, ( void * ) &pxMessage, ( portTickType ) 0 );

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueSend xQueueSend

+ * \ingroup QueueManagement

+ */

+#define xQueueSendToBack( xQueue, pvItemToQueue, xTicksToWait ) xQueueGenericSend( ( xQueue ), ( pvItemToQueue ), ( xTicksToWait ), queueSEND_TO_BACK )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSend(

+							  xQueueHandle xQueue,

+							  const void * pvItemToQueue,

+							  portTickType xTicksToWait

+						 );

+ * </pre>

+ *

+ * This is a macro that calls xQueueGenericSend().  It is included for

+ * backward compatibility with versions of FreeRTOS.org that did not

+ * include the xQueueSendToFront() and xQueueSendToBack() macros.  It is

+ * equivalent to xQueueSendToBack().

+ *

+ * Post an item on a queue.  The item is queued by copy, not by reference.

+ * This function must not be called from an interrupt service routine.

+ * See xQueueSendFromISR () for an alternative which may be used in an ISR.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for space to become available on the queue, should it already

+ * be full.  The call will return immediately if this is set to 0 and the

+ * queue is full.  The time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ *

+ * @return pdTRUE if the item was successfully posted, otherwise errQUEUE_FULL.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ unsigned long ulVar = 10UL;

+

+ void vATask( void *pvParameters )

+ {

+ xQueueHandle xQueue1, xQueue2;

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 unsigned long values.

+	xQueue1 = xQueueCreate( 10, sizeof( unsigned long ) );

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue2 = xQueueCreate( 10, sizeof( struct AMessage * ) );

+

+	// ...

+

+	if( xQueue1 != 0 )

+	{

+		// Send an unsigned long.  Wait for 10 ticks for space to become

+		// available if necessary.

+		if( xQueueSend( xQueue1, ( void * ) &ulVar, ( portTickType ) 10 ) != pdPASS )

+		{

+			// Failed to post the message, even after 10 ticks.

+		}

+	}

+

+	if( xQueue2 != 0 )

+	{

+		// Send a pointer to a struct AMessage object.  Don't block if the

+		// queue is already full.

+		pxMessage = & xMessage;

+		xQueueSend( xQueue2, ( void * ) &pxMessage, ( portTickType ) 0 );

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueSend xQueueSend

+ * \ingroup QueueManagement

+ */

+#define xQueueSend( xQueue, pvItemToQueue, xTicksToWait ) xQueueGenericSend( ( xQueue ), ( pvItemToQueue ), ( xTicksToWait ), queueSEND_TO_BACK )

+

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueGenericSend(

+									xQueueHandle xQueue,

+									const void * pvItemToQueue,

+									portTickType xTicksToWait

+									portBASE_TYPE xCopyPosition

+								);

+ * </pre>

+ *

+ * It is preferred that the macros xQueueSend(), xQueueSendToFront() and

+ * xQueueSendToBack() are used in place of calling this function directly.

+ *

+ * Post an item on a queue.  The item is queued by copy, not by reference.

+ * This function must not be called from an interrupt service routine.

+ * See xQueueSendFromISR () for an alternative which may be used in an ISR.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for space to become available on the queue, should it already

+ * be full.  The call will return immediately if this is set to 0 and the

+ * queue is full.  The time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ *

+ * @param xCopyPosition Can take the value queueSEND_TO_BACK to place the

+ * item at the back of the queue, or queueSEND_TO_FRONT to place the item

+ * at the front of the queue (for high priority messages).

+ *

+ * @return pdTRUE if the item was successfully posted, otherwise errQUEUE_FULL.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ unsigned long ulVar = 10UL;

+

+ void vATask( void *pvParameters )

+ {

+ xQueueHandle xQueue1, xQueue2;

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 unsigned long values.

+	xQueue1 = xQueueCreate( 10, sizeof( unsigned long ) );

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue2 = xQueueCreate( 10, sizeof( struct AMessage * ) );

+

+	// ...

+

+	if( xQueue1 != 0 )

+	{

+		// Send an unsigned long.  Wait for 10 ticks for space to become

+		// available if necessary.

+		if( xQueueGenericSend( xQueue1, ( void * ) &ulVar, ( portTickType ) 10, queueSEND_TO_BACK ) != pdPASS )

+		{

+			// Failed to post the message, even after 10 ticks.

+		}

+	}

+

+	if( xQueue2 != 0 )

+	{

+		// Send a pointer to a struct AMessage object.  Don't block if the

+		// queue is already full.

+		pxMessage = & xMessage;

+		xQueueGenericSend( xQueue2, ( void * ) &pxMessage, ( portTickType ) 0, queueSEND_TO_BACK );

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueSend xQueueSend

+ * \ingroup QueueManagement

+ */

+signed portBASE_TYPE xQueueGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition );

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueuePeek(

+							 xQueueHandle xQueue,

+							 void *pvBuffer,

+							 portTickType xTicksToWait

+						 );</pre>

+ *

+ * This is a macro that calls the xQueueGenericReceive() function.

+ *

+ * Receive an item from a queue without removing the item from the queue.

+ * The item is received by copy so a buffer of adequate size must be

+ * provided.  The number of bytes copied into the buffer was defined when

+ * the queue was created.

+ *

+ * Successfully received items remain on the queue so will be returned again

+ * by the next call, or a call to xQueueReceive().

+ *

+ * This macro must not be used in an interrupt service routine.

+ *

+ * @param pxQueue The handle to the queue from which the item is to be

+ * received.

+ *

+ * @param pvBuffer Pointer to the buffer into which the received item will

+ * be copied.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for an item to receive should the queue be empty at the time

+ * of the call.	 The time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ * xQueuePeek() will return immediately if xTicksToWait is 0 and the queue

+ * is empty.

+ *

+ * @return pdTRUE if an item was successfully received from the queue,

+ * otherwise pdFALSE.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ xQueueHandle xQueue;

+

+ // Task to create a queue and post a value.

+ void vATask( void *pvParameters )

+ {

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue = xQueueCreate( 10, sizeof( struct AMessage * ) );

+	if( xQueue == 0 )

+	{

+		// Failed to create the queue.

+	}

+

+	// ...

+

+	// Send a pointer to a struct AMessage object.  Don't block if the

+	// queue is already full.

+	pxMessage = & xMessage;

+	xQueueSend( xQueue, ( void * ) &pxMessage, ( portTickType ) 0 );

+

+	// ... Rest of task code.

+ }

+

+ // Task to peek the data from the queue.

+ void vADifferentTask( void *pvParameters )

+ {

+ struct AMessage *pxRxedMessage;

+

+	if( xQueue != 0 )

+	{

+		// Peek a message on the created queue.  Block for 10 ticks if a

+		// message is not immediately available.

+		if( xQueuePeek( xQueue, &( pxRxedMessage ), ( portTickType ) 10 ) )

+		{

+			// pcRxedMessage now points to the struct AMessage variable posted

+			// by vATask, but the item still remains on the queue.

+		}

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueReceive xQueueReceive

+ * \ingroup QueueManagement

+ */

+#define xQueuePeek( xQueue, pvBuffer, xTicksToWait ) xQueueGenericReceive( ( xQueue ), ( pvBuffer ), ( xTicksToWait ), pdTRUE )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueReceive(

+								 xQueueHandle xQueue,

+								 void *pvBuffer,

+								 portTickType xTicksToWait

+							);</pre>

+ *

+ * This is a macro that calls the xQueueGenericReceive() function.

+ *

+ * Receive an item from a queue.  The item is received by copy so a buffer of

+ * adequate size must be provided.  The number of bytes copied into the buffer

+ * was defined when the queue was created.

+ *

+ * Successfully received items are removed from the queue.

+ *

+ * This function must not be used in an interrupt service routine.  See

+ * xQueueReceiveFromISR for an alternative that can.

+ *

+ * @param pxQueue The handle to the queue from which the item is to be

+ * received.

+ *

+ * @param pvBuffer Pointer to the buffer into which the received item will

+ * be copied.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for an item to receive should the queue be empty at the time

+ * of the call.	 xQueueReceive() will return immediately if xTicksToWait

+ * is zero and the queue is empty.  The time is defined in tick periods so the

+ * constant portTICK_RATE_MS should be used to convert to real time if this is

+ * required.

+ *

+ * @return pdTRUE if an item was successfully received from the queue,

+ * otherwise pdFALSE.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ xQueueHandle xQueue;

+

+ // Task to create a queue and post a value.

+ void vATask( void *pvParameters )

+ {

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue = xQueueCreate( 10, sizeof( struct AMessage * ) );

+	if( xQueue == 0 )

+	{

+		// Failed to create the queue.

+	}

+

+	// ...

+

+	// Send a pointer to a struct AMessage object.  Don't block if the

+	// queue is already full.

+	pxMessage = & xMessage;

+	xQueueSend( xQueue, ( void * ) &pxMessage, ( portTickType ) 0 );

+

+	// ... Rest of task code.

+ }

+

+ // Task to receive from the queue.

+ void vADifferentTask( void *pvParameters )

+ {

+ struct AMessage *pxRxedMessage;

+

+	if( xQueue != 0 )

+	{

+		// Receive a message on the created queue.  Block for 10 ticks if a

+		// message is not immediately available.

+		if( xQueueReceive( xQueue, &( pxRxedMessage ), ( portTickType ) 10 ) )

+		{

+			// pcRxedMessage now points to the struct AMessage variable posted

+			// by vATask.

+		}

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueReceive xQueueReceive

+ * \ingroup QueueManagement

+ */

+#define xQueueReceive( xQueue, pvBuffer, xTicksToWait ) xQueueGenericReceive( ( xQueue ), ( pvBuffer ), ( xTicksToWait ), pdFALSE )

+

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueGenericReceive(

+									   xQueueHandle	xQueue,

+									   void	*pvBuffer,

+									   portTickType	xTicksToWait

+									   portBASE_TYPE	xJustPeek

+									);</pre>

+ *

+ * It is preferred that the macro xQueueReceive() be used rather than calling

+ * this function directly.

+ *

+ * Receive an item from a queue.  The item is received by copy so a buffer of

+ * adequate size must be provided.  The number of bytes copied into the buffer

+ * was defined when the queue was created.

+ *

+ * This function must not be used in an interrupt service routine.  See

+ * xQueueReceiveFromISR for an alternative that can.

+ *

+ * @param pxQueue The handle to the queue from which the item is to be

+ * received.

+ *

+ * @param pvBuffer Pointer to the buffer into which the received item will

+ * be copied.

+ *

+ * @param xTicksToWait The maximum amount of time the task should block

+ * waiting for an item to receive should the queue be empty at the time

+ * of the call.	 The time is defined in tick periods so the constant

+ * portTICK_RATE_MS should be used to convert to real time if this is required.

+ * xQueueGenericReceive() will return immediately if the queue is empty and

+ * xTicksToWait is 0.

+ *

+ * @param xJustPeek When set to true, the item received from the queue is not

+ * actually removed from the queue - meaning a subsequent call to

+ * xQueueReceive() will return the same item.  When set to false, the item

+ * being received from the queue is also removed from the queue.

+ *

+ * @return pdTRUE if an item was successfully received from the queue,

+ * otherwise pdFALSE.

+ *

+ * Example usage:

+   <pre>

+ struct AMessage

+ {

+	char ucMessageID;

+	char ucData[ 20 ];

+ } xMessage;

+

+ xQueueHandle xQueue;

+

+ // Task to create a queue and post a value.

+ void vATask( void *pvParameters )

+ {

+ struct AMessage *pxMessage;

+

+	// Create a queue capable of containing 10 pointers to AMessage structures.

+	// These should be passed by pointer as they contain a lot of data.

+	xQueue = xQueueCreate( 10, sizeof( struct AMessage * ) );

+	if( xQueue == 0 )

+	{

+		// Failed to create the queue.

+	}

+

+	// ...

+

+	// Send a pointer to a struct AMessage object.  Don't block if the

+	// queue is already full.

+	pxMessage = & xMessage;

+	xQueueSend( xQueue, ( void * ) &pxMessage, ( portTickType ) 0 );

+

+	// ... Rest of task code.

+ }

+

+ // Task to receive from the queue.

+ void vADifferentTask( void *pvParameters )

+ {

+ struct AMessage *pxRxedMessage;

+

+	if( xQueue != 0 )

+	{

+		// Receive a message on the created queue.  Block for 10 ticks if a

+		// message is not immediately available.

+		if( xQueueGenericReceive( xQueue, &( pxRxedMessage ), ( portTickType ) 10 ) )

+		{

+			// pcRxedMessage now points to the struct AMessage variable posted

+			// by vATask.

+		}

+	}

+

+	// ... Rest of task code.

+ }

+ </pre>

+ * \defgroup xQueueReceive xQueueReceive

+ * \ingroup QueueManagement

+ */

+signed portBASE_TYPE xQueueGenericReceive( xQueueHandle xQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeek );

+

+/**

+ * queue. h

+ * <pre>unsigned portBASE_TYPE uxQueueMessagesWaiting( const xQueueHandle xQueue );</pre>

+ *

+ * Return the number of messages stored in a queue.

+ *

+ * @param xQueue A handle to the queue being queried.

+ *

+ * @return The number of messages available in the queue.

+ *

+ * \page uxQueueMessagesWaiting uxQueueMessagesWaiting

+ * \ingroup QueueManagement

+ */

+unsigned portBASE_TYPE uxQueueMessagesWaiting( const xQueueHandle xQueue );

+

+/**

+ * queue. h

+ * <pre>void vQueueDelete( xQueueHandle xQueue );</pre>

+ *

+ * Delete a queue - freeing all the memory allocated for storing of items

+ * placed on the queue.

+ *

+ * @param xQueue A handle to the queue to be deleted.

+ *

+ * \page vQueueDelete vQueueDelete

+ * \ingroup QueueManagement

+ */

+void vQueueDelete( xQueueHandle pxQueue );

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSendToFrontFromISR(

+										 xQueueHandle pxQueue,

+										 const void *pvItemToQueue,

+										 portBASE_TYPE *pxHigherPriorityTaskWoken

+									  );

+ </pre>

+ *

+ * This is a macro that calls xQueueGenericSendFromISR().

+ *

+ * Post an item to the front of a queue.  It is safe to use this macro from

+ * within an interrupt service routine.

+ *

+ * Items are queued by copy not reference so it is preferable to only

+ * queue small items, especially when called from an ISR.  In most cases

+ * it would be preferable to store a pointer to the item being queued.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param pxHigherPriorityTaskWoken xQueueSendToFrontFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if sending to the queue caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xQueueSendToFromFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @return pdTRUE if the data was successfully sent to the queue, otherwise

+ * errQUEUE_FULL.

+ *

+ * Example usage for buffered IO (where the ISR can obtain more than one value

+ * per call):

+   <pre>

+ void vBufferISR( void )

+ {

+ char cIn;

+ portBASE_TYPE xHigherPrioritTaskWoken;

+

+	// We have not woken a task at the start of the ISR.

+	xHigherPriorityTaskWoken = pdFALSE;

+

+	// Loop until the buffer is empty.

+	do

+	{

+		// Obtain a byte from the buffer.

+		cIn = portINPUT_BYTE( RX_REGISTER_ADDRESS );

+

+		// Post the byte.

+		xQueueSendToFrontFromISR( xRxQueue, &cIn, &xHigherPriorityTaskWoken );

+

+	} while( portINPUT_BYTE( BUFFER_COUNT ) );

+

+	// Now the buffer is empty we can switch context if necessary.

+	if( xHigherPriorityTaskWoken )

+	{

+		taskYIELD ();

+	}

+ }

+ </pre>

+ *

+ * \defgroup xQueueSendFromISR xQueueSendFromISR

+ * \ingroup QueueManagement

+ */

+#define xQueueSendToFrontFromISR( pxQueue, pvItemToQueue, pxHigherPriorityTaskWoken ) xQueueGenericSendFromISR( ( pxQueue ), ( pvItemToQueue ), ( pxHigherPriorityTaskWoken ), queueSEND_TO_FRONT )

+

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSendToBackFromISR(

+										 xQueueHandle pxQueue,

+										 const void *pvItemToQueue,

+										 portBASE_TYPE *pxHigherPriorityTaskWoken

+									  );

+ </pre>

+ *

+ * This is a macro that calls xQueueGenericSendFromISR().

+ *

+ * Post an item to the back of a queue.  It is safe to use this macro from

+ * within an interrupt service routine.

+ *

+ * Items are queued by copy not reference so it is preferable to only

+ * queue small items, especially when called from an ISR.  In most cases

+ * it would be preferable to store a pointer to the item being queued.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param pxHigherPriorityTaskWoken xQueueSendToBackFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if sending to the queue caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xQueueSendToBackFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @return pdTRUE if the data was successfully sent to the queue, otherwise

+ * errQUEUE_FULL.

+ *

+ * Example usage for buffered IO (where the ISR can obtain more than one value

+ * per call):

+   <pre>

+ void vBufferISR( void )

+ {

+ char cIn;

+ portBASE_TYPE xHigherPriorityTaskWoken;

+

+	// We have not woken a task at the start of the ISR.

+	xHigherPriorityTaskWoken = pdFALSE;

+

+	// Loop until the buffer is empty.

+	do

+	{

+		// Obtain a byte from the buffer.

+		cIn = portINPUT_BYTE( RX_REGISTER_ADDRESS );

+

+		// Post the byte.

+		xQueueSendToBackFromISR( xRxQueue, &cIn, &xHigherPriorityTaskWoken );

+

+	} while( portINPUT_BYTE( BUFFER_COUNT ) );

+

+	// Now the buffer is empty we can switch context if necessary.

+	if( xHigherPriorityTaskWoken )

+	{

+		taskYIELD ();

+	}

+ }

+ </pre>

+ *

+ * \defgroup xQueueSendFromISR xQueueSendFromISR

+ * \ingroup QueueManagement

+ */

+#define xQueueSendToBackFromISR( pxQueue, pvItemToQueue, pxHigherPriorityTaskWoken ) xQueueGenericSendFromISR( ( pxQueue ), ( pvItemToQueue ), ( pxHigherPriorityTaskWoken ), queueSEND_TO_BACK )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueSendFromISR(

+									 xQueueHandle pxQueue,

+									 const void *pvItemToQueue,

+									 portBASE_TYPE *pxHigherPriorityTaskWoken

+								);

+ </pre>

+ *

+ * This is a macro that calls xQueueGenericSendFromISR().  It is included

+ * for backward compatibility with versions of FreeRTOS.org that did not

+ * include the xQueueSendToBackFromISR() and xQueueSendToFrontFromISR()

+ * macros.

+ *

+ * Post an item to the back of a queue.  It is safe to use this function from

+ * within an interrupt service routine.

+ *

+ * Items are queued by copy not reference so it is preferable to only

+ * queue small items, especially when called from an ISR.  In most cases

+ * it would be preferable to store a pointer to the item being queued.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param pxHigherPriorityTaskWoken xQueueSendFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if sending to the queue caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xQueueSendFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @return pdTRUE if the data was successfully sent to the queue, otherwise

+ * errQUEUE_FULL.

+ *

+ * Example usage for buffered IO (where the ISR can obtain more than one value

+ * per call):

+   <pre>

+ void vBufferISR( void )

+ {

+ char cIn;

+ portBASE_TYPE xHigherPriorityTaskWoken;

+

+	// We have not woken a task at the start of the ISR.

+	xHigherPriorityTaskWoken = pdFALSE;

+

+	// Loop until the buffer is empty.

+	do

+	{

+		// Obtain a byte from the buffer.

+		cIn = portINPUT_BYTE( RX_REGISTER_ADDRESS );

+

+		// Post the byte.

+		xQueueSendFromISR( xRxQueue, &cIn, &xHigherPriorityTaskWoken );

+

+	} while( portINPUT_BYTE( BUFFER_COUNT ) );

+

+	// Now the buffer is empty we can switch context if necessary.

+	if( xHigherPriorityTaskWoken )

+	{

+		// Actual macro used here is port specific.

+		taskYIELD_FROM_ISR ();

+	}

+ }

+ </pre>

+ *

+ * \defgroup xQueueSendFromISR xQueueSendFromISR

+ * \ingroup QueueManagement

+ */

+#define xQueueSendFromISR( pxQueue, pvItemToQueue, pxHigherPriorityTaskWoken ) xQueueGenericSendFromISR( ( pxQueue ), ( pvItemToQueue ), ( pxHigherPriorityTaskWoken ), queueSEND_TO_BACK )

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueGenericSendFromISR(

+										   xQueueHandle	pxQueue,

+										   const	void	*pvItemToQueue,

+										   portBASE_TYPE	*pxHigherPriorityTaskWoken,

+										   portBASE_TYPE	xCopyPosition

+									   );

+ </pre>

+ *

+ * It is preferred that the macros xQueueSendFromISR(),

+ * xQueueSendToFrontFromISR() and xQueueSendToBackFromISR() be used in place

+ * of calling this function directly.

+ *

+ * Post an item on a queue.  It is safe to use this function from within an

+ * interrupt service routine.

+ *

+ * Items are queued by copy not reference so it is preferable to only

+ * queue small items, especially when called from an ISR.  In most cases

+ * it would be preferable to store a pointer to the item being queued.

+ *

+ * @param xQueue The handle to the queue on which the item is to be posted.

+ *

+ * @param pvItemToQueue A pointer to the item that is to be placed on the

+ * queue.  The size of the items the queue will hold was defined when the

+ * queue was created, so this many bytes will be copied from pvItemToQueue

+ * into the queue storage area.

+ *

+ * @param pxHigherPriorityTaskWoken xQueueGenericSendFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if sending to the queue caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xQueueGenericSendFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @param xCopyPosition Can take the value queueSEND_TO_BACK to place the

+ * item at the back of the queue, or queueSEND_TO_FRONT to place the item

+ * at the front of the queue (for high priority messages).

+ *

+ * @return pdTRUE if the data was successfully sent to the queue, otherwise

+ * errQUEUE_FULL.

+ *

+ * Example usage for buffered IO (where the ISR can obtain more than one value

+ * per call):

+   <pre>

+ void vBufferISR( void )

+ {

+ char cIn;

+ portBASE_TYPE xHigherPriorityTaskWokenByPost;

+

+	// We have not woken a task at the start of the ISR.

+	xHigherPriorityTaskWokenByPost = pdFALSE;

+

+	// Loop until the buffer is empty.

+	do

+	{

+		// Obtain a byte from the buffer.

+		cIn = portINPUT_BYTE( RX_REGISTER_ADDRESS );

+

+		// Post each byte.

+		xQueueGenericSendFromISR( xRxQueue, &cIn, &xHigherPriorityTaskWokenByPost, queueSEND_TO_BACK );

+

+	} while( portINPUT_BYTE( BUFFER_COUNT ) );

+

+	// Now the buffer is empty we can switch context if necessary.  Note that the

+	// name of the yield function required is port specific.

+	if( xHigherPriorityTaskWokenByPost )

+	{

+		taskYIELD_YIELD_FROM_ISR();

+	}

+ }

+ </pre>

+ *

+ * \defgroup xQueueSendFromISR xQueueSendFromISR

+ * \ingroup QueueManagement

+ */

+signed portBASE_TYPE xQueueGenericSendFromISR( xQueueHandle pxQueue, const void * const pvItemToQueue, signed portBASE_TYPE *pxHigherPriorityTaskWoken, portBASE_TYPE xCopyPosition );

+

+/**

+ * queue. h

+ * <pre>

+ portBASE_TYPE xQueueReceiveFromISR(

+									   xQueueHandle	pxQueue,

+									   void	*pvBuffer,

+									   portBASE_TYPE	*pxTaskWoken

+								   );

+ * </pre>

+ *

+ * Receive an item from a queue.  It is safe to use this function from within an

+ * interrupt service routine.

+ *

+ * @param pxQueue The handle to the queue from which the item is to be

+ * received.

+ *

+ * @param pvBuffer Pointer to the buffer into which the received item will

+ * be copied.

+ *

+ * @param pxTaskWoken A task may be blocked waiting for space to become

+ * available on the queue.  If xQueueReceiveFromISR causes such a task to

+ * unblock *pxTaskWoken will get set to pdTRUE, otherwise *pxTaskWoken will

+ * remain unchanged.

+ *

+ * @return pdTRUE if an item was successfully received from the queue,

+ * otherwise pdFALSE.

+ *

+ * Example usage:

+   <pre>

+

+ xQueueHandle xQueue;

+

+ // Function to create a queue and post some values.

+ void vAFunction( void *pvParameters )

+ {

+ char cValueToPost;

+ const portTickType xBlockTime = ( portTickType )0xff;

+

+	// Create a queue capable of containing 10 characters.

+	xQueue = xQueueCreate( 10, sizeof( char ) );

+	if( xQueue == 0 )

+	{

+		// Failed to create the queue.

+	}

+

+	// ...

+

+	// Post some characters that will be used within an ISR.  If the queue

+	// is full then this task will block for xBlockTime ticks.

+	cValueToPost = 'a';

+	xQueueSend( xQueue, ( void * ) &cValueToPost, xBlockTime );

+	cValueToPost = 'b';

+	xQueueSend( xQueue, ( void * ) &cValueToPost, xBlockTime );

+

+	// ... keep posting characters ... this task may block when the queue

+	// becomes full.

+

+	cValueToPost = 'c';

+	xQueueSend( xQueue, ( void * ) &cValueToPost, xBlockTime );

+ }

+

+ // ISR that outputs all the characters received on the queue.

+ void vISR_Routine( void )

+ {

+ portBASE_TYPE xTaskWokenByReceive = pdFALSE;

+ char cRxedChar;

+

+	while( xQueueReceiveFromISR( xQueue, ( void * ) &cRxedChar, &xTaskWokenByReceive) )

+	{

+		// A character was received.  Output the character now.

+		vOutputCharacter( cRxedChar );

+

+		// If removing the character from the queue woke the task that was

+		// posting onto the queue cTaskWokenByReceive will have been set to

+		// pdTRUE.  No matter how many times this loop iterates only one

+		// task will be woken.

+	}

+

+	if( cTaskWokenByPost != ( char ) pdFALSE;

+	{

+		taskYIELD ();

+	}

+ }

+ </pre>

+ * \defgroup xQueueReceiveFromISR xQueueReceiveFromISR

+ * \ingroup QueueManagement

+ */

+signed portBASE_TYPE xQueueReceiveFromISR( xQueueHandle pxQueue, void * const pvBuffer, signed portBASE_TYPE *pxHigherPriorityTaskWoken );

+

+/*

+ * Utilities to query queues that are safe to use from an ISR.  These utilities

+ * should be used only from witin an ISR, or within a critical section.

+ */

+signed portBASE_TYPE xQueueIsQueueEmptyFromISR( const xQueueHandle pxQueue );

+signed portBASE_TYPE xQueueIsQueueFullFromISR( const xQueueHandle pxQueue );

+unsigned portBASE_TYPE uxQueueMessagesWaitingFromISR( const xQueueHandle pxQueue );

+

+

+/*

+ * xQueueAltGenericSend() is an alternative version of xQueueGenericSend().

+ * Likewise xQueueAltGenericReceive() is an alternative version of

+ * xQueueGenericReceive().

+ *

+ * The source code that implements the alternative (Alt) API is much

+ * simpler	because it executes everything from within a critical section.

+ * This is	the approach taken by many other RTOSes, but FreeRTOS.org has the

+ * preferred fully featured API too.  The fully featured API has more

+ * complex	code that takes longer to execute, but makes much less use of

+ * critical sections.  Therefore the alternative API sacrifices interrupt

+ * responsiveness to gain execution speed, whereas the fully featured API

+ * sacrifices execution speed to ensure better interrupt responsiveness.

+ */

+signed portBASE_TYPE xQueueAltGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition );

+signed portBASE_TYPE xQueueAltGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking );

+#define xQueueAltSendToFront( xQueue, pvItemToQueue, xTicksToWait ) xQueueAltGenericSend( ( xQueue ), ( pvItemToQueue ), ( xTicksToWait ), queueSEND_TO_FRONT )

+#define xQueueAltSendToBack( xQueue, pvItemToQueue, xTicksToWait ) xQueueAltGenericSend( ( xQueue ), ( pvItemToQueue ), ( xTicksToWait ), queueSEND_TO_BACK )

+#define xQueueAltReceive( xQueue, pvBuffer, xTicksToWait ) xQueueAltGenericReceive( ( xQueue ), ( pvBuffer ), ( xTicksToWait ), pdFALSE )

+#define xQueueAltPeek( xQueue, pvBuffer, xTicksToWait ) xQueueAltGenericReceive( ( xQueue ), ( pvBuffer ), ( xTicksToWait ), pdTRUE )

+

+/*

+ * The functions defined above are for passing data to and from tasks.  The

+ * functions below are the equivalents for passing data to and from

+ * co-routines.

+ *

+ * These functions are called from the co-routine macro implementation and

+ * should not be called directly from application code.  Instead use the macro

+ * wrappers defined within croutine.h.

+ */

+signed portBASE_TYPE xQueueCRSendFromISR( xQueueHandle pxQueue, const void *pvItemToQueue, signed portBASE_TYPE xCoRoutinePreviouslyWoken );

+signed portBASE_TYPE xQueueCRReceiveFromISR( xQueueHandle pxQueue, void *pvBuffer, signed portBASE_TYPE *pxTaskWoken );

+signed portBASE_TYPE xQueueCRSend( xQueueHandle pxQueue, const void *pvItemToQueue, portTickType xTicksToWait );

+signed portBASE_TYPE xQueueCRReceive( xQueueHandle pxQueue, void *pvBuffer, portTickType xTicksToWait );

+

+/*

+ * For internal use only.  Use xSemaphoreCreateMutex(), 

+ * xSemaphoreCreateCounting() or xSemaphoreGetMutexHolder() instead of calling 

+ * these functions directly.

+ */

+xQueueHandle xQueueCreateMutex( unsigned char ucQueueType );

+xQueueHandle xQueueCreateCountingSemaphore( unsigned portBASE_TYPE uxCountValue, unsigned portBASE_TYPE uxInitialCount );

+void* xQueueGetMutexHolder( xQueueHandle xSemaphore );

+

+/*

+ * For internal use only.  Use xSemaphoreTakeMutexRecursive() or

+ * xSemaphoreGiveMutexRecursive() instead of calling these functions directly.

+ */

+portBASE_TYPE xQueueTakeMutexRecursive( xQueueHandle pxMutex, portTickType xBlockTime );

+portBASE_TYPE xQueueGiveMutexRecursive( xQueueHandle pxMutex );

+

+/*

+ * Reset a queue back to its original empty state.  pdPASS is returned if the

+ * queue is successfully reset.  pdFAIL is returned if the queue could not be

+ * reset because there are tasks blocked on the queue waiting to either

+ * receive from the queue or send to the queue.

+ */

+#define xQueueReset( pxQueue ) xQueueGenericReset( pxQueue, pdFALSE )

+

+/*

+ * The registry is provided as a means for kernel aware debuggers to

+ * locate queues, semaphores and mutexes.  Call vQueueAddToRegistry() add

+ * a queue, semaphore or mutex handle to the registry if you want the handle

+ * to be available to a kernel aware debugger.  If you are not using a kernel

+ * aware debugger then this function can be ignored.

+ *

+ * configQUEUE_REGISTRY_SIZE defines the maximum number of handles the

+ * registry can hold.  configQUEUE_REGISTRY_SIZE must be greater than 0

+ * within FreeRTOSConfig.h for the registry to be available.  Its value

+ * does not effect the number of queues, semaphores and mutexes that can be

+ * created - just the number that the registry can hold.

+ *

+ * @param xQueue The handle of the queue being added to the registry.  This

+ * is the handle returned by a call to xQueueCreate().  Semaphore and mutex

+ * handles can also be passed in here.

+ *

+ * @param pcName The name to be associated with the handle.  This is the

+ * name that the kernel aware debugger will display.

+ */

+#if configQUEUE_REGISTRY_SIZE > 0U

+	void vQueueAddToRegistry( xQueueHandle xQueue, signed char *pcName );

+#endif

+

+/*

+ * Generic version of the queue creation function, which is in turn called by 

+ * any queue, semaphore or mutex creation function or macro.

+ */

+    xQueueHandle xQueueGenericCreate( void* buffer, unsigned portBASE_TYPE uxQueueLength, unsigned portBASE_TYPE uxItemSize, unsigned char ucQueueType );

+

+/* Not public API functions. */

+void vQueueWaitForMessageRestricted( xQueueHandle pxQueue, portTickType xTicksToWait );

+portBASE_TYPE xQueueGenericReset( xQueueHandle pxQueue, portBASE_TYPE xNewQueue );

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* QUEUE_H */

+

diff --git a/FreeRTOS/Source/include/semphr.h b/FreeRTOS/Source/include/semphr.h
new file mode 100644
index 0000000..bec8c06
--- /dev/null
+++ b/FreeRTOS/Source/include/semphr.h
@@ -0,0 +1,782 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef SEMAPHORE_H

+#define SEMAPHORE_H

+

+#ifndef INC_FREERTOS_H

+	#error "include FreeRTOS.h" must appear in source files before "include semphr.h"

+#endif

+

+#include "queue.h"

+

+typedef xQueueHandle xSemaphoreHandle;

+

+#define semBINARY_SEMAPHORE_QUEUE_LENGTH	( ( unsigned char ) 1U )

+#define semSEMAPHORE_QUEUE_ITEM_LENGTH		( ( unsigned char ) 0U )

+#define semGIVE_BLOCK_TIME					( ( portTickType ) 0U )

+

+

+/**

+ * semphr. h

+ * <pre>vSemaphoreCreateBinary( xSemaphoreHandle xSemaphore )</pre>

+ *

+ * <i>Macro</i> that implements a semaphore by using the existing queue mechanism.

+ * The queue length is 1 as this is a binary semaphore.  The data size is 0

+ * as we don't want to actually store any data - we just want to know if the

+ * queue is empty or full.

+ *

+ * This type of semaphore can be used for pure synchronisation between tasks or

+ * between an interrupt and a task.  The semaphore need not be given back once

+ * obtained, so one task/interrupt can continuously 'give' the semaphore while

+ * another continuously 'takes' the semaphore.  For this reason this type of

+ * semaphore does not use a priority inheritance mechanism.  For an alternative

+ * that does use priority inheritance see xSemaphoreCreateMutex().

+ *

+ * @param xSemaphore Handle to the created semaphore.  Should be of type xSemaphoreHandle.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore;

+

+ void vATask( void * pvParameters )

+ {

+    // Semaphore cannot be used before a call to vSemaphoreCreateBinary ().

+    // This is a macro so pass the variable in directly.

+    vSemaphoreCreateBinary( xSemaphore );

+

+    if( xSemaphore != NULL )

+    {

+        // The semaphore was created successfully.

+        // The semaphore can now be used.  

+    }

+ }

+ </pre>

+ * \defgroup vSemaphoreCreateBinary vSemaphoreCreateBinary

+ * \ingroup Semaphores

+ */

+xQueueHandle xSemaphoreCreateBinary(void);

+

+#define vSemaphoreCreateBinary( xSemaphore ) ( xSemaphore ) = xSemaphoreCreateBinary( )

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreTake( 

+ *                   xSemaphoreHandle xSemaphore, 

+ *                   portTickType xBlockTime 

+ *               )</pre>

+ *

+ * <i>Macro</i> to obtain a semaphore.  The semaphore must have previously been

+ * created with a call to vSemaphoreCreateBinary(), xSemaphoreCreateMutex() or

+ * xSemaphoreCreateCounting().

+ *

+ * @param xSemaphore A handle to the semaphore being taken - obtained when

+ * the semaphore was created.

+ *

+ * @param xBlockTime The time in ticks to wait for the semaphore to become

+ * available.  The macro portTICK_RATE_MS can be used to convert this to a

+ * real time.  A block time of zero can be used to poll the semaphore.  A block

+ * time of portMAX_DELAY can be used to block indefinitely (provided

+ * INCLUDE_vTaskSuspend is set to 1 in FreeRTOSConfig.h).

+ *

+ * @return pdTRUE if the semaphore was obtained.  pdFALSE

+ * if xBlockTime expired without the semaphore becoming available.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore = NULL;

+

+ // A task that creates a semaphore.

+ void vATask( void * pvParameters )

+ {

+    // Create the semaphore to guard a shared resource.

+    vSemaphoreCreateBinary( xSemaphore );

+ }

+

+ // A task that uses the semaphore.

+ void vAnotherTask( void * pvParameters )

+ {

+    // ... Do other things.

+

+    if( xSemaphore != NULL )

+    {

+        // See if we can obtain the semaphore.  If the semaphore is not available

+        // wait 10 ticks to see if it becomes free.	

+        if( xSemaphoreTake( xSemaphore, ( portTickType ) 10 ) == pdTRUE )

+        {

+            // We were able to obtain the semaphore and can now access the

+            // shared resource.

+

+            // ...

+

+            // We have finished accessing the shared resource.  Release the 

+            // semaphore.

+            xSemaphoreGive( xSemaphore );

+        }

+        else

+        {

+            // We could not obtain the semaphore and can therefore not access

+            // the shared resource safely.

+        }

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreTake xSemaphoreTake

+ * \ingroup Semaphores

+ */

+#define xSemaphoreTake( xSemaphore, xBlockTime )		xQueueGenericReceive( ( xQueueHandle ) ( xSemaphore ), NULL, ( xBlockTime ), pdFALSE )

+

+/**

+ * semphr. h

+ * xSemaphoreTakeRecursive( 

+ *                          xSemaphoreHandle xMutex, 

+ *                          portTickType xBlockTime 

+ *                        )

+ *

+ * <i>Macro</i> to recursively obtain, or 'take', a mutex type semaphore.  

+ * The mutex must have previously been created using a call to 

+ * xSemaphoreCreateRecursiveMutex();

+ * 

+ * configUSE_RECURSIVE_MUTEXES must be set to 1 in FreeRTOSConfig.h for this

+ * macro to be available.

+ * 

+ * This macro must not be used on mutexes created using xSemaphoreCreateMutex().

+ *

+ * A mutex used recursively can be 'taken' repeatedly by the owner. The mutex 

+ * doesn't become available again until the owner has called 

+ * xSemaphoreGiveRecursive() for each successful 'take' request.  For example, 

+ * if a task successfully 'takes' the same mutex 5 times then the mutex will 

+ * not be available to any other task until it has also  'given' the mutex back

+ * exactly five times.

+ *

+ * @param xMutex A handle to the mutex being obtained.  This is the

+ * handle returned by xSemaphoreCreateRecursiveMutex();

+ *

+ * @param xBlockTime The time in ticks to wait for the semaphore to become

+ * available.  The macro portTICK_RATE_MS can be used to convert this to a

+ * real time.  A block time of zero can be used to poll the semaphore.  If

+ * the task already owns the semaphore then xSemaphoreTakeRecursive() will

+ * return immediately no matter what the value of xBlockTime. 

+ *

+ * @return pdTRUE if the semaphore was obtained.  pdFALSE if xBlockTime

+ * expired without the semaphore becoming available.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xMutex = NULL;

+

+ // A task that creates a mutex.

+ void vATask( void * pvParameters )

+ {

+    // Create the mutex to guard a shared resource.

+    xMutex = xSemaphoreCreateRecursiveMutex();

+ }

+

+ // A task that uses the mutex.

+ void vAnotherTask( void * pvParameters )

+ {

+    // ... Do other things.

+

+    if( xMutex != NULL )

+    {

+        // See if we can obtain the mutex.  If the mutex is not available

+        // wait 10 ticks to see if it becomes free.	

+        if( xSemaphoreTakeRecursive( xSemaphore, ( portTickType ) 10 ) == pdTRUE )

+        {

+            // We were able to obtain the mutex and can now access the

+            // shared resource.

+

+            // ...

+            // For some reason due to the nature of the code further calls to 

+			// xSemaphoreTakeRecursive() are made on the same mutex.  In real

+			// code these would not be just sequential calls as this would make

+			// no sense.  Instead the calls are likely to be buried inside

+			// a more complex call structure.

+            xSemaphoreTakeRecursive( xMutex, ( portTickType ) 10 );

+            xSemaphoreTakeRecursive( xMutex, ( portTickType ) 10 );

+

+            // The mutex has now been 'taken' three times, so will not be 

+			// available to another task until it has also been given back

+			// three times.  Again it is unlikely that real code would have

+			// these calls sequentially, but instead buried in a more complex

+			// call structure.  This is just for illustrative purposes.

+            xSemaphoreGiveRecursive( xMutex );

+			xSemaphoreGiveRecursive( xMutex );

+			xSemaphoreGiveRecursive( xMutex );

+

+			// Now the mutex can be taken by other tasks.

+        }

+        else

+        {

+            // We could not obtain the mutex and can therefore not access

+            // the shared resource safely.

+        }

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreTakeRecursive xSemaphoreTakeRecursive

+ * \ingroup Semaphores

+ */

+#define xSemaphoreTakeRecursive( xMutex, xBlockTime )	xQueueTakeMutexRecursive( ( xMutex ), ( xBlockTime ) )

+

+

+/* 

+ * xSemaphoreAltTake() is an alternative version of xSemaphoreTake().

+ *

+ * The source code that implements the alternative (Alt) API is much 

+ * simpler	because it executes everything from within a critical section.  

+ * This is	the approach taken by many other RTOSes, but FreeRTOS.org has the 

+ * preferred fully featured API too.  The fully featured API has more 

+ * complex	code that takes longer to execute, but makes much less use of 

+ * critical sections.  Therefore the alternative API sacrifices interrupt 

+ * responsiveness to gain execution speed, whereas the fully featured API

+ * sacrifices execution speed to ensure better interrupt responsiveness.

+ */

+#define xSemaphoreAltTake( xSemaphore, xBlockTime )		xQueueAltGenericReceive( ( xQueueHandle ) ( xSemaphore ), NULL, ( xBlockTime ), pdFALSE )

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreGive( xSemaphoreHandle xSemaphore )</pre>

+ *

+ * <i>Macro</i> to release a semaphore.  The semaphore must have previously been

+ * created with a call to vSemaphoreCreateBinary(), xSemaphoreCreateMutex() or

+ * xSemaphoreCreateCounting(). and obtained using sSemaphoreTake().

+ *

+ * This macro must not be used from an ISR.  See xSemaphoreGiveFromISR () for

+ * an alternative which can be used from an ISR.

+ *

+ * This macro must also not be used on semaphores created using 

+ * xSemaphoreCreateRecursiveMutex().

+ *

+ * @param xSemaphore A handle to the semaphore being released.  This is the

+ * handle returned when the semaphore was created.

+ *

+ * @return pdTRUE if the semaphore was released.  pdFALSE if an error occurred.

+ * Semaphores are implemented using queues.  An error can occur if there is

+ * no space on the queue to post a message - indicating that the 

+ * semaphore was not first obtained correctly.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore = NULL;

+

+ void vATask( void * pvParameters )

+ {

+    // Create the semaphore to guard a shared resource.

+    vSemaphoreCreateBinary( xSemaphore );

+

+    if( xSemaphore != NULL )

+    {

+        if( xSemaphoreGive( xSemaphore ) != pdTRUE )

+        {

+            // We would expect this call to fail because we cannot give

+            // a semaphore without first "taking" it!

+        }

+

+        // Obtain the semaphore - don't block if the semaphore is not

+        // immediately available.

+        if( xSemaphoreTake( xSemaphore, ( portTickType ) 0 ) )

+        {

+            // We now have the semaphore and can access the shared resource.

+

+            // ...

+

+            // We have finished accessing the shared resource so can free the

+            // semaphore.

+            if( xSemaphoreGive( xSemaphore ) != pdTRUE )

+            {

+                // We would not expect this call to fail because we must have

+                // obtained the semaphore to get here.

+            }

+        }

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreGive xSemaphoreGive

+ * \ingroup Semaphores

+ */

+#define xSemaphoreGive( xSemaphore )		xQueueGenericSend( ( xQueueHandle ) ( xSemaphore ), NULL, semGIVE_BLOCK_TIME, queueSEND_TO_BACK )

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreGiveRecursive( xSemaphoreHandle xMutex )</pre>

+ *

+ * <i>Macro</i> to recursively release, or 'give', a mutex type semaphore.

+ * The mutex must have previously been created using a call to 

+ * xSemaphoreCreateRecursiveMutex();

+ * 

+ * configUSE_RECURSIVE_MUTEXES must be set to 1 in FreeRTOSConfig.h for this

+ * macro to be available.

+ *

+ * This macro must not be used on mutexes created using xSemaphoreCreateMutex().

+ * 

+ * A mutex used recursively can be 'taken' repeatedly by the owner. The mutex 

+ * doesn't become available again until the owner has called 

+ * xSemaphoreGiveRecursive() for each successful 'take' request.  For example, 

+ * if a task successfully 'takes' the same mutex 5 times then the mutex will 

+ * not be available to any other task until it has also  'given' the mutex back

+ * exactly five times.

+ *

+ * @param xMutex A handle to the mutex being released, or 'given'.  This is the

+ * handle returned by xSemaphoreCreateMutex();

+ *

+ * @return pdTRUE if the semaphore was given.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xMutex = NULL;

+

+ // A task that creates a mutex.

+ void vATask( void * pvParameters )

+ {

+    // Create the mutex to guard a shared resource.

+    xMutex = xSemaphoreCreateRecursiveMutex();

+ }

+

+ // A task that uses the mutex.

+ void vAnotherTask( void * pvParameters )

+ {

+    // ... Do other things.

+

+    if( xMutex != NULL )

+    {

+        // See if we can obtain the mutex.  If the mutex is not available

+        // wait 10 ticks to see if it becomes free.	

+        if( xSemaphoreTakeRecursive( xMutex, ( portTickType ) 10 ) == pdTRUE )

+        {

+            // We were able to obtain the mutex and can now access the

+            // shared resource.

+

+            // ...

+            // For some reason due to the nature of the code further calls to 

+			// xSemaphoreTakeRecursive() are made on the same mutex.  In real

+			// code these would not be just sequential calls as this would make

+			// no sense.  Instead the calls are likely to be buried inside

+			// a more complex call structure.

+            xSemaphoreTakeRecursive( xMutex, ( portTickType ) 10 );

+            xSemaphoreTakeRecursive( xMutex, ( portTickType ) 10 );

+

+            // The mutex has now been 'taken' three times, so will not be 

+			// available to another task until it has also been given back

+			// three times.  Again it is unlikely that real code would have

+			// these calls sequentially, it would be more likely that the calls

+			// to xSemaphoreGiveRecursive() would be called as a call stack

+			// unwound.  This is just for demonstrative purposes.

+            xSemaphoreGiveRecursive( xMutex );

+			xSemaphoreGiveRecursive( xMutex );

+			xSemaphoreGiveRecursive( xMutex );

+

+			// Now the mutex can be taken by other tasks.

+        }

+        else

+        {

+            // We could not obtain the mutex and can therefore not access

+            // the shared resource safely.

+        }

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreGiveRecursive xSemaphoreGiveRecursive

+ * \ingroup Semaphores

+ */

+#define xSemaphoreGiveRecursive( xMutex )	xQueueGiveMutexRecursive( ( xMutex ) )

+

+/* 

+ * xSemaphoreAltGive() is an alternative version of xSemaphoreGive().

+ *

+ * The source code that implements the alternative (Alt) API is much 

+ * simpler	because it executes everything from within a critical section.  

+ * This is	the approach taken by many other RTOSes, but FreeRTOS.org has the 

+ * preferred fully featured API too.  The fully featured API has more 

+ * complex	code that takes longer to execute, but makes much less use of 

+ * critical sections.  Therefore the alternative API sacrifices interrupt 

+ * responsiveness to gain execution speed, whereas the fully featured API

+ * sacrifices execution speed to ensure better interrupt responsiveness.

+ */

+#define xSemaphoreAltGive( xSemaphore )		xQueueAltGenericSend( ( xQueueHandle ) ( xSemaphore ), NULL, semGIVE_BLOCK_TIME, queueSEND_TO_BACK )

+

+/**

+ * semphr. h

+ * <pre>

+ xSemaphoreGiveFromISR( 

+                          xSemaphoreHandle xSemaphore, 

+                          signed portBASE_TYPE *pxHigherPriorityTaskWoken

+                      )</pre>

+ *

+ * <i>Macro</i> to  release a semaphore.  The semaphore must have previously been

+ * created with a call to vSemaphoreCreateBinary() or xSemaphoreCreateCounting().

+ *

+ * Mutex type semaphores (those created using a call to xSemaphoreCreateMutex())

+ * must not be used with this macro.

+ *

+ * This macro can be used from an ISR.

+ *

+ * @param xSemaphore A handle to the semaphore being released.  This is the

+ * handle returned when the semaphore was created.

+ *

+ * @param pxHigherPriorityTaskWoken xSemaphoreGiveFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if giving the semaphore caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xSemaphoreGiveFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @return pdTRUE if the semaphore was successfully given, otherwise errQUEUE_FULL.

+ *

+ * Example usage:

+ <pre>

+ \#define LONG_TIME 0xffff

+ \#define TICKS_TO_WAIT	10

+ xSemaphoreHandle xSemaphore = NULL;

+

+ // Repetitive task.

+ void vATask( void * pvParameters )

+ {

+    for( ;; )

+    {

+        // We want this task to run every 10 ticks of a timer.  The semaphore 

+        // was created before this task was started.

+

+        // Block waiting for the semaphore to become available.

+        if( xSemaphoreTake( xSemaphore, LONG_TIME ) == pdTRUE )

+        {

+            // It is time to execute.

+

+            // ...

+

+            // We have finished our task.  Return to the top of the loop where

+            // we will block on the semaphore until it is time to execute 

+            // again.  Note when using the semaphore for synchronisation with an

+			// ISR in this manner there is no need to 'give' the semaphore back.

+        }

+    }

+ }

+

+ // Timer ISR

+ void vTimerISR( void * pvParameters )

+ {

+ static unsigned char ucLocalTickCount = 0;

+ static signed portBASE_TYPE xHigherPriorityTaskWoken;

+

+    // A timer tick has occurred.

+

+    // ... Do other time functions.

+

+    // Is it time for vATask () to run?

+	xHigherPriorityTaskWoken = pdFALSE;

+    ucLocalTickCount++;

+    if( ucLocalTickCount >= TICKS_TO_WAIT )

+    {

+        // Unblock the task by releasing the semaphore.

+        xSemaphoreGiveFromISR( xSemaphore, &xHigherPriorityTaskWoken );

+

+        // Reset the count so we release the semaphore again in 10 ticks time.

+        ucLocalTickCount = 0;

+    }

+

+    if( xHigherPriorityTaskWoken != pdFALSE )

+    {

+        // We can force a context switch here.  Context switching from an

+        // ISR uses port specific syntax.  Check the demo task for your port

+        // to find the syntax required.

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreGiveFromISR xSemaphoreGiveFromISR

+ * \ingroup Semaphores

+ */

+#define xSemaphoreGiveFromISR( xSemaphore, pxHigherPriorityTaskWoken )			xQueueGenericSendFromISR( ( xQueueHandle ) ( xSemaphore ), NULL, ( pxHigherPriorityTaskWoken ), queueSEND_TO_BACK )

+

+/**

+ * semphr. h

+ * <pre>

+ xSemaphoreTakeFromISR( 

+                          xSemaphoreHandle xSemaphore, 

+                          signed portBASE_TYPE *pxHigherPriorityTaskWoken

+                      )</pre>

+ *

+ * <i>Macro</i> to  take a semaphore from an ISR.  The semaphore must have 

+ * previously been created with a call to vSemaphoreCreateBinary() or 

+ * xSemaphoreCreateCounting().

+ *

+ * Mutex type semaphores (those created using a call to xSemaphoreCreateMutex())

+ * must not be used with this macro.

+ *

+ * This macro can be used from an ISR, however taking a semaphore from an ISR

+ * is not a common operation.  It is likely to only be useful when taking a

+ * counting semaphore when an interrupt is obtaining an object from a resource

+ * pool (when the semaphore count indicates the number of resources available).

+ *

+ * @param xSemaphore A handle to the semaphore being taken.  This is the

+ * handle returned when the semaphore was created.

+ *

+ * @param pxHigherPriorityTaskWoken xSemaphoreTakeFromISR() will set

+ * *pxHigherPriorityTaskWoken to pdTRUE if taking the semaphore caused a task

+ * to unblock, and the unblocked task has a priority higher than the currently

+ * running task.  If xSemaphoreTakeFromISR() sets this value to pdTRUE then

+ * a context switch should be requested before the interrupt is exited.

+ *

+ * @return pdTRUE if the semaphore was successfully taken, otherwise 

+ * pdFALSE

+ */

+#define xSemaphoreTakeFromISR( xSemaphore, pxHigherPriorityTaskWoken )			xQueueReceiveFromISR( ( xQueueHandle ) ( xSemaphore ), NULL, ( pxHigherPriorityTaskWoken ) )

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreHandle xSemaphoreCreateMutex( void )</pre>

+ *

+ * <i>Macro</i> that implements a mutex semaphore by using the existing queue 

+ * mechanism.

+ *

+ * Mutexes created using this macro can be accessed using the xSemaphoreTake()

+ * and xSemaphoreGive() macros.  The xSemaphoreTakeRecursive() and 

+ * xSemaphoreGiveRecursive() macros should not be used.

+ * 

+ * This type of semaphore uses a priority inheritance mechanism so a task 

+ * 'taking' a semaphore MUST ALWAYS 'give' the semaphore back once the 

+ * semaphore it is no longer required.  

+ *

+ * Mutex type semaphores cannot be used from within interrupt service routines.  

+ *

+ * See vSemaphoreCreateBinary() for an alternative implementation that can be 

+ * used for pure synchronisation (where one task or interrupt always 'gives' the 

+ * semaphore and another always 'takes' the semaphore) and from within interrupt 

+ * service routines.

+ *

+ * @return xSemaphore Handle to the created mutex semaphore.  Should be of type 

+ *		xSemaphoreHandle.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore;

+

+ void vATask( void * pvParameters )

+ {

+    // Semaphore cannot be used before a call to xSemaphoreCreateMutex().

+    // This is a macro so pass the variable in directly.

+    xSemaphore = xSemaphoreCreateMutex();

+

+    if( xSemaphore != NULL )

+    {

+        // The semaphore was created successfully.

+        // The semaphore can now be used.  

+    }

+ }

+ </pre>

+ * \defgroup vSemaphoreCreateMutex vSemaphoreCreateMutex

+ * \ingroup Semaphores

+ */

+#define xSemaphoreCreateMutex() xQueueCreateMutex( queueQUEUE_TYPE_MUTEX )

+

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreHandle xSemaphoreCreateRecursiveMutex( void )</pre>

+ *

+ * <i>Macro</i> that implements a recursive mutex by using the existing queue 

+ * mechanism.

+ *

+ * Mutexes created using this macro can be accessed using the 

+ * xSemaphoreTakeRecursive() and xSemaphoreGiveRecursive() macros.  The 

+ * xSemaphoreTake() and xSemaphoreGive() macros should not be used.

+ *

+ * A mutex used recursively can be 'taken' repeatedly by the owner. The mutex 

+ * doesn't become available again until the owner has called 

+ * xSemaphoreGiveRecursive() for each successful 'take' request.  For example, 

+ * if a task successfully 'takes' the same mutex 5 times then the mutex will 

+ * not be available to any other task until it has also  'given' the mutex back

+ * exactly five times.

+ * 

+ * This type of semaphore uses a priority inheritance mechanism so a task 

+ * 'taking' a semaphore MUST ALWAYS 'give' the semaphore back once the 

+ * semaphore it is no longer required.  

+ *

+ * Mutex type semaphores cannot be used from within interrupt service routines.  

+ *

+ * See vSemaphoreCreateBinary() for an alternative implementation that can be 

+ * used for pure synchronisation (where one task or interrupt always 'gives' the 

+ * semaphore and another always 'takes' the semaphore) and from within interrupt 

+ * service routines.

+ *

+ * @return xSemaphore Handle to the created mutex semaphore.  Should be of type 

+ *		xSemaphoreHandle.

+ *

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore;

+

+ void vATask( void * pvParameters )

+ {

+    // Semaphore cannot be used before a call to xSemaphoreCreateMutex().

+    // This is a macro so pass the variable in directly.

+    xSemaphore = xSemaphoreCreateRecursiveMutex();

+

+    if( xSemaphore != NULL )

+    {

+        // The semaphore was created successfully.

+        // The semaphore can now be used.  

+    }

+ }

+ </pre>

+ * \defgroup vSemaphoreCreateMutex vSemaphoreCreateMutex

+ * \ingroup Semaphores

+ */

+#define xSemaphoreCreateRecursiveMutex() xQueueCreateMutex( queueQUEUE_TYPE_RECURSIVE_MUTEX )

+

+/**

+ * semphr. h

+ * <pre>xSemaphoreHandle xSemaphoreCreateCounting( unsigned portBASE_TYPE uxMaxCount, unsigned portBASE_TYPE uxInitialCount )</pre>

+ *

+ * <i>Macro</i> that creates a counting semaphore by using the existing 

+ * queue mechanism.  

+ *

+ * Counting semaphores are typically used for two things:

+ *

+ * 1) Counting events.  

+ *

+ *    In this usage scenario an event handler will 'give' a semaphore each time

+ *    an event occurs (incrementing the semaphore count value), and a handler 

+ *    task will 'take' a semaphore each time it processes an event 

+ *    (decrementing the semaphore count value).  The count value is therefore 

+ *    the difference between the number of events that have occurred and the 

+ *    number that have been processed.  In this case it is desirable for the 

+ *    initial count value to be zero.

+ *

+ * 2) Resource management.

+ *

+ *    In this usage scenario the count value indicates the number of resources

+ *    available.  To obtain control of a resource a task must first obtain a 

+ *    semaphore - decrementing the semaphore count value.  When the count value

+ *    reaches zero there are no free resources.  When a task finishes with the

+ *    resource it 'gives' the semaphore back - incrementing the semaphore count

+ *    value.  In this case it is desirable for the initial count value to be

+ *    equal to the maximum count value, indicating that all resources are free.

+ *

+ * @param uxMaxCount The maximum count value that can be reached.  When the 

+ *        semaphore reaches this value it can no longer be 'given'.

+ *

+ * @param uxInitialCount The count value assigned to the semaphore when it is

+ *        created.

+ *

+ * @return Handle to the created semaphore.  Null if the semaphore could not be

+ *         created.

+ * 

+ * Example usage:

+ <pre>

+ xSemaphoreHandle xSemaphore;

+

+ void vATask( void * pvParameters )

+ {

+ xSemaphoreHandle xSemaphore = NULL;

+

+    // Semaphore cannot be used before a call to xSemaphoreCreateCounting().

+    // The max value to which the semaphore can count should be 10, and the

+    // initial value assigned to the count should be 0.

+    xSemaphore = xSemaphoreCreateCounting( 10, 0 );

+

+    if( xSemaphore != NULL )

+    {

+        // The semaphore was created successfully.

+        // The semaphore can now be used.  

+    }

+ }

+ </pre>

+ * \defgroup xSemaphoreCreateCounting xSemaphoreCreateCounting

+ * \ingroup Semaphores

+ */

+#define xSemaphoreCreateCounting( uxMaxCount, uxInitialCount ) xQueueCreateCountingSemaphore( ( uxMaxCount ), ( uxInitialCount ) )

+

+/**

+ * semphr. h

+ * <pre>void vSemaphoreDelete( xSemaphoreHandle xSemaphore );</pre>

+ *

+ * Delete a semaphore.  This function must be used with care.  For example,

+ * do not delete a mutex type semaphore if the mutex is held by a task.

+ *

+ * @param xSemaphore A handle to the semaphore to be deleted.

+ *

+ * \page vSemaphoreDelete vSemaphoreDelete

+ * \ingroup Semaphores

+ */

+#define vSemaphoreDelete( xSemaphore ) vQueueDelete( ( xQueueHandle ) ( xSemaphore ) )

+

+/**

+ * semphr.h

+ * <pre>xTaskHandle xSemaphoreGetMutexHolder( xSemaphoreHandle xMutex );</pre>

+ *

+ * If xMutex is indeed a mutex type semaphore, return the current mutex holder.

+ * If xMutex is not a mutex type semaphore, or the mutex is available (not held

+ * by a task), return NULL.

+ *

+ * Note: This Is is a good way of determining if the calling task is the mutex 

+ * holder, but not a good way of determining the identity of the mutex holder as

+ * the holder may change between the function exiting and the returned value

+ * being tested.

+ */

+#define xSemaphoreGetMutexHolder( xSemaphore ) xQueueGetMutexHolder( ( xSemaphore ) )

+

+#endif /* SEMAPHORE_H */

+

+

diff --git a/FreeRTOS/Source/include/static-allocator.h b/FreeRTOS/Source/include/static-allocator.h
new file mode 100644
index 0000000..2e6defc
--- /dev/null
+++ b/FreeRTOS/Source/include/static-allocator.h
@@ -0,0 +1,22 @@
+#ifndef __STATIC_ALLOCATOR_H_INCLUDED__
+#define __STATIC_ALLOCATOR_H_INCLUDED__
+
+#include <stdint.h>
+
+typedef struct static_pool_s {
+    void* backing_store;
+    void* flags;
+    int   item_size;
+    int   num_items;
+} static_pool_t;
+
+void poolInit( static_pool_t* inPool,
+               int inItemSize,
+               int inNumItems,
+               void* inBackingStore,
+               void* inFlags);
+void *poolAllocateBuffer( static_pool_t* inPool );
+void poolFreeBuffer( static_pool_t* inPool, void* inPointer);
+
+
+#endif // __STATIC_ALLOCATOR_H_INCLUDED__
diff --git a/FreeRTOS/Source/include/task.h b/FreeRTOS/Source/include/task.h
new file mode 100644
index 0000000..12965ee
--- /dev/null
+++ b/FreeRTOS/Source/include/task.h
@@ -0,0 +1,1322 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+

+	

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+	 *    not run, what could be wrong?                                      *

+	 *                                                                       *

+	 *    http://www.FreeRTOS.org/FAQHelp.html                               *

+	 *                                                                       *

+    ***************************************************************************

+

+	

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+	

+	http://www.FreeRTOS.org/plus - Selection of FreeRTOS ecosystem products,

+	including FreeRTOS+Trace - an indispensable productivity tool.

+

+	Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+	the code with commercial support, indemnification, and middleware, under 

+	the OpenRTOS brand:  http://www.OpenRTOS.com.  High Integrity Systems also

+	provide a safety engineered and independently SIL3 certified version under 

+	the	SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef TASK_H

+#define TASK_H

+

+#ifndef INC_FREERTOS_H

+	#error "include FreeRTOS.h must appear in source files before include task.h"

+#endif

+

+#include "portable.h"

+#include "list.h"

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/*-----------------------------------------------------------

+ * MACROS AND DEFINITIONS

+ *----------------------------------------------------------*/

+

+#define tskKERNEL_VERSION_NUMBER "V7.2.0"

+

+/**

+ * task. h

+ *

+ * Type by which tasks are referenced.  For example, a call to xTaskCreate

+ * returns (via a pointer parameter) an xTaskHandle variable that can then

+ * be used as a parameter to vTaskDelete to delete the task.

+ *

+ * \page xTaskHandle xTaskHandle

+ * \ingroup Tasks

+ */

+typedef void * xTaskHandle;

+

+/*

+ * Used internally only.

+ */

+typedef struct xTIME_OUT

+{

+	portBASE_TYPE xOverflowCount;

+	portTickType  xTimeOnEntering;

+} xTimeOutType;

+

+/*

+ * Defines the memory ranges allocated to the task when an MPU is used.

+ */

+typedef struct xMEMORY_REGION

+{

+	void *pvBaseAddress;

+	unsigned long ulLengthInBytes;

+	unsigned long ulParameters;

+} xMemoryRegion;

+

+/*

+ * Parameters required to create an MPU protected task.

+ */

+typedef struct xTASK_PARAMTERS

+{

+	pdTASK_CODE pvTaskCode;

+	const signed char * const pcName;

+	unsigned short usStackDepth;

+	void *pvParameters;

+	unsigned portBASE_TYPE uxPriority;

+	portSTACK_TYPE *puxStackBuffer;

+	xMemoryRegion xRegions[ portNUM_CONFIGURABLE_REGIONS ];

+} xTaskParameters;

+

+/*

+ * Defines the priority used by the idle task.  This must not be modified.

+ *

+ * \ingroup TaskUtils

+ */

+#define tskIDLE_PRIORITY			( ( unsigned portBASE_TYPE ) 0U )

+

+/**

+ * task. h

+ *

+ * Macro for forcing a context switch.

+ *

+ * \page taskYIELD taskYIELD

+ * \ingroup SchedulerControl

+ */

+#define taskYIELD()					portYIELD()

+

+/**

+ * task. h

+ *

+ * Macro to mark the start of a critical code region.  Preemptive context

+ * switches cannot occur when in a critical region.

+ *

+ * NOTE: This may alter the stack (depending on the portable implementation)

+ * so must be used with care!

+ *

+ * \page taskENTER_CRITICAL taskENTER_CRITICAL

+ * \ingroup SchedulerControl

+ */

+#define taskENTER_CRITICAL()		portENTER_CRITICAL()

+

+/**

+ * task. h

+ *

+ * Macro to mark the end of a critical code region.  Preemptive context

+ * switches cannot occur when in a critical region.

+ *

+ * NOTE: This may alter the stack (depending on the portable implementation)

+ * so must be used with care!

+ *

+ * \page taskEXIT_CRITICAL taskEXIT_CRITICAL

+ * \ingroup SchedulerControl

+ */

+#define taskEXIT_CRITICAL()			portEXIT_CRITICAL()

+

+/**

+ * task. h

+ *

+ * Macro to disable all maskable interrupts.

+ *

+ * \page taskDISABLE_INTERRUPTS taskDISABLE_INTERRUPTS

+ * \ingroup SchedulerControl

+ */

+#define taskDISABLE_INTERRUPTS()	portDISABLE_INTERRUPTS()

+

+/**

+ * task. h

+ *

+ * Macro to enable microcontroller interrupts.

+ *

+ * \page taskENABLE_INTERRUPTS taskENABLE_INTERRUPTS

+ * \ingroup SchedulerControl

+ */

+#define taskENABLE_INTERRUPTS()		portENABLE_INTERRUPTS()

+

+/* Definitions returned by xTaskGetSchedulerState(). */

+#define taskSCHEDULER_NOT_STARTED	0

+#define taskSCHEDULER_RUNNING		1

+#define taskSCHEDULER_SUSPENDED		2

+

+/*-----------------------------------------------------------

+ * TASK CREATION API

+ *----------------------------------------------------------*/

+

+/**

+ * task. h

+ *<pre>

+ portBASE_TYPE xTaskCreate(

+							  pdTASK_CODE pvTaskCode,

+							  const char * const pcName,

+							  unsigned short usStackDepth,

+							  void *pvParameters,

+							  unsigned portBASE_TYPE uxPriority,

+							  xTaskHandle *pvCreatedTask

+						  );</pre>

+ *

+ * Create a new task and add it to the list of tasks that are ready to run.

+ *

+ * xTaskCreate() can only be used to create a task that has unrestricted

+ * access to the entire microcontroller memory map.  Systems that include MPU

+ * support can alternatively create an MPU constrained task using

+ * xTaskCreateRestricted().

+ *

+ * @param pvTaskCode Pointer to the task entry function.  Tasks

+ * must be implemented to never return (i.e. continuous loop).

+ *

+ * @param pcName A descriptive name for the task.  This is mainly used to

+ * facilitate debugging.  Max length defined by tskMAX_TASK_NAME_LEN - default

+ * is 16.

+ *

+ * @param usStackDepth The size of the task stack specified as the number of

+ * variables the stack can hold - not the number of bytes.  For example, if

+ * the stack is 16 bits wide and usStackDepth is defined as 100, 200 bytes

+ * will be allocated for stack storage.

+ *

+ * @param pvParameters Pointer that will be used as the parameter for the task

+ * being created.

+ *

+ * @param uxPriority The priority at which the task should run.  Systems that

+ * include MPU support can optionally create tasks in a privileged (system)

+ * mode by setting bit portPRIVILEGE_BIT of the priority parameter.  For

+ * example, to create a privileged task at priority 2 the uxPriority parameter

+ * should be set to ( 2 | portPRIVILEGE_BIT ).

+ *

+ * @param pvCreatedTask Used to pass back a handle by which the created task

+ * can be referenced.

+ *

+ * @return pdPASS if the task was successfully created and added to a ready

+ * list, otherwise an error code defined in the file errors. h

+ *

+ * Example usage:

+   <pre>

+ // Task to be created.

+ void vTaskCode( void * pvParameters )

+ {

+	 for( ;; )

+	 {

+		 // Task code goes here.

+	 }

+ }

+

+ // Function that creates a task.

+ void vOtherFunction( void )

+ {

+ static unsigned char ucParameterToPass;

+ xTaskHandle xHandle;

+

+	 // Create the task, storing the handle.  Note that the passed parameter ucParameterToPass

+	 // must exist for the lifetime of the task, so in this case is declared static.  If it was just an

+	 // an automatic stack variable it might no longer exist, or at least have been corrupted, by the time

+	 // the new task attempts to access it.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, &ucParameterToPass, tskIDLE_PRIORITY, &xHandle );

+

+	 // Use the handle to delete the task.

+	 vTaskDelete( xHandle );

+ }

+   </pre>

+ * \defgroup xTaskCreate xTaskCreate

+ * \ingroup Tasks

+ */

+#define xTaskCreate( pvTaskCode, pcName, usStackDepth, pvParameters, uxPriority, pxCreatedTask ) xTaskGenericCreate( ( pvTaskCode ), ( pcName ), ( usStackDepth ), ( pvParameters ), ( uxPriority ), ( pxCreatedTask ), ( NULL ), ( NULL ) )

+

+/**

+ * task. h

+ *<pre>

+ portBASE_TYPE xTaskCreateRestricted( xTaskParameters *pxTaskDefinition, xTaskHandle *pxCreatedTask );</pre>

+ *

+ * xTaskCreateRestricted() should only be used in systems that include an MPU

+ * implementation.

+ *

+ * Create a new task and add it to the list of tasks that are ready to run.

+ * The function parameters define the memory regions and associated access

+ * permissions allocated to the task.

+ *

+ * @param pxTaskDefinition Pointer to a structure that contains a member

+ * for each of the normal xTaskCreate() parameters (see the xTaskCreate() API

+ * documentation) plus an optional stack buffer and the memory region

+ * definitions.

+ *

+ * @param pxCreatedTask Used to pass back a handle by which the created task

+ * can be referenced.

+ *

+ * @return pdPASS if the task was successfully created and added to a ready

+ * list, otherwise an error code defined in the file errors. h

+ *

+ * Example usage:

+   <pre>

+// Create an xTaskParameters structure that defines the task to be created.

+static const xTaskParameters xCheckTaskParameters =

+{

+	vATask,		// pvTaskCode - the function that implements the task.

+	"ATask",	// pcName - just a text name for the task to assist debugging.

+	100,		// usStackDepth	- the stack size DEFINED IN WORDS.

+	NULL,		// pvParameters - passed into the task function as the function parameters.

+	( 1UL | portPRIVILEGE_BIT ),// uxPriority - task priority, set the portPRIVILEGE_BIT if the task should run in a privileged state.

+	cStackBuffer,// puxStackBuffer - the buffer to be used as the task stack.

+

+	// xRegions - Allocate up to three separate memory regions for access by

+	// the task, with appropriate access permissions.  Different processors have

+	// different memory alignment requirements - refer to the FreeRTOS documentation

+	// for full information.

+	{											

+		// Base address					Length	Parameters

+        { cReadWriteArray,				32,		portMPU_REGION_READ_WRITE },

+        { cReadOnlyArray,				32,		portMPU_REGION_READ_ONLY },

+        { cPrivilegedOnlyAccessArray,	128,	portMPU_REGION_PRIVILEGED_READ_WRITE }

+	}

+};

+

+int main( void )

+{

+xTaskHandle xHandle;

+

+	// Create a task from the const structure defined above.  The task handle

+	// is requested (the second parameter is not NULL) but in this case just for

+	// demonstration purposes as its not actually used.

+	xTaskCreateRestricted( &xRegTest1Parameters, &xHandle );

+

+	// Start the scheduler.

+	vTaskStartScheduler();

+

+	// Will only get here if there was insufficient memory to create the idle

+	// task.

+	for( ;; );

+}

+   </pre>

+ * \defgroup xTaskCreateRestricted xTaskCreateRestricted

+ * \ingroup Tasks

+ */

+#define xTaskCreateRestricted( x, pxCreatedTask ) xTaskGenericCreate( ((x)->pvTaskCode), ((x)->pcName), ((x)->usStackDepth), ((x)->pvParameters), ((x)->uxPriority), (pxCreatedTask), ((x)->puxStackBuffer), ((x)->xRegions) )

+

+/**

+ * task. h

+ *<pre>

+ void vTaskAllocateMPURegions( xTaskHandle xTask, const xMemoryRegion * const pxRegions );</pre>

+ *

+ * Memory regions are assigned to a restricted task when the task is created by

+ * a call to xTaskCreateRestricted().  These regions can be redefined using

+ * vTaskAllocateMPURegions().

+ *

+ * @param xTask The handle of the task being updated.

+ *

+ * @param xRegions A pointer to an xMemoryRegion structure that contains the

+ * new memory region definitions.

+ *

+ * Example usage:

+   <pre>

+// Define an array of xMemoryRegion structures that configures an MPU region

+// allowing read/write access for 1024 bytes starting at the beginning of the

+// ucOneKByte array.  The other two of the maximum 3 definable regions are

+// unused so set to zero.

+static const xMemoryRegion xAltRegions[ portNUM_CONFIGURABLE_REGIONS ] =

+{											

+	// Base address		Length		Parameters

+	{ ucOneKByte,		1024,		portMPU_REGION_READ_WRITE },

+	{ 0,				0,			0 },

+	{ 0,				0,			0 }

+};

+

+void vATask( void *pvParameters )

+{

+	// This task was created such that it has access to certain regions of

+	// memory as defined by the MPU configuration.  At some point it is

+	// desired that these MPU regions are replaced with that defined in the

+	// xAltRegions const struct above.  Use a call to vTaskAllocateMPURegions()

+	// for this purpose.  NULL is used as the task handle to indicate that this

+	// function should modify the MPU regions of the calling task.

+	vTaskAllocateMPURegions( NULL, xAltRegions );

+	

+	// Now the task can continue its function, but from this point on can only

+	// access its stack and the ucOneKByte array (unless any other statically

+	// defined or shared regions have been declared elsewhere).

+}

+   </pre>

+ * \defgroup xTaskCreateRestricted xTaskCreateRestricted

+ * \ingroup Tasks

+ */

+void vTaskAllocateMPURegions( xTaskHandle xTask, const xMemoryRegion * const pxRegions ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskDelete( xTaskHandle pxTask );</pre>

+ *

+ * INCLUDE_vTaskDelete must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Remove a task from the RTOS real time kernels management.  The task being

+ * deleted will be removed from all ready, blocked, suspended and event lists.

+ *

+ * NOTE:  The idle task is responsible for freeing the kernel allocated

+ * memory from tasks that have been deleted.  It is therefore important that

+ * the idle task is not starved of microcontroller processing time if your

+ * application makes any calls to vTaskDelete ().  Memory allocated by the

+ * task code is not automatically freed, and should be freed before the task

+ * is deleted.

+ *

+ * See the demo application file death.c for sample code that utilises

+ * vTaskDelete ().

+ *

+ * @param pxTask The handle of the task to be deleted.  Passing NULL will

+ * cause the calling task to be deleted.

+ *

+ * Example usage:

+   <pre>

+ void vOtherFunction( void )

+ {

+ xTaskHandle xHandle;

+

+	 // Create the task, storing the handle.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, &xHandle );

+

+	 // Use the handle to delete the task.

+	 vTaskDelete( xHandle );

+ }

+   </pre>

+ * \defgroup vTaskDelete vTaskDelete

+ * \ingroup Tasks

+ */

+void vTaskDelete( xTaskHandle pxTaskToDelete ) PRIVILEGED_FUNCTION;

+

+/*-----------------------------------------------------------

+ * TASK CONTROL API

+ *----------------------------------------------------------*/

+

+/**

+ * task. h

+ * <pre>void vTaskDelay( portTickType xTicksToDelay );</pre>

+ *

+ * Delay a task for a given number of ticks.  The actual time that the

+ * task remains blocked depends on the tick rate.  The constant

+ * portTICK_RATE_MS can be used to calculate real time from the tick

+ * rate - with the resolution of one tick period.

+ *

+ * INCLUDE_vTaskDelay must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ *

+ * vTaskDelay() specifies a time at which the task wishes to unblock relative to

+ * the time at which vTaskDelay() is called.  For example, specifying a block

+ * period of 100 ticks will cause the task to unblock 100 ticks after

+ * vTaskDelay() is called.  vTaskDelay() does not therefore provide a good method

+ * of controlling the frequency of a cyclical task as the path taken through the

+ * code, as well as other task and interrupt activity, will effect the frequency

+ * at which vTaskDelay() gets called and therefore the time at which the task

+ * next executes.  See vTaskDelayUntil() for an alternative API function designed

+ * to facilitate fixed frequency execution.  It does this by specifying an

+ * absolute time (rather than a relative time) at which the calling task should

+ * unblock.

+ *

+ * @param xTicksToDelay The amount of time, in tick periods, that

+ * the calling task should block.

+ *

+ * Example usage:

+

+ void vTaskFunction( void * pvParameters )

+ {

+ void vTaskFunction( void * pvParameters )

+ {

+ // Block for 500ms.

+ const portTickType xDelay = 500 / portTICK_RATE_MS;

+

+	 for( ;; )

+	 {

+		 // Simply toggle the LED every 500ms, blocking between each toggle.

+		 vToggleLED();

+		 vTaskDelay( xDelay );

+	 }

+ }

+

+ * \defgroup vTaskDelay vTaskDelay

+ * \ingroup TaskCtrl

+ */

+void vTaskDelay( portTickType xTicksToDelay ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskDelayUntil( portTickType *pxPreviousWakeTime, portTickType xTimeIncrement );</pre>

+ *

+ * INCLUDE_vTaskDelayUntil must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Delay a task until a specified time.  This function can be used by cyclical

+ * tasks to ensure a constant execution frequency.

+ *

+ * This function differs from vTaskDelay () in one important aspect:  vTaskDelay () will

+ * cause a task to block for the specified number of ticks from the time vTaskDelay () is

+ * called.  It is therefore difficult to use vTaskDelay () by itself to generate a fixed

+ * execution frequency as the time between a task starting to execute and that task

+ * calling vTaskDelay () may not be fixed [the task may take a different path though the

+ * code between calls, or may get interrupted or preempted a different number of times

+ * each time it executes].

+ *

+ * Whereas vTaskDelay () specifies a wake time relative to the time at which the function

+ * is called, vTaskDelayUntil () specifies the absolute (exact) time at which it wishes to

+ * unblock.

+ *

+ * The constant portTICK_RATE_MS can be used to calculate real time from the tick

+ * rate - with the resolution of one tick period.

+ *

+ * @param pxPreviousWakeTime Pointer to a variable that holds the time at which the

+ * task was last unblocked.  The variable must be initialised with the current time

+ * prior to its first use (see the example below).  Following this the variable is

+ * automatically updated within vTaskDelayUntil ().

+ *

+ * @param xTimeIncrement The cycle time period.  The task will be unblocked at

+ * time *pxPreviousWakeTime + xTimeIncrement.  Calling vTaskDelayUntil with the

+ * same xTimeIncrement parameter value will cause the task to execute with

+ * a fixed interface period.

+ *

+ * Example usage:

+   <pre>

+ // Perform an action every 10 ticks.

+ void vTaskFunction( void * pvParameters )

+ {

+ portTickType xLastWakeTime;

+ const portTickType xFrequency = 10;

+

+	 // Initialise the xLastWakeTime variable with the current time.

+	 xLastWakeTime = xTaskGetTickCount ();

+	 for( ;; )

+	 {

+		 // Wait for the next cycle.

+		 vTaskDelayUntil( &xLastWakeTime, xFrequency );

+

+		 // Perform action here.

+	 }

+ }

+   </pre>

+ * \defgroup vTaskDelayUntil vTaskDelayUntil

+ * \ingroup TaskCtrl

+ */

+void vTaskDelayUntil( portTickType * const pxPreviousWakeTime, portTickType xTimeIncrement ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>unsigned portBASE_TYPE uxTaskPriorityGet( xTaskHandle pxTask );</pre>

+ *

+ * INCLUDE_xTaskPriorityGet must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Obtain the priority of any task.

+ *

+ * @param pxTask Handle of the task to be queried.  Passing a NULL

+ * handle results in the priority of the calling task being returned.

+ *

+ * @return The priority of pxTask.

+ *

+ * Example usage:

+   <pre>

+ void vAFunction( void )

+ {

+ xTaskHandle xHandle;

+

+	 // Create a task, storing the handle.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, &xHandle );

+

+	 // ...

+

+	 // Use the handle to obtain the priority of the created task.

+	 // It was created with tskIDLE_PRIORITY, but may have changed

+	 // it itself.

+	 if( uxTaskPriorityGet( xHandle ) != tskIDLE_PRIORITY )

+	 {

+		 // The task has changed it's priority.

+	 }

+

+	 // ...

+

+	 // Is our priority higher than the created task?

+	 if( uxTaskPriorityGet( xHandle ) < uxTaskPriorityGet( NULL ) )

+	 {

+		 // Our priority (obtained using NULL handle) is higher.

+	 }

+ }

+   </pre>

+ * \defgroup uxTaskPriorityGet uxTaskPriorityGet

+ * \ingroup TaskCtrl

+ */

+unsigned portBASE_TYPE uxTaskPriorityGet( xTaskHandle pxTask ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskPrioritySet( xTaskHandle pxTask, unsigned portBASE_TYPE uxNewPriority );</pre>

+ *

+ * INCLUDE_vTaskPrioritySet must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Set the priority of any task.

+ *

+ * A context switch will occur before the function returns if the priority

+ * being set is higher than the currently executing task.

+ *

+ * @param pxTask Handle to the task for which the priority is being set.

+ * Passing a NULL handle results in the priority of the calling task being set.

+ *

+ * @param uxNewPriority The priority to which the task will be set.

+ *

+ * Example usage:

+   <pre>

+ void vAFunction( void )

+ {

+ xTaskHandle xHandle;

+

+	 // Create a task, storing the handle.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, &xHandle );

+

+	 // ...

+

+	 // Use the handle to raise the priority of the created task.

+	 vTaskPrioritySet( xHandle, tskIDLE_PRIORITY + 1 );

+

+	 // ...

+

+	 // Use a NULL handle to raise our priority to the same value.

+	 vTaskPrioritySet( NULL, tskIDLE_PRIORITY + 1 );

+ }

+   </pre>

+ * \defgroup vTaskPrioritySet vTaskPrioritySet

+ * \ingroup TaskCtrl

+ */

+void vTaskPrioritySet( xTaskHandle pxTask, unsigned portBASE_TYPE uxNewPriority ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskSuspend( xTaskHandle pxTaskToSuspend );</pre>

+ *

+ * INCLUDE_vTaskSuspend must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Suspend any task.  When suspended a task will never get any microcontroller

+ * processing time, no matter what its priority.

+ *

+ * Calls to vTaskSuspend are not accumulative -

+ * i.e. calling vTaskSuspend () twice on the same task still only requires one

+ * call to vTaskResume () to ready the suspended task.

+ *

+ * @param pxTaskToSuspend Handle to the task being suspended.  Passing a NULL

+ * handle will cause the calling task to be suspended.

+ *

+ * Example usage:

+   <pre>

+ void vAFunction( void )

+ {

+ xTaskHandle xHandle;

+

+	 // Create a task, storing the handle.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, &xHandle );

+

+	 // ...

+

+	 // Use the handle to suspend the created task.

+	 vTaskSuspend( xHandle );

+

+	 // ...

+

+	 // The created task will not run during this period, unless

+	 // another task calls vTaskResume( xHandle ).

+

+	 //...

+

+

+	 // Suspend ourselves.

+	 vTaskSuspend( NULL );

+

+	 // We cannot get here unless another task calls vTaskResume

+	 // with our handle as the parameter.

+ }

+   </pre>

+ * \defgroup vTaskSuspend vTaskSuspend

+ * \ingroup TaskCtrl

+ */

+void vTaskSuspend( xTaskHandle pxTaskToSuspend ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskResume( xTaskHandle pxTaskToResume );</pre>

+ *

+ * INCLUDE_vTaskSuspend must be defined as 1 for this function to be available.

+ * See the configuration section for more information.

+ *

+ * Resumes a suspended task.

+ *

+ * A task that has been suspended by one of more calls to vTaskSuspend ()

+ * will be made available for running again by a single call to

+ * vTaskResume ().

+ *

+ * @param pxTaskToResume Handle to the task being readied.

+ *

+ * Example usage:

+   <pre>

+ void vAFunction( void )

+ {

+ xTaskHandle xHandle;

+

+	 // Create a task, storing the handle.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, &xHandle );

+

+	 // ...

+

+	 // Use the handle to suspend the created task.

+	 vTaskSuspend( xHandle );

+

+	 // ...

+

+	 // The created task will not run during this period, unless

+	 // another task calls vTaskResume( xHandle ).

+

+	 //...

+

+

+	 // Resume the suspended task ourselves.

+	 vTaskResume( xHandle );

+

+	 // The created task will once again get microcontroller processing

+	 // time in accordance with it priority within the system.

+ }

+   </pre>

+ * \defgroup vTaskResume vTaskResume

+ * \ingroup TaskCtrl

+ */

+void vTaskResume( xTaskHandle pxTaskToResume ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void xTaskResumeFromISR( xTaskHandle pxTaskToResume );</pre>

+ *

+ * INCLUDE_xTaskResumeFromISR must be defined as 1 for this function to be

+ * available.  See the configuration section for more information.

+ *

+ * An implementation of vTaskResume() that can be called from within an ISR.

+ *

+ * A task that has been suspended by one of more calls to vTaskSuspend ()

+ * will be made available for running again by a single call to

+ * xTaskResumeFromISR ().

+ *

+ * @param pxTaskToResume Handle to the task being readied.

+ *

+ * \defgroup vTaskResumeFromISR vTaskResumeFromISR

+ * \ingroup TaskCtrl

+ */

+portBASE_TYPE xTaskResumeFromISR( xTaskHandle pxTaskToResume ) PRIVILEGED_FUNCTION;

+

+/*-----------------------------------------------------------

+ * SCHEDULER CONTROL

+ *----------------------------------------------------------*/

+

+/**

+ * task. h

+ * <pre>void vTaskStartScheduler( void );</pre>

+ *

+ * Starts the real time kernel tick processing.  After calling the kernel

+ * has control over which tasks are executed and when.  This function

+ * does not return until an executing task calls vTaskEndScheduler ().

+ *

+ * At least one task should be created via a call to xTaskCreate ()

+ * before calling vTaskStartScheduler ().  The idle task is created

+ * automatically when the first application task is created.

+ *

+ * See the demo application file main.c for an example of creating

+ * tasks and starting the kernel.

+ *

+ * Example usage:

+   <pre>

+ void vAFunction( void )

+ {

+	 // Create at least one task before starting the kernel.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL );

+

+	 // Start the real time kernel with preemption.

+	 vTaskStartScheduler ();

+

+	 // Will not get here unless a task calls vTaskEndScheduler ()

+ }

+   </pre>

+ *

+ * \defgroup vTaskStartScheduler vTaskStartScheduler

+ * \ingroup SchedulerControl

+ */

+void vTaskStartScheduler( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskEndScheduler( void );</pre>

+ *

+ * Stops the real time kernel tick.  All created tasks will be automatically

+ * deleted and multitasking (either preemptive or cooperative) will

+ * stop.  Execution then resumes from the point where vTaskStartScheduler ()

+ * was called, as if vTaskStartScheduler () had just returned.

+ *

+ * See the demo application file main. c in the demo/PC directory for an

+ * example that uses vTaskEndScheduler ().

+ *

+ * vTaskEndScheduler () requires an exit function to be defined within the

+ * portable layer (see vPortEndScheduler () in port. c for the PC port).  This

+ * performs hardware specific operations such as stopping the kernel tick.

+ *

+ * vTaskEndScheduler () will cause all of the resources allocated by the

+ * kernel to be freed - but will not free resources allocated by application

+ * tasks.

+ *

+ * Example usage:

+   <pre>

+ void vTaskCode( void * pvParameters )

+ {

+	 for( ;; )

+	 {

+		 // Task code goes here.

+

+		 // At some point we want to end the real time kernel processing

+		 // so call ...

+		 vTaskEndScheduler ();

+	 }

+ }

+

+ void vAFunction( void )

+ {

+	 // Create at least one task before starting the kernel.

+	 xTaskCreate( vTaskCode, "NAME", STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL );

+

+	 // Start the real time kernel with preemption.

+	 vTaskStartScheduler ();

+

+	 // Will only get here when the vTaskCode () task has called

+	 // vTaskEndScheduler ().  When we get here we are back to single task

+	 // execution.

+ }

+   </pre>

+ *

+ * \defgroup vTaskEndScheduler vTaskEndScheduler

+ * \ingroup SchedulerControl

+ */

+void vTaskEndScheduler( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>void vTaskSuspendAll( void );</pre>

+ *

+ * Suspends all real time kernel activity while keeping interrupts (including the

+ * kernel tick) enabled.

+ *

+ * After calling vTaskSuspendAll () the calling task will continue to execute

+ * without risk of being swapped out until a call to xTaskResumeAll () has been

+ * made.

+ *

+ * API functions that have the potential to cause a context switch (for example,

+ * vTaskDelayUntil(), xQueueSend(), etc.) must not be called while the scheduler

+ * is suspended.

+ *

+ * Example usage:

+   <pre>

+ void vTask1( void * pvParameters )

+ {

+	 for( ;; )

+	 {

+		 // Task code goes here.

+

+		 // ...

+

+		 // At some point the task wants to perform a long operation during

+		 // which it does not want to get swapped out.  It cannot use

+		 // taskENTER_CRITICAL ()/taskEXIT_CRITICAL () as the length of the

+		 // operation may cause interrupts to be missed - including the

+		 // ticks.

+

+		 // Prevent the real time kernel swapping out the task.

+		 vTaskSuspendAll ();

+

+		 // Perform the operation here.  There is no need to use critical

+		 // sections as we have all the microcontroller processing time.

+		 // During this time interrupts will still operate and the kernel

+		 // tick count will be maintained.

+

+		 // ...

+

+		 // The operation is complete.  Restart the kernel.

+		 xTaskResumeAll ();

+	 }

+ }

+   </pre>

+ * \defgroup vTaskSuspendAll vTaskSuspendAll

+ * \ingroup SchedulerControl

+ */

+void vTaskSuspendAll( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>char xTaskResumeAll( void );</pre>

+ *

+ * Resumes real time kernel activity following a call to vTaskSuspendAll ().

+ * After a call to vTaskSuspendAll () the kernel will take control of which

+ * task is executing at any time.

+ *

+ * @return If resuming the scheduler caused a context switch then pdTRUE is

+ *		  returned, otherwise pdFALSE is returned.

+ *

+ * Example usage:

+   <pre>

+ void vTask1( void * pvParameters )

+ {

+	 for( ;; )

+	 {

+		 // Task code goes here.

+

+		 // ...

+

+		 // At some point the task wants to perform a long operation during

+		 // which it does not want to get swapped out.  It cannot use

+		 // taskENTER_CRITICAL ()/taskEXIT_CRITICAL () as the length of the

+		 // operation may cause interrupts to be missed - including the

+		 // ticks.

+

+		 // Prevent the real time kernel swapping out the task.

+		 vTaskSuspendAll ();

+

+		 // Perform the operation here.  There is no need to use critical

+		 // sections as we have all the microcontroller processing time.

+		 // During this time interrupts will still operate and the real

+		 // time kernel tick count will be maintained.

+

+		 // ...

+

+		 // The operation is complete.  Restart the kernel.  We want to force

+		 // a context switch - but there is no point if resuming the scheduler

+		 // caused a context switch already.

+		 if( !xTaskResumeAll () )

+		 {

+			  taskYIELD ();

+		 }

+	 }

+ }

+   </pre>

+ * \defgroup xTaskResumeAll xTaskResumeAll

+ * \ingroup SchedulerControl

+ */

+signed portBASE_TYPE xTaskResumeAll( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>signed portBASE_TYPE xTaskIsTaskSuspended( xTaskHandle xTask );</pre>

+ *

+ * Utility task that simply returns pdTRUE if the task referenced by xTask is

+ * currently in the Suspended state, or pdFALSE if the task referenced by xTask

+ * is in any other state.

+ *

+ */

+signed portBASE_TYPE xTaskIsTaskSuspended( xTaskHandle xTask ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <pre>signed portBASE_TYPE xTaskIsTaskFinished( xTaskHandle xTask );</pre>

+ *

+ * Utility task that simply returns pdTRUE if the task has terminated.

+ *

+ */

+signed portBASE_TYPE xTaskIsTaskFinished( xTaskHandle xTask ) PRIVILEGED_FUNCTION;

+

+/*-----------------------------------------------------------

+ * TASK UTILITIES

+ *----------------------------------------------------------*/

+

+/**

+ * task. h

+ * <PRE>portTickType xTaskGetTickCount( void );</PRE>

+ *

+ * @return The count of ticks since vTaskStartScheduler was called.

+ *

+ * \page xTaskGetTickCount xTaskGetTickCount

+ * \ingroup TaskUtils

+ */

+portTickType xTaskGetTickCount( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <PRE>portTickType xTaskGetTickCountFromISR( void );</PRE>

+ *

+ * @return The count of ticks since vTaskStartScheduler was called.

+ *

+ * This is a version of xTaskGetTickCount() that is safe to be called from an

+ * ISR - provided that portTickType is the natural word size of the

+ * microcontroller being used or interrupt nesting is either not supported or

+ * not being used.

+ *

+ * \page xTaskGetTickCount xTaskGetTickCount

+ * \ingroup TaskUtils

+ */

+portTickType xTaskGetTickCountFromISR( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <PRE>unsigned short uxTaskGetNumberOfTasks( void );</PRE>

+ *

+ * @return The number of tasks that the real time kernel is currently managing.

+ * This includes all ready, blocked and suspended tasks.  A task that

+ * has been deleted but not yet freed by the idle task will also be

+ * included in the count.

+ *

+ * \page uxTaskGetNumberOfTasks uxTaskGetNumberOfTasks

+ * \ingroup TaskUtils

+ */

+unsigned portBASE_TYPE uxTaskGetNumberOfTasks( void ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <PRE>signed char *pcTaskGetTaskName( xTaskHandle xTaskToQuery );</PRE>

+ *

+ * @return The text (human readable) name of the task referenced by the handle

+ * xTaskToQueury.  A task can query its own name by either passing in its own

+ * handle, or by setting xTaskToQuery to NULL.  INCLUDE_pcTaskGetTaskName must be

+ * set to 1 in FreeRTOSConfig.h for pcTaskGetTaskName() to be available.

+ *

+ * \page pcTaskGetTaskName pcTaskGetTaskName

+ * \ingroup TaskUtils

+ */

+signed char *pcTaskGetTaskName( xTaskHandle xTaskToQuery );

+

+/**

+ * task. h

+ * <PRE>void vTaskList( char *pcWriteBuffer );</PRE>

+ *

+ * configUSE_TRACE_FACILITY must be defined as 1 for this function to be

+ * available.  See the configuration section for more information.

+ *

+ * NOTE: This function will disable interrupts for its duration.  It is

+ * not intended for normal application runtime use but as a debug aid.

+ *

+ * Lists all the current tasks, along with their current state and stack

+ * usage high water mark.

+ *

+ * Tasks are reported as blocked ('B'), ready ('R'), deleted ('D') or

+ * suspended ('S').

+ *

+ * @param pcWriteBuffer A buffer into which the above mentioned details

+ * will be written, in ascii form.  This buffer is assumed to be large

+ * enough to contain the generated report.  Approximately 40 bytes per

+ * task should be sufficient.

+ *

+ * \page vTaskList vTaskList

+ * \ingroup TaskUtils

+ */

+void vTaskList( signed char *pcWriteBuffer ) PRIVILEGED_FUNCTION;

+void vTaskList1(void (*pmCallback)(volatile void *pxPCB, signed char cStatus) ) PRIVILEGED_FUNCTION;

+

+/**

+ * task. h

+ * <PRE>void vTaskGetRunTimeStats( char *pcWriteBuffer );</PRE>

+ *

+ * configGENERATE_RUN_TIME_STATS must be defined as 1 for this function

+ * to be available.  The application must also then provide definitions

+ * for portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() and

+ * portGET_RUN_TIME_COUNTER_VALUE to configure a peripheral timer/counter

+ * and return the timers current count value respectively.  The counter

+ * should be at least 10 times the frequency of the tick count.

+ *

+ * NOTE: This function will disable interrupts for its duration.  It is

+ * not intended for normal application runtime use but as a debug aid.

+ *

+ * Setting configGENERATE_RUN_TIME_STATS to 1 will result in a total

+ * accumulated execution time being stored for each task.  The resolution

+ * of the accumulated time value depends on the frequency of the timer

+ * configured by the portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() macro.

+ * Calling vTaskGetRunTimeStats() writes the total execution time of each

+ * task into a buffer, both as an absolute count value and as a percentage

+ * of the total system execution time.

+ *

+ * @param pcWriteBuffer A buffer into which the execution times will be

+ * written, in ascii form.  This buffer is assumed to be large enough to

+ * contain the generated report.  Approximately 40 bytes per task should

+ * be sufficient.

+ *

+ * \page vTaskGetRunTimeStats vTaskGetRunTimeStats

+ * \ingroup TaskUtils

+ */

+void vTaskGetRunTimeStats( signed char *pcWriteBuffer ) PRIVILEGED_FUNCTION;

+

+/**

+ * task.h

+ * <PRE>unsigned portBASE_TYPE uxTaskGetStackHighWaterMark( xTaskHandle xTask );</PRE>

+ *

+ * INCLUDE_uxTaskGetStackHighWaterMark must be set to 1 in FreeRTOSConfig.h for

+ * this function to be available.

+ *

+ * Returns the high water mark of the stack associated with xTask.  That is,

+ * the minimum free stack space there has been (in words, so on a 32 bit machine

+ * a value of 1 means 4 bytes) since the task started.  The smaller the returned

+ * number the closer the task has come to overflowing its stack.

+ *

+ * @param xTask Handle of the task associated with the stack to be checked.

+ * Set xTask to NULL to check the stack of the calling task.

+ *

+ * @return The smallest amount of free stack space there has been (in bytes)

+ * since the task referenced by xTask was created.

+ */

+unsigned portBASE_TYPE uxTaskGetStackHighWaterMark( xTaskHandle xTask ) PRIVILEGED_FUNCTION;

+

+/* When using trace macros it is sometimes necessary to include tasks.h before

+FreeRTOS.h.  When this is done pdTASK_HOOK_CODE will not yet have been defined,

+so the following two prototypes will cause a compilation error.  This can be

+fixed by simply guarding against the inclusion of these two prototypes unless

+they are explicitly required by the configUSE_APPLICATION_TASK_TAG configuration

+constant. */

+#ifdef configUSE_APPLICATION_TASK_TAG

+	#if configUSE_APPLICATION_TASK_TAG == 1

+		/**

+		 * task.h

+		 * <pre>void vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction );</pre>

+		 *

+		 * Sets pxHookFunction to be the task hook function used by the task xTask.

+		 * Passing xTask as NULL has the effect of setting the calling tasks hook

+		 * function.

+		 */

+		void vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction ) PRIVILEGED_FUNCTION;

+

+		/**

+		 * task.h

+		 * <pre>void xTaskGetApplicationTaskTag( xTaskHandle xTask );</pre>

+		 *

+		 * Returns the pxHookFunction value assigned to the task xTask.

+		 */

+		pdTASK_HOOK_CODE xTaskGetApplicationTaskTag( xTaskHandle xTask ) PRIVILEGED_FUNCTION;

+	#endif /* configUSE_APPLICATION_TASK_TAG ==1 */

+#endif /* ifdef configUSE_APPLICATION_TASK_TAG */

+

+/**

+ * task.h

+ * <pre>portBASE_TYPE xTaskCallApplicationTaskHook( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction );</pre>

+ *

+ * Calls the hook function associated with xTask.  Passing xTask as NULL has

+ * the effect of calling the Running tasks (the calling task) hook function.

+ *

+ * pvParameter is passed to the hook function for the task to interpret as it

+ * wants.

+ */

+portBASE_TYPE xTaskCallApplicationTaskHook( xTaskHandle xTask, void *pvParameter ) PRIVILEGED_FUNCTION;

+

+/**

+ * xTaskGetIdleTaskHandle() is only available if 

+ * INCLUDE_xTaskGetIdleTaskHandle is set to 1 in FreeRTOSConfig.h.

+ *

+ * Simply returns the handle of the idle task.  It is not valid to call

+ * xTaskGetIdleTaskHandle() before the scheduler has been started.

+ */

+xTaskHandle xTaskGetIdleTaskHandle( void );

+

+/*-----------------------------------------------------------

+ * SCHEDULER INTERNALS AVAILABLE FOR PORTING PURPOSES

+ *----------------------------------------------------------*/

+

+/*

+ * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS ONLY

+ * INTENDED FOR USE WHEN IMPLEMENTING A PORT OF THE SCHEDULER AND IS

+ * AN INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.

+ *

+ * Called from the real time kernel tick (either preemptive or cooperative),

+ * this increments the tick count and checks if any tasks that are blocked

+ * for a finite period required removing from a blocked list and placing on

+ * a ready list.

+ */

+void vTaskIncrementTick( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Ported from FreeRTOSV8.0.1 to support k24 VLPS mode

+ * If tickless mode is being used, or a low power mode is implemented, then

+ * the tick interrupt will not execute during idle periods.  When this is the

+ * case, the tick count value maintained by the scheduler needs to be kept up

+ * to date with the actual execution time by being skipped forward by a time

+ * equal to the idle period.

+ */

+void vTaskStepTick( const portTickType xTicksToJump );

+

+/*

+ * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN

+ * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.

+ *

+ * THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED.

+ *

+ * Removes the calling task from the ready list and places it both

+ * on the list of tasks waiting for a particular event, and the

+ * list of delayed tasks.  The task will be removed from both lists

+ * and replaced on the ready list should either the event occur (and

+ * there be no higher priority tasks waiting on the same event) or

+ * the delay period expires.

+ *

+ * @param pxEventList The list containing tasks that are blocked waiting

+ * for the event to occur.

+ *

+ * @param xTicksToWait The maximum amount of time that the task should wait

+ * for the event to occur.  This is specified in kernel ticks,the constant

+ * portTICK_RATE_MS can be used to convert kernel ticks into a real time

+ * period.

+ */

+void vTaskPlaceOnEventList( const xList * const pxEventList, portTickType xTicksToWait ) PRIVILEGED_FUNCTION;

+

+/*

+ * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN

+ * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.

+ *

+ * THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED.

+ *

+ * This function performs nearly the same function as vTaskPlaceOnEventList().

+ * The difference being that this function does not permit tasks to block

+ * indefinitely, whereas vTaskPlaceOnEventList() does.

+ *

+ * @return pdTRUE if the task being removed has a higher priority than the task

+ * making the call, otherwise pdFALSE.

+ */

+void vTaskPlaceOnEventListRestricted( const xList * const pxEventList, portTickType xTicksToWait ) PRIVILEGED_FUNCTION;

+

+/*

+ * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN

+ * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.

+ *

+ * THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED.

+ *

+ * Removes a task from both the specified event list and the list of blocked

+ * tasks, and places it on a ready queue.

+ *

+ * xTaskRemoveFromEventList () will be called if either an event occurs to

+ * unblock a task, or the block timeout period expires.

+ *

+ * @return pdTRUE if the task being removed has a higher priority than the task

+ * making the call, otherwise pdFALSE.

+ */

+signed portBASE_TYPE xTaskRemoveFromEventList( const xList * const pxEventList ) PRIVILEGED_FUNCTION;

+

+/*

+ * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS ONLY

+ * INTENDED FOR USE WHEN IMPLEMENTING A PORT OF THE SCHEDULER AND IS

+ * AN INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.

+ *

+ * Sets the pointer to the current TCB to the TCB of the highest priority task

+ * that is ready to run.

+ */

+void vTaskSwitchContext( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Return the handle of the calling task.

+ */

+xTaskHandle xTaskGetCurrentTaskHandle( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Capture the current time status for future reference.

+ */

+void vTaskSetTimeOutState( xTimeOutType * const pxTimeOut ) PRIVILEGED_FUNCTION;

+

+/*

+ * Compare the time status now with that previously captured to see if the

+ * timeout has expired.

+ */

+portBASE_TYPE xTaskCheckForTimeOut( xTimeOutType * const pxTimeOut, portTickType * const pxTicksToWait ) PRIVILEGED_FUNCTION;

+

+/*

+ * Shortcut used by the queue implementation to prevent unnecessary call to

+ * taskYIELD();

+ */

+void vTaskMissedYield( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Returns the scheduler state as taskSCHEDULER_RUNNING,

+ * taskSCHEDULER_NOT_STARTED or taskSCHEDULER_SUSPENDED.

+ */

+portBASE_TYPE xTaskGetSchedulerState( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Raises the priority of the mutex holder to that of the calling task should

+ * the mutex holder have a priority less than the calling task.

+ */

+void vTaskPriorityInherit( xTaskHandle * const pxMutexHolder ) PRIVILEGED_FUNCTION;

+

+/*

+ * Set the priority of a task back to its proper priority in the case that it

+ * inherited a higher priority while it was holding a semaphore.

+ */

+void vTaskPriorityDisinherit( xTaskHandle * const pxMutexHolder ) PRIVILEGED_FUNCTION;

+

+/*

+ * Generic version of the task creation function which is in turn called by the

+ * xTaskCreate() and xTaskCreateRestricted() macros.

+ */

+signed portBASE_TYPE xTaskGenericCreate( pdTASK_CODE pxTaskCode, const signed char * const pcName, unsigned short usStackDepth, void *pvParameters, unsigned portBASE_TYPE uxPriority, xTaskHandle *pxCreatedTask, portSTACK_TYPE *puxStackBuffer, const xMemoryRegion * const xRegions ) PRIVILEGED_FUNCTION;

+

+/*

+ * Get the uxTCBNumber assigned to the task referenced by the xTask parameter.

+ */

+unsigned portBASE_TYPE uxTaskGetTaskNumber( xTaskHandle xTask );

+

+/* 

+ * Set the uxTCBNumber of the task referenced by the xTask parameter to

+ * ucHandle.

+ */

+void vTaskSetTaskNumber( xTaskHandle xTask, unsigned portBASE_TYPE uxHandle );

+

+

+#ifdef __cplusplus

+}

+#endif

+#endif /* TASK_H */

+

+

+

diff --git a/FreeRTOS/Source/include/timers.h b/FreeRTOS/Source/include/timers.h
new file mode 100644
index 0000000..5f62368
--- /dev/null
+++ b/FreeRTOS/Source/include/timers.h
@@ -0,0 +1,952 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef TIMERS_H

+#define TIMERS_H

+

+#ifndef INC_FREERTOS_H

+	#error "include FreeRTOS.h must appear in source files before include timers.h"

+#endif

+

+#include "portable.h"

+#include "list.h"

+#include "task.h"

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* IDs for commands that can be sent/received on the timer queue.  These are to

+be used solely through the macros that make up the public software timer API,

+as defined below. */

+#define tmrCOMMAND_START					0

+#define tmrCOMMAND_STOP						1

+#define tmrCOMMAND_CHANGE_PERIOD			2

+#define tmrCOMMAND_DELETE					3

+

+/*-----------------------------------------------------------

+ * MACROS AND DEFINITIONS

+ *----------------------------------------------------------*/

+

+ /**

+ * Type by which software timers are referenced.  For example, a call to

+ * xTimerCreate() returns an xTimerHandle variable that can then be used to

+ * reference the subject timer in calls to other software timer API functions

+ * (for example, xTimerStart(), xTimerReset(), etc.).

+ */

+typedef void * xTimerHandle;

+

+/* Define the prototype to which timer callback functions must conform. */

+typedef void (*tmrTIMER_CALLBACK)( xTimerHandle xTimer );

+

+/**

+ * xTimerHandle xTimerCreate( 	const signed char *pcTimerName,

+ * 								portTickType xTimerPeriodInTicks,

+ * 								unsigned portBASE_TYPE uxAutoReload,

+ * 								void * pvTimerID,

+ * 								tmrTIMER_CALLBACK pxCallbackFunction );

+ *

+ * Creates a new software timer instance.  This allocates the storage required

+ * by the new timer, initialises the new timers internal state, and returns a

+ * handle by which the new timer can be referenced.

+ *

+ * Timers are created in the dormant state.  The xTimerStart(), xTimerReset(),

+ * xTimerStartFromISR(), xTimerResetFromISR(), xTimerChangePeriod() and

+ * xTimerChangePeriodFromISR() API functions can all be used to transition a timer into the

+ * active state.

+ *

+ * @param pcTimerName A text name that is assigned to the timer.  This is done

+ * purely to assist debugging.  The kernel itself only ever references a timer by

+ * its handle, and never by its name.

+ *

+ * @param xTimerPeriodInTicks The timer period.  The time is defined in tick periods so

+ * the constant portTICK_RATE_MS can be used to convert a time that has been

+ * specified in milliseconds.  For example, if the timer must expire after 100

+ * ticks, then xTimerPeriodInTicks should be set to 100.  Alternatively, if the timer

+ * must expire after 500ms, then xPeriod can be set to ( 500 / portTICK_RATE_MS )

+ * provided configTICK_RATE_HZ is less than or equal to 1000.

+ *

+ * @param uxAutoReload If uxAutoReload is set to pdTRUE then the timer will

+ * expire repeatedly with a frequency set by the xTimerPeriodInTicks parameter.  If

+ * uxAutoReload is set to pdFALSE then the timer will be a one-shot timer and

+ * enter the dormant state after it expires.

+ *

+ * @param pvTimerID An identifier that is assigned to the timer being created.

+ * Typically this would be used in the timer callback function to identify which

+ * timer expired when the same callback function is assigned to more than one

+ * timer.

+ *

+ * @param pxCallbackFunction The function to call when the timer expires.

+ * Callback functions must have the prototype defined by tmrTIMER_CALLBACK,

+ * which is	"void vCallbackFunction( xTimerHandle xTimer );".

+ *

+ * @return If the timer is successfully create then a handle to the newly

+ * created timer is returned.  If the timer cannot be created (because either

+ * there is insufficient FreeRTOS heap remaining to allocate the timer

+ * structures, or the timer period was set to 0) then 0 is returned.

+ *

+ * Example usage:

+ *

+ * #define NUM_TIMERS 5

+ *

+ * // An array to hold handles to the created timers.

+ * xTimerHandle xTimers[ NUM_TIMERS ];

+ *

+ * // An array to hold a count of the number of times each timer expires.

+ * long lExpireCounters[ NUM_TIMERS ] = { 0 };

+ *

+ * // Define a callback function that will be used by multiple timer instances.

+ * // The callback function does nothing but count the number of times the

+ * // associated timer expires, and stop the timer once the timer has expired

+ * // 10 times.

+ * void vTimerCallback( xTimerHandle pxTimer )

+ * {

+ * long lArrayIndex;

+ * const long xMaxExpiryCountBeforeStopping = 10;

+ *

+ * 	   // Optionally do something if the pxTimer parameter is NULL.

+ * 	   configASSERT( pxTimer );

+ * 	

+ *     // Which timer expired?

+ *     lArrayIndex = ( long ) pvTimerGetTimerID( pxTimer );

+ *

+ *     // Increment the number of times that pxTimer has expired.

+ *     lExpireCounters[ lArrayIndex ] += 1;

+ *

+ *     // If the timer has expired 10 times then stop it from running.

+ *     if( lExpireCounters[ lArrayIndex ] == xMaxExpiryCountBeforeStopping )

+ *     {

+ *         // Do not use a block time if calling a timer API function from a

+ *         // timer callback function, as doing so could cause a deadlock!

+ *         xTimerStop( pxTimer, 0 );

+ *     }

+ * }

+ *

+ * void main( void )

+ * {

+ * long x;

+ *

+ *     // Create then start some timers.  Starting the timers before the scheduler

+ *     // has been started means the timers will start running immediately that

+ *     // the scheduler starts.

+ *     for( x = 0; x < NUM_TIMERS; x++ )

+ *     {

+ *         xTimers[ x ] = xTimerCreate(     "Timer",         // Just a text name, not used by the kernel.

+ *                                         ( 100 * x ),     // The timer period in ticks.

+ *                                         pdTRUE,         // The timers will auto-reload themselves when they expire.

+ *                                         ( void * ) x,     // Assign each timer a unique id equal to its array index.

+ *                                         vTimerCallback     // Each timer calls the same callback when it expires.

+ *                                     );

+ *

+ *         if( xTimers[ x ] == NULL )

+ *         {

+ *             // The timer was not created.

+ *         }

+ *         else

+ *         {

+ *             // Start the timer.  No block time is specified, and even if one was

+ *             // it would be ignored because the scheduler has not yet been

+ *             // started.

+ *             if( xTimerStart( xTimers[ x ], 0 ) != pdPASS )

+ *             {

+ *                 // The timer could not be set into the Active state.

+ *             }

+ *         }

+ *     }

+ *

+ *     // ...

+ *     // Create tasks here.

+ *     // ...

+ *

+ *     // Starting the scheduler will start the timers running as they have already

+ *     // been set into the active state.

+ *     xTaskStartScheduler();

+ *

+ *     // Should not reach here.

+ *     for( ;; );

+ * }

+ */

+xTimerHandle xTimerCreate( const signed char *pcTimerName, portTickType xTimerPeriodInTicks, unsigned portBASE_TYPE uxAutoReload, void * pvTimerID, tmrTIMER_CALLBACK pxCallbackFunction ) PRIVILEGED_FUNCTION;

+

+/**

+ * void *pvTimerGetTimerID( xTimerHandle xTimer );

+ *

+ * Returns the ID assigned to the timer.

+ *

+ * IDs are assigned to timers using the pvTimerID parameter of the call to

+ * xTimerCreated() that was used to create the timer.

+ *

+ * If the same callback function is assigned to multiple timers then the timer

+ * ID can be used within the callback function to identify which timer actually

+ * expired.

+ *

+ * @param xTimer The timer being queried.

+ *

+ * @return The ID assigned to the timer being queried.

+ *

+ * Example usage:

+ *

+ * See the xTimerCreate() API function example usage scenario.

+ */

+void *pvTimerGetTimerID( xTimerHandle xTimer ) PRIVILEGED_FUNCTION;

+

+/**

+ * portBASE_TYPE xTimerIsTimerActive( xTimerHandle xTimer );

+ *

+ * Queries a timer to see if it is active or dormant.

+ *

+ * A timer will be dormant if:

+ *     1) It has been created but not started, or

+ *     2) It is an expired on-shot timer that has not been restarted.

+ *

+ * Timers are created in the dormant state.  The xTimerStart(), xTimerReset(),

+ * xTimerStartFromISR(), xTimerResetFromISR(), xTimerChangePeriod() and

+ * xTimerChangePeriodFromISR() API functions can all be used to transition a timer into the

+ * active state.

+ *

+ * @param xTimer The timer being queried.

+ *

+ * @return pdFALSE will be returned if the timer is dormant.  A value other than

+ * pdFALSE will be returned if the timer is active.

+ *

+ * Example usage:

+ *

+ * // This function assumes xTimer has already been created.

+ * void vAFunction( xTimerHandle xTimer )

+ * {

+ *     if( xTimerIsTimerActive( xTimer ) != pdFALSE ) // or more simply and equivalently "if( xTimerIsTimerActive( xTimer ) )"

+ *     {

+ *         // xTimer is active, do something.

+ *     }

+ *     else

+ *     {

+ *         // xTimer is not active, do something else.

+ *     }

+ * }

+ */

+portBASE_TYPE xTimerIsTimerActive( xTimerHandle xTimer ) PRIVILEGED_FUNCTION;

+

+/**

+ * xTimerGetTimerDaemonTaskHandle() is only available if 

+ * INCLUDE_xTimerGetTimerDaemonTaskHandle is set to 1 in FreeRTOSConfig.h.

+ *

+ * Simply returns the handle of the timer service/daemon task.  It it not valid

+ * to call xTimerGetTimerDaemonTaskHandle() before the scheduler has been started.

+ */

+xTaskHandle xTimerGetTimerDaemonTaskHandle( void );

+

+/**

+ * portBASE_TYPE xTimerStart( xTimerHandle xTimer, portTickType xBlockTime );

+ *

+ * Timer functionality is provided by a timer service/daemon task.  Many of the

+ * public FreeRTOS timer API functions send commands to the timer service task

+ * though a queue called the timer command queue.  The timer command queue is

+ * private to the kernel itself and is not directly accessible to application

+ * code.  The length of the timer command queue is set by the

+ * configTIMER_QUEUE_LENGTH configuration constant.

+ *

+ * xTimerStart() starts a timer that was previously created using the

+ * xTimerCreate() API function.  If the timer had already been started and was

+ * already in the active state, then xTimerStart() has equivalent functionality

+ * to the xTimerReset() API function.

+ *

+ * Starting a timer ensures the timer is in the active state.  If the timer

+ * is not stopped, deleted, or reset in the mean time, the callback function

+ * associated with the timer will get called 'n' ticks after xTimerStart() was

+ * called, where 'n' is the timers defined period.

+ *

+ * It is valid to call xTimerStart() before the scheduler has been started, but

+ * when this is done the timer will not actually start until the scheduler is

+ * started, and the timers expiry time will be relative to when the scheduler is

+ * started, not relative to when xTimerStart() was called.

+ *

+ * The configUSE_TIMERS configuration constant must be set to 1 for xTimerStart()

+ * to be available.

+ *

+ * @param xTimer The handle of the timer being started/restarted.

+ *

+ * @param xBlockTime Specifies the time, in ticks, that the calling task should

+ * be held in the Blocked state to wait for the start command to be successfully

+ * sent to the timer command queue, should the queue already be full when

+ * xTimerStart() was called.  xBlockTime is ignored if xTimerStart() is called

+ * before the scheduler is started.

+ *

+ * @return pdFAIL will be returned if the start command could not be sent to

+ * the timer command queue even after xBlockTime ticks had passed.  pdPASS will

+ * be returned if the command was successfully sent to the timer command queue.

+ * When the command is actually processed will depend on the priority of the

+ * timer service/daemon task relative to other tasks in the system, although the

+ * timers expiry time is relative to when xTimerStart() is actually called.  The

+ * timer service/daemon task priority is set by the configTIMER_TASK_PRIORITY

+ * configuration constant.

+ *

+ * Example usage:

+ *

+ * See the xTimerCreate() API function example usage scenario.

+ *

+ */

+#define xTimerStart( xTimer, xBlockTime ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_START, ( xTaskGetTickCount() ), NULL, ( xBlockTime ) )

+

+/**

+ * portBASE_TYPE xTimerStop( xTimerHandle xTimer, portTickType xBlockTime );

+ *

+ * Timer functionality is provided by a timer service/daemon task.  Many of the

+ * public FreeRTOS timer API functions send commands to the timer service task

+ * though a queue called the timer command queue.  The timer command queue is

+ * private to the kernel itself and is not directly accessible to application

+ * code.  The length of the timer command queue is set by the

+ * configTIMER_QUEUE_LENGTH configuration constant.

+ *

+ * xTimerStop() stops a timer that was previously started using either of the

+ * The xTimerStart(), xTimerReset(), xTimerStartFromISR(), xTimerResetFromISR(),

+ * xTimerChangePeriod() or xTimerChangePeriodFromISR() API functions.

+ *

+ * Stopping a timer ensures the timer is not in the active state.

+ *

+ * The configUSE_TIMERS configuration constant must be set to 1 for xTimerStop()

+ * to be available.

+ *

+ * @param xTimer The handle of the timer being stopped.

+ *

+ * @param xBlockTime Specifies the time, in ticks, that the calling task should

+ * be held in the Blocked state to wait for the stop command to be successfully

+ * sent to the timer command queue, should the queue already be full when

+ * xTimerStop() was called.  xBlockTime is ignored if xTimerStop() is called

+ * before the scheduler is started.

+ *

+ * @return pdFAIL will be returned if the stop command could not be sent to

+ * the timer command queue even after xBlockTime ticks had passed.  pdPASS will

+ * be returned if the command was successfully sent to the timer command queue.

+ * When the command is actually processed will depend on the priority of the

+ * timer service/daemon task relative to other tasks in the system.  The timer

+ * service/daemon task priority is set by the configTIMER_TASK_PRIORITY

+ * configuration constant.

+ *

+ * Example usage:

+ *

+ * See the xTimerCreate() API function example usage scenario.

+ *

+ */

+#define xTimerStop( xTimer, xBlockTime ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_STOP, 0U, NULL, ( xBlockTime ) )

+

+/**

+ * portBASE_TYPE xTimerChangePeriod( 	xTimerHandle xTimer,

+ *										portTickType xNewPeriod,

+ *										portTickType xBlockTime );

+ *

+ * Timer functionality is provided by a timer service/daemon task.  Many of the

+ * public FreeRTOS timer API functions send commands to the timer service task

+ * though a queue called the timer command queue.  The timer command queue is

+ * private to the kernel itself and is not directly accessible to application

+ * code.  The length of the timer command queue is set by the

+ * configTIMER_QUEUE_LENGTH configuration constant.

+ *

+ * xTimerChangePeriod() changes the period of a timer that was previously

+ * created using the xTimerCreate() API function.

+ *

+ * xTimerChangePeriod() can be called to change the period of an active or

+ * dormant state timer.

+ *

+ * The configUSE_TIMERS configuration constant must be set to 1 for

+ * xTimerChangePeriod() to be available.

+ *

+ * @param xTimer The handle of the timer that is having its period changed.

+ *

+ * @param xNewPeriod The new period for xTimer. Timer periods are specified in

+ * tick periods, so the constant portTICK_RATE_MS can be used to convert a time

+ * that has been specified in milliseconds.  For example, if the timer must

+ * expire after 100 ticks, then xNewPeriod should be set to 100.  Alternatively,

+ * if the timer must expire after 500ms, then xNewPeriod can be set to

+ * ( 500 / portTICK_RATE_MS ) provided configTICK_RATE_HZ is less than

+ * or equal to 1000.

+ *

+ * @param xBlockTime Specifies the time, in ticks, that the calling task should

+ * be held in the Blocked state to wait for the change period command to be

+ * successfully sent to the timer command queue, should the queue already be

+ * full when xTimerChangePeriod() was called.  xBlockTime is ignored if

+ * xTimerChangePeriod() is called before the scheduler is started.

+ *

+ * @return pdFAIL will be returned if the change period command could not be

+ * sent to the timer command queue even after xBlockTime ticks had passed.

+ * pdPASS will be returned if the command was successfully sent to the timer

+ * command queue.  When the command is actually processed will depend on the

+ * priority of the timer service/daemon task relative to other tasks in the

+ * system.  The timer service/daemon task priority is set by the

+ * configTIMER_TASK_PRIORITY configuration constant.

+ *

+ * Example usage:

+ *

+ * // This function assumes xTimer has already been created.  If the timer

+ * // referenced by xTimer is already active when it is called, then the timer

+ * // is deleted.  If the timer referenced by xTimer is not active when it is

+ * // called, then the period of the timer is set to 500ms and the timer is

+ * // started.

+ * void vAFunction( xTimerHandle xTimer )

+ * {

+ *     if( xTimerIsTimerActive( xTimer ) != pdFALSE ) // or more simply and equivalently "if( xTimerIsTimerActive( xTimer ) )"

+ *     {

+ *         // xTimer is already active - delete it.

+ *         xTimerDelete( xTimer );

+ *     }

+ *     else

+ *     {

+ *         // xTimer is not active, change its period to 500ms.  This will also

+ *         // cause the timer to start.  Block for a maximum of 100 ticks if the

+ *         // change period command cannot immediately be sent to the timer

+ *         // command queue.

+ *         if( xTimerChangePeriod( xTimer, 500 / portTICK_RATE_MS, 100 ) == pdPASS )

+ *         {

+ *             // The command was successfully sent.

+ *         }

+ *         else

+ *         {

+ *             // The command could not be sent, even after waiting for 100 ticks

+ *             // to pass.  Take appropriate action here.

+ *         }

+ *     }

+ * }

+ */

+ #define xTimerChangePeriod( xTimer, xNewPeriod, xBlockTime ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_CHANGE_PERIOD, ( xNewPeriod ), NULL, ( xBlockTime ) )

+

+/**

+ * portBASE_TYPE xTimerDelete( xTimerHandle xTimer, portTickType xBlockTime );

+ *

+ * Timer functionality is provided by a timer service/daemon task.  Many of the

+ * public FreeRTOS timer API functions send commands to the timer service task

+ * though a queue called the timer command queue.  The timer command queue is

+ * private to the kernel itself and is not directly accessible to application

+ * code.  The length of the timer command queue is set by the

+ * configTIMER_QUEUE_LENGTH configuration constant.

+ *

+ * xTimerDelete() deletes a timer that was previously created using the

+ * xTimerCreate() API function.

+ *

+ * The configUSE_TIMERS configuration constant must be set to 1 for

+ * xTimerDelete() to be available.

+ *

+ * @param xTimer The handle of the timer being deleted.

+ *

+ * @param xBlockTime Specifies the time, in ticks, that the calling task should

+ * be held in the Blocked state to wait for the delete command to be

+ * successfully sent to the timer command queue, should the queue already be

+ * full when xTimerDelete() was called.  xBlockTime is ignored if xTimerDelete()

+ * is called before the scheduler is started.

+ *

+ * @return pdFAIL will be returned if the delete command could not be sent to

+ * the timer command queue even after xBlockTime ticks had passed.  pdPASS will

+ * be returned if the command was successfully sent to the timer command queue.

+ * When the command is actually processed will depend on the priority of the

+ * timer service/daemon task relative to other tasks in the system.  The timer

+ * service/daemon task priority is set by the configTIMER_TASK_PRIORITY

+ * configuration constant.

+ *

+ * Example usage:

+ *

+ * See the xTimerChangePeriod() API function example usage scenario.

+ */

+#define xTimerDelete( xTimer, xBlockTime ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_DELETE, 0U, NULL, ( xBlockTime ) )

+

+/**

+ * portBASE_TYPE xTimerReset( xTimerHandle xTimer, portTickType xBlockTime );

+ *

+ * Timer functionality is provided by a timer service/daemon task.  Many of the

+ * public FreeRTOS timer API functions send commands to the timer service task

+ * though a queue called the timer command queue.  The timer command queue is

+ * private to the kernel itself and is not directly accessible to application

+ * code.  The length of the timer command queue is set by the

+ * configTIMER_QUEUE_LENGTH configuration constant.

+ *

+ * xTimerReset() re-starts a timer that was previously created using the

+ * xTimerCreate() API function.  If the timer had already been started and was

+ * already in the active state, then xTimerReset() will cause the timer to

+ * re-evaluate its expiry time so that it is relative to when xTimerReset() was

+ * called.  If the timer was in the dormant state then xTimerReset() has

+ * equivalent functionality to the xTimerStart() API function.

+ *

+ * Resetting a timer ensures the timer is in the active state.  If the timer

+ * is not stopped, deleted, or reset in the mean time, the callback function

+ * associated with the timer will get called 'n' ticks after xTimerReset() was

+ * called, where 'n' is the timers defined period.

+ *

+ * It is valid to call xTimerReset() before the scheduler has been started, but

+ * when this is done the timer will not actually start until the scheduler is

+ * started, and the timers expiry time will be relative to when the scheduler is

+ * started, not relative to when xTimerReset() was called.

+ *

+ * The configUSE_TIMERS configuration constant must be set to 1 for xTimerReset()

+ * to be available.

+ *

+ * @param xTimer The handle of the timer being reset/started/restarted.

+ *

+ * @param xBlockTime Specifies the time, in ticks, that the calling task should

+ * be held in the Blocked state to wait for the reset command to be successfully

+ * sent to the timer command queue, should the queue already be full when

+ * xTimerReset() was called.  xBlockTime is ignored if xTimerReset() is called

+ * before the scheduler is started.

+ *

+ * @return pdFAIL will be returned if the reset command could not be sent to

+ * the timer command queue even after xBlockTime ticks had passed.  pdPASS will

+ * be returned if the command was successfully sent to the timer command queue.

+ * When the command is actually processed will depend on the priority of the

+ * timer service/daemon task relative to other tasks in the system, although the

+ * timers expiry time is relative to when xTimerStart() is actually called.  The

+ * timer service/daemon task priority is set by the configTIMER_TASK_PRIORITY

+ * configuration constant.

+ *

+ * Example usage:

+ *

+ * // When a key is pressed, an LCD back-light is switched on.  If 5 seconds pass

+ * // without a key being pressed, then the LCD back-light is switched off.  In

+ * // this case, the timer is a one-shot timer.

+ *

+ * xTimerHandle xBacklightTimer = NULL;

+ *

+ * // The callback function assigned to the one-shot timer.  In this case the

+ * // parameter is not used.

+ * void vBacklightTimerCallback( xTimerHandle pxTimer )

+ * {

+ *     // The timer expired, therefore 5 seconds must have passed since a key

+ *     // was pressed.  Switch off the LCD back-light.

+ *     vSetBacklightState( BACKLIGHT_OFF );

+ * }

+ *

+ * // The key press event handler.

+ * void vKeyPressEventHandler( char cKey )

+ * {

+ *     // Ensure the LCD back-light is on, then reset the timer that is

+ *     // responsible for turning the back-light off after 5 seconds of

+ *     // key inactivity.  Wait 10 ticks for the command to be successfully sent

+ *     // if it cannot be sent immediately.

+ *     vSetBacklightState( BACKLIGHT_ON );

+ *     if( xTimerReset( xBacklightTimer, 100 ) != pdPASS )

+ *     {

+ *         // The reset command was not executed successfully.  Take appropriate

+ *         // action here.

+ *     }

+ *

+ *     // Perform the rest of the key processing here.

+ * }

+ *

+ * void main( void )

+ * {

+ * long x;

+ *

+ *     // Create then start the one-shot timer that is responsible for turning

+ *     // the back-light off if no keys are pressed within a 5 second period.

+ *     xBacklightTimer = xTimerCreate( "BacklightTimer",           // Just a text name, not used by the kernel.

+ *                                     ( 5000 / portTICK_RATE_MS), // The timer period in ticks.

+ *                                     pdFALSE,                    // The timer is a one-shot timer.

+ *                                     0,                          // The id is not used by the callback so can take any value.

+ *                                     vBacklightTimerCallback     // The callback function that switches the LCD back-light off.

+ *                                   );

+ *

+ *     if( xBacklightTimer == NULL )

+ *     {

+ *         // The timer was not created.

+ *     }

+ *     else

+ *     {

+ *         // Start the timer.  No block time is specified, and even if one was

+ *         // it would be ignored because the scheduler has not yet been

+ *         // started.

+ *         if( xTimerStart( xBacklightTimer, 0 ) != pdPASS )

+ *         {

+ *             // The timer could not be set into the Active state.

+ *         }

+ *     }

+ *

+ *     // ...

+ *     // Create tasks here.

+ *     // ...

+ *

+ *     // Starting the scheduler will start the timer running as it has already

+ *     // been set into the active state.

+ *     xTaskStartScheduler();

+ *

+ *     // Should not reach here.

+ *     for( ;; );

+ * }

+ */

+#define xTimerReset( xTimer, xBlockTime ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_START, ( xTaskGetTickCount() ), NULL, ( xBlockTime ) )

+

+/**

+ * portBASE_TYPE xTimerStartFromISR( 	xTimerHandle xTimer,

+ *										portBASE_TYPE *pxHigherPriorityTaskWoken );

+ *

+ * A version of xTimerStart() that can be called from an interrupt service

+ * routine.

+ *

+ * @param xTimer The handle of the timer being started/restarted.

+ *

+ * @param pxHigherPriorityTaskWoken The timer service/daemon task spends most

+ * of its time in the Blocked state, waiting for messages to arrive on the timer

+ * command queue.  Calling xTimerStartFromISR() writes a message to the timer

+ * command queue, so has the potential to transition the timer service/daemon

+ * task out of the Blocked state.  If calling xTimerStartFromISR() causes the

+ * timer service/daemon task to leave the Blocked state, and the timer service/

+ * daemon task has a priority equal to or greater than the currently executing

+ * task (the task that was interrupted), then *pxHigherPriorityTaskWoken will

+ * get set to pdTRUE internally within the xTimerStartFromISR() function.  If

+ * xTimerStartFromISR() sets this value to pdTRUE then a context switch should

+ * be performed before the interrupt exits.

+ *

+ * @return pdFAIL will be returned if the start command could not be sent to

+ * the timer command queue.  pdPASS will be returned if the command was

+ * successfully sent to the timer command queue.  When the command is actually

+ * processed will depend on the priority of the timer service/daemon task

+ * relative to other tasks in the system, although the timers expiry time is

+ * relative to when xTimerStartFromISR() is actually called.  The timer service/daemon

+ * task priority is set by the configTIMER_TASK_PRIORITY configuration constant.

+ *

+ * Example usage:

+ *

+ * // This scenario assumes xBacklightTimer has already been created.  When a

+ * // key is pressed, an LCD back-light is switched on.  If 5 seconds pass

+ * // without a key being pressed, then the LCD back-light is switched off.  In

+ * // this case, the timer is a one-shot timer, and unlike the example given for

+ * // the xTimerReset() function, the key press event handler is an interrupt

+ * // service routine.

+ *

+ * // The callback function assigned to the one-shot timer.  In this case the

+ * // parameter is not used.

+ * void vBacklightTimerCallback( xTimerHandle pxTimer )

+ * {

+ *     // The timer expired, therefore 5 seconds must have passed since a key

+ *     // was pressed.  Switch off the LCD back-light.

+ *     vSetBacklightState( BACKLIGHT_OFF );

+ * }

+ *

+ * // The key press interrupt service routine.

+ * void vKeyPressEventInterruptHandler( void )

+ * {

+ * portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;

+ *

+ *     // Ensure the LCD back-light is on, then restart the timer that is

+ *     // responsible for turning the back-light off after 5 seconds of

+ *     // key inactivity.  This is an interrupt service routine so can only

+ *     // call FreeRTOS API functions that end in "FromISR".

+ *     vSetBacklightState( BACKLIGHT_ON );

+ *

+ *     // xTimerStartFromISR() or xTimerResetFromISR() could be called here

+ *     // as both cause the timer to re-calculate its expiry time.

+ *     // xHigherPriorityTaskWoken was initialised to pdFALSE when it was

+ *     // declared (in this function).

+ *     if( xTimerStartFromISR( xBacklightTimer, &xHigherPriorityTaskWoken ) != pdPASS )

+ *     {

+ *         // The start command was not executed successfully.  Take appropriate

+ *         // action here.

+ *     }

+ *

+ *     // Perform the rest of the key processing here.

+ *

+ *     // If xHigherPriorityTaskWoken equals pdTRUE, then a context switch

+ *     // should be performed.  The syntax required to perform a context switch

+ *     // from inside an ISR varies from port to port, and from compiler to

+ *     // compiler.  Inspect the demos for the port you are using to find the

+ *     // actual syntax required.

+ *     if( xHigherPriorityTaskWoken != pdFALSE )

+ *     {

+ *         // Call the interrupt safe yield function here (actual function

+ *         // depends on the FreeRTOS port being used.

+ *     }

+ * }

+ */

+#define xTimerStartFromISR( xTimer, pxHigherPriorityTaskWoken ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_START, ( xTaskGetTickCountFromISR() ), ( pxHigherPriorityTaskWoken ), 0U )

+

+/**

+ * portBASE_TYPE xTimerStopFromISR( 	xTimerHandle xTimer,

+ *										portBASE_TYPE *pxHigherPriorityTaskWoken );

+ *

+ * A version of xTimerStop() that can be called from an interrupt service

+ * routine.

+ *

+ * @param xTimer The handle of the timer being stopped.

+ *

+ * @param pxHigherPriorityTaskWoken The timer service/daemon task spends most

+ * of its time in the Blocked state, waiting for messages to arrive on the timer

+ * command queue.  Calling xTimerStopFromISR() writes a message to the timer

+ * command queue, so has the potential to transition the timer service/daemon

+ * task out of the Blocked state.  If calling xTimerStopFromISR() causes the

+ * timer service/daemon task to leave the Blocked state, and the timer service/

+ * daemon task has a priority equal to or greater than the currently executing

+ * task (the task that was interrupted), then *pxHigherPriorityTaskWoken will

+ * get set to pdTRUE internally within the xTimerStopFromISR() function.  If

+ * xTimerStopFromISR() sets this value to pdTRUE then a context switch should

+ * be performed before the interrupt exits.

+ *

+ * @return pdFAIL will be returned if the stop command could not be sent to

+ * the timer command queue.  pdPASS will be returned if the command was

+ * successfully sent to the timer command queue.  When the command is actually

+ * processed will depend on the priority of the timer service/daemon task

+ * relative to other tasks in the system.  The timer service/daemon task

+ * priority is set by the configTIMER_TASK_PRIORITY configuration constant.

+ *

+ * Example usage:

+ *

+ * // This scenario assumes xTimer has already been created and started.  When

+ * // an interrupt occurs, the timer should be simply stopped.

+ *

+ * // The interrupt service routine that stops the timer.

+ * void vAnExampleInterruptServiceRoutine( void )

+ * {

+ * portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;

+ *

+ *     // The interrupt has occurred - simply stop the timer.

+ *     // xHigherPriorityTaskWoken was set to pdFALSE where it was defined

+ *     // (within this function).  As this is an interrupt service routine, only

+ *     // FreeRTOS API functions that end in "FromISR" can be used.

+ *     if( xTimerStopFromISR( xTimer, &xHigherPriorityTaskWoken ) != pdPASS )

+ *     {

+ *         // The stop command was not executed successfully.  Take appropriate

+ *         // action here.

+ *     }

+ *

+ *     // If xHigherPriorityTaskWoken equals pdTRUE, then a context switch

+ *     // should be performed.  The syntax required to perform a context switch

+ *     // from inside an ISR varies from port to port, and from compiler to

+ *     // compiler.  Inspect the demos for the port you are using to find the

+ *     // actual syntax required.

+ *     if( xHigherPriorityTaskWoken != pdFALSE )

+ *     {

+ *         // Call the interrupt safe yield function here (actual function

+ *         // depends on the FreeRTOS port being used.

+ *     }

+ * }

+ */

+#define xTimerStopFromISR( xTimer, pxHigherPriorityTaskWoken ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_STOP, 0, ( pxHigherPriorityTaskWoken ), 0U )

+

+/**

+ * portBASE_TYPE xTimerChangePeriodFromISR( xTimerHandle xTimer,

+ *											portTickType xNewPeriod,

+ *											portBASE_TYPE *pxHigherPriorityTaskWoken );

+ *

+ * A version of xTimerChangePeriod() that can be called from an interrupt

+ * service routine.

+ *

+ * @param xTimer The handle of the timer that is having its period changed.

+ *

+ * @param xNewPeriod The new period for xTimer. Timer periods are specified in

+ * tick periods, so the constant portTICK_RATE_MS can be used to convert a time

+ * that has been specified in milliseconds.  For example, if the timer must

+ * expire after 100 ticks, then xNewPeriod should be set to 100.  Alternatively,

+ * if the timer must expire after 500ms, then xNewPeriod can be set to

+ * ( 500 / portTICK_RATE_MS ) provided configTICK_RATE_HZ is less than

+ * or equal to 1000.

+ *

+ * @param pxHigherPriorityTaskWoken The timer service/daemon task spends most

+ * of its time in the Blocked state, waiting for messages to arrive on the timer

+ * command queue.  Calling xTimerChangePeriodFromISR() writes a message to the

+ * timer command queue, so has the potential to transition the timer service/

+ * daemon task out of the Blocked state.  If calling xTimerChangePeriodFromISR()

+ * causes the timer service/daemon task to leave the Blocked state, and the

+ * timer service/daemon task has a priority equal to or greater than the

+ * currently executing task (the task that was interrupted), then

+ * *pxHigherPriorityTaskWoken will get set to pdTRUE internally within the

+ * xTimerChangePeriodFromISR() function.  If xTimerChangePeriodFromISR() sets

+ * this value to pdTRUE then a context switch should be performed before the

+ * interrupt exits.

+ *

+ * @return pdFAIL will be returned if the command to change the timers period

+ * could not be sent to the timer command queue.  pdPASS will be returned if the

+ * command was successfully sent to the timer command queue.  When the command

+ * is actually processed will depend on the priority of the timer service/daemon

+ * task relative to other tasks in the system.  The timer service/daemon task

+ * priority is set by the configTIMER_TASK_PRIORITY configuration constant.

+ *

+ * Example usage:

+ *

+ * // This scenario assumes xTimer has already been created and started.  When

+ * // an interrupt occurs, the period of xTimer should be changed to 500ms.

+ *

+ * // The interrupt service routine that changes the period of xTimer.

+ * void vAnExampleInterruptServiceRoutine( void )

+ * {

+ * portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;

+ *

+ *     // The interrupt has occurred - change the period of xTimer to 500ms.

+ *     // xHigherPriorityTaskWoken was set to pdFALSE where it was defined

+ *     // (within this function).  As this is an interrupt service routine, only

+ *     // FreeRTOS API functions that end in "FromISR" can be used.

+ *     if( xTimerChangePeriodFromISR( xTimer, &xHigherPriorityTaskWoken ) != pdPASS )

+ *     {

+ *         // The command to change the timers period was not executed

+ *         // successfully.  Take appropriate action here.

+ *     }

+ *

+ *     // If xHigherPriorityTaskWoken equals pdTRUE, then a context switch

+ *     // should be performed.  The syntax required to perform a context switch

+ *     // from inside an ISR varies from port to port, and from compiler to

+ *     // compiler.  Inspect the demos for the port you are using to find the

+ *     // actual syntax required.

+ *     if( xHigherPriorityTaskWoken != pdFALSE )

+ *     {

+ *         // Call the interrupt safe yield function here (actual function

+ *         // depends on the FreeRTOS port being used.

+ *     }

+ * }

+ */

+#define xTimerChangePeriodFromISR( xTimer, xNewPeriod, pxHigherPriorityTaskWoken ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_CHANGE_PERIOD, ( xNewPeriod ), ( pxHigherPriorityTaskWoken ), 0U )

+

+/**

+ * portBASE_TYPE xTimerResetFromISR( 	xTimerHandle xTimer,

+ *										portBASE_TYPE *pxHigherPriorityTaskWoken );

+ *

+ * A version of xTimerReset() that can be called from an interrupt service

+ * routine.

+ *

+ * @param xTimer The handle of the timer that is to be started, reset, or

+ * restarted.

+ *

+ * @param pxHigherPriorityTaskWoken The timer service/daemon task spends most

+ * of its time in the Blocked state, waiting for messages to arrive on the timer

+ * command queue.  Calling xTimerResetFromISR() writes a message to the timer

+ * command queue, so has the potential to transition the timer service/daemon

+ * task out of the Blocked state.  If calling xTimerResetFromISR() causes the

+ * timer service/daemon task to leave the Blocked state, and the timer service/

+ * daemon task has a priority equal to or greater than the currently executing

+ * task (the task that was interrupted), then *pxHigherPriorityTaskWoken will

+ * get set to pdTRUE internally within the xTimerResetFromISR() function.  If

+ * xTimerResetFromISR() sets this value to pdTRUE then a context switch should

+ * be performed before the interrupt exits.

+ *

+ * @return pdFAIL will be returned if the reset command could not be sent to

+ * the timer command queue.  pdPASS will be returned if the command was

+ * successfully sent to the timer command queue.  When the command is actually

+ * processed will depend on the priority of the timer service/daemon task

+ * relative to other tasks in the system, although the timers expiry time is

+ * relative to when xTimerResetFromISR() is actually called.  The timer service/daemon

+ * task priority is set by the configTIMER_TASK_PRIORITY configuration constant.

+ *

+ * Example usage:

+ *

+ * // This scenario assumes xBacklightTimer has already been created.  When a

+ * // key is pressed, an LCD back-light is switched on.  If 5 seconds pass

+ * // without a key being pressed, then the LCD back-light is switched off.  In

+ * // this case, the timer is a one-shot timer, and unlike the example given for

+ * // the xTimerReset() function, the key press event handler is an interrupt

+ * // service routine.

+ *

+ * // The callback function assigned to the one-shot timer.  In this case the

+ * // parameter is not used.

+ * void vBacklightTimerCallback( xTimerHandle pxTimer )

+ * {

+ *     // The timer expired, therefore 5 seconds must have passed since a key

+ *     // was pressed.  Switch off the LCD back-light.

+ *     vSetBacklightState( BACKLIGHT_OFF );

+ * }

+ *

+ * // The key press interrupt service routine.

+ * void vKeyPressEventInterruptHandler( void )

+ * {

+ * portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;

+ *

+ *     // Ensure the LCD back-light is on, then reset the timer that is

+ *     // responsible for turning the back-light off after 5 seconds of

+ *     // key inactivity.  This is an interrupt service routine so can only

+ *     // call FreeRTOS API functions that end in "FromISR".

+ *     vSetBacklightState( BACKLIGHT_ON );

+ *

+ *     // xTimerStartFromISR() or xTimerResetFromISR() could be called here

+ *     // as both cause the timer to re-calculate its expiry time.

+ *     // xHigherPriorityTaskWoken was initialised to pdFALSE when it was

+ *     // declared (in this function).

+ *     if( xTimerResetFromISR( xBacklightTimer, &xHigherPriorityTaskWoken ) != pdPASS )

+ *     {

+ *         // The reset command was not executed successfully.  Take appropriate

+ *         // action here.

+ *     }

+ *

+ *     // Perform the rest of the key processing here.

+ *

+ *     // If xHigherPriorityTaskWoken equals pdTRUE, then a context switch

+ *     // should be performed.  The syntax required to perform a context switch

+ *     // from inside an ISR varies from port to port, and from compiler to

+ *     // compiler.  Inspect the demos for the port you are using to find the

+ *     // actual syntax required.

+ *     if( xHigherPriorityTaskWoken != pdFALSE )

+ *     {

+ *         // Call the interrupt safe yield function here (actual function

+ *         // depends on the FreeRTOS port being used.

+ *     }

+ * }

+ */

+#define xTimerResetFromISR( xTimer, pxHigherPriorityTaskWoken ) xTimerGenericCommand( ( xTimer ), tmrCOMMAND_START, ( xTaskGetTickCountFromISR() ), ( pxHigherPriorityTaskWoken ), 0U )

+

+/*

+ * Functions beyond this part are not part of the public API and are intended

+ * for use by the kernel only.

+ */

+portBASE_TYPE xTimerCreateTimerTask( void ) PRIVILEGED_FUNCTION;

+portBASE_TYPE xTimerGenericCommand( xTimerHandle xTimer, portBASE_TYPE xCommandID, portTickType xOptionalValue, signed portBASE_TYPE *pxHigherPriorityTaskWoken, portTickType xBlockTime ) PRIVILEGED_FUNCTION;

+

+#ifdef __cplusplus

+}

+#endif

+#endif /* TIMERS_H */

+

+

+

diff --git a/FreeRTOS/Source/init.c b/FreeRTOS/Source/init.c
new file mode 100644
index 0000000..c88f053
--- /dev/null
+++ b/FreeRTOS/Source/init.c
@@ -0,0 +1,16 @@
+
+#include "FreeRTOS.h"
+// function declarations
+void xInitRTOS(void);
+void xInitQueues(void);
+void xInitTimers(void);
+void xInitTCBs(void);
+
+void xInitRTOS(void)
+{
+    xInitQueues();
+#if ( configUSE_TIMERS == 1 )
+    xInitTimers();
+#endif
+    xInitTCBs();
+}
diff --git a/FreeRTOS/Source/list.c b/FreeRTOS/Source/list.c
new file mode 100644
index 0000000..9ae5d86
--- /dev/null
+++ b/FreeRTOS/Source/list.c
@@ -0,0 +1,204 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#include <stdlib.h>

+#include "FreeRTOS.h"

+#include "list.h"

+

+/*-----------------------------------------------------------

+ * PUBLIC LIST API documented in list.h

+ *----------------------------------------------------------*/

+

+void vListInitialise( xList *pxList )

+{

+	/* The list structure contains a list item which is used to mark the

+	end of the list.  To initialise the list the list end is inserted

+	as the only list entry. */

+	pxList->pxIndex = ( xListItem * ) &( pxList->xListEnd );

+

+	/* The list end value is the highest possible value in the list to

+	ensure it remains at the end of the list. */

+	pxList->xListEnd.xItemValue = portMAX_DELAY;

+

+	/* The list end next and previous pointers point to itself so we know

+	when the list is empty. */

+	pxList->xListEnd.pxNext = ( xListItem * ) &( pxList->xListEnd );

+	pxList->xListEnd.pxPrevious = ( xListItem * ) &( pxList->xListEnd );

+

+	pxList->uxNumberOfItems = ( unsigned portBASE_TYPE ) 0U;

+}

+/*-----------------------------------------------------------*/

+

+void vListInitialiseItem( xListItem *pxItem )

+{

+	/* Make sure the list item is not recorded as being on a list. */

+	pxItem->pvContainer = NULL;

+}

+/*-----------------------------------------------------------*/

+

+void vListInsertEnd( xList *pxList, xListItem *pxNewListItem )

+{

+volatile xListItem * pxIndex;

+

+	/* Insert a new list item into pxList, but rather than sort the list,

+	makes the new list item the last item to be removed by a call to

+	pvListGetOwnerOfNextEntry.  This means it has to be the item pointed to by

+	the pxIndex member. */

+	pxIndex = pxList->pxIndex;

+

+	pxNewListItem->pxNext = pxIndex->pxNext;

+	pxNewListItem->pxPrevious = pxList->pxIndex;

+	pxIndex->pxNext->pxPrevious = ( volatile xListItem * ) pxNewListItem;

+	pxIndex->pxNext = ( volatile xListItem * ) pxNewListItem;

+	pxList->pxIndex = ( volatile xListItem * ) pxNewListItem;

+

+	/* Remember which list the item is in. */

+	pxNewListItem->pvContainer = ( void * ) pxList;

+

+	( pxList->uxNumberOfItems )++;

+}

+/*-----------------------------------------------------------*/

+

+void vListInsert( xList *pxList, xListItem *pxNewListItem )

+{

+volatile xListItem *pxIterator;

+portTickType xValueOfInsertion;

+

+	/* Insert the new list item into the list, sorted in ulListItem order. */

+	xValueOfInsertion = pxNewListItem->xItemValue;

+

+	/* If the list already contains a list item with the same item value then

+	the new list item should be placed after it.  This ensures that TCB's which

+	are stored in ready lists (all of which have the same ulListItem value)

+	get an equal share of the CPU.  However, if the xItemValue is the same as

+	the back marker the iteration loop below will not end.  This means we need

+	to guard against this by checking the value first and modifying the

+	algorithm slightly if necessary. */

+	if( xValueOfInsertion == portMAX_DELAY )

+	{

+		pxIterator = pxList->xListEnd.pxPrevious;

+	}

+	else

+	{

+		/* *** NOTE ***********************************************************

+		If you find your application is crashing here then likely causes are:

+			1) Stack overflow -

+			   see http://www.freertos.org/Stacks-and-stack-overflow-checking.html

+			2) Incorrect interrupt priority assignment, especially on Cortex-M3

+			   parts where numerically high priority values denote low actual

+			   interrupt priories, which can seem counter intuitive.  See

+			   configMAX_SYSCALL_INTERRUPT_PRIORITY on http://www.freertos.org/a00110.html

+			3) Calling an API function from within a critical section or when

+			   the scheduler is suspended.

+			4) Using a queue or semaphore before it has been initialised or

+			   before the scheduler has been started (are interrupts firing

+			   before vTaskStartScheduler() has been called?).

+		See http://www.freertos.org/FAQHelp.html for more tips.

+		**********************************************************************/

+		

+		for( pxIterator = ( xListItem * ) &( pxList->xListEnd ); pxIterator->pxNext->xItemValue <= xValueOfInsertion; pxIterator = pxIterator->pxNext )

+		{

+			/* There is nothing to do here, we are just iterating to the

+			wanted insertion position. */

+		}

+	}

+

+	pxNewListItem->pxNext = pxIterator->pxNext;

+	pxNewListItem->pxNext->pxPrevious = ( volatile xListItem * ) pxNewListItem;

+	pxNewListItem->pxPrevious = pxIterator;

+	pxIterator->pxNext = ( volatile xListItem * ) pxNewListItem;

+

+	/* Remember which list the item is in.  This allows fast removal of the

+	item later. */

+	pxNewListItem->pvContainer = ( void * ) pxList;

+

+	( pxList->uxNumberOfItems )++;

+}

+/*-----------------------------------------------------------*/

+

+void vListRemove( xListItem *pxItemToRemove )

+{

+xList * pxList;

+

+	pxItemToRemove->pxNext->pxPrevious = pxItemToRemove->pxPrevious;

+	pxItemToRemove->pxPrevious->pxNext = pxItemToRemove->pxNext;

+	

+	/* The list item knows which list it is in.  Obtain the list from the list

+	item. */

+	pxList = ( xList * ) pxItemToRemove->pvContainer;

+

+	/* Make sure the index is left pointing to a valid item. */

+	if( pxList->pxIndex == pxItemToRemove )

+	{

+		pxList->pxIndex = pxItemToRemove->pxPrevious;

+	}

+

+	pxItemToRemove->pvContainer = NULL;

+	( pxList->uxNumberOfItems )--;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/port.c b/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/port.c
new file mode 100644
index 0000000..9f1e4a0
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/port.c
@@ -0,0 +1,282 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.00:

+

+	+ Call to taskYIELD() from within tick ISR has been replaced by the more

+	  efficient portSWITCH_CONTEXT().

+	+ ISR function definitions renamed to include the prv prefix.

+

+Changes from V2.6.1

+

+	+ Replaced the sUsingPreemption variable with the configUSE_PREEMPTION

+	  macro to be consistent with the later ports.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Flashlite 186

+ * port.

+ *----------------------------------------------------------*/

+

+#include <dos.h>

+#include <stdlib.h>

+#include <setjmp.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/*lint -e950 Non ANSI reserved words okay in this file only. */

+

+#define portTIMER_EOI_TYPE		( 8 )

+#define portRESET_PIC()			portOUTPUT_WORD( ( unsigned short ) 0xff22, portTIMER_EOI_TYPE )

+#define portTIMER_INT_NUMBER	0x12

+

+#define portTIMER_1_CONTROL_REGISTER	( ( unsigned short ) 0xff5e )

+#define portTIMER_0_CONTROL_REGISTER	( ( unsigned short ) 0xff56 )

+#define portTIMER_INTERRUPT_ENABLE		( ( unsigned short ) 0x2000 )

+

+/* Setup the hardware to generate the required tick frequency. */

+static void prvSetTickFrequency( unsigned long ulTickRateHz );

+

+/* Set the hardware back to the state as per before the scheduler started. */

+static void prvExitFunction( void );

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/*lint -e956 File scopes necessary here. */

+

+/* Set true when the vectors are set so the scheduler will service the tick. */

+static portBASE_TYPE xSchedulerRunning = pdFALSE;

+

+/* Points to the original routine installed on the vector we use for manual

+context switches.  This is then used to restore the original routine during

+prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISR )();

+

+/* Used to restore the original DOS context when the scheduler is ended. */

+static jmp_buf xJumpBuf;

+

+/*lint +e956 */

+

+/*-----------------------------------------------------------*/

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* This is called with interrupts already disabled. */

+

+	/* Remember what was on the interrupts we are going to use

+	so we can put them back later if required. */

+	pxOldSwitchISR = _dos_getvect( portSWITCH_INT_NUMBER );

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	_dos_setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	#if( configUSE_PREEMPTION == 1 )

+	{

+		/* Put our tick switch function on the timer interrupt. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvPreemptiveTick );

+	}

+	#else

+	{

+		/* We want the timer interrupt to just increment the tick count. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvNonPreemptiveTick );

+	}

+	#endif

+

+	prvSetTickFrequency( configTICK_RATE_HZ );

+

+	/* Clean up function if we want to return to DOS. */

+	if( setjmp( xJumpBuf ) != 0 )

+	{

+		prvExitFunction();

+		xSchedulerRunning = pdFALSE;

+	}

+	else

+	{

+		xSchedulerRunning = pdTRUE;

+

+		/* Kick off the scheduler by setting up the context of the first task. */

+		portFIRST_CONTEXT();

+	}

+

+	return xSchedulerRunning;

+}

+/*-----------------------------------------------------------*/

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portSWITCH_CONTEXT();

+

+		/* Reset the PIC ready for the next time. */

+		portRESET_PIC();

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		portRESET_PIC();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portSWITCH_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Jump back to the processor state prior to starting the

+	scheduler.  This means we are not going to be using a

+	task stack frame so the task can be deleted. */

+	longjmp( xJumpBuf, 1 );

+}

+/*-----------------------------------------------------------*/

+

+static void prvExitFunction( void )

+{

+const unsigned short usTimerDisable = 0x0000;

+unsigned short usTimer0Control;

+

+	/* Interrupts should be disabled here anyway - but no

+	harm in making sure. */

+	portDISABLE_INTERRUPTS();

+	if( xSchedulerRunning == pdTRUE )

+	{

+		/* Put back the switch interrupt routines that was in place

+		before the scheduler started. */

+		_dos_setvect( portSWITCH_INT_NUMBER, pxOldSwitchISR );

+	}

+

+	/* Disable the timer used for the tick to ensure the scheduler is

+	not called before restoring interrupts.  There was previously nothing

+	on this timer so there is no old ISR to restore. */

+	portOUTPUT_WORD( portTIMER_1_CONTROL_REGISTER, usTimerDisable );

+

+	/* Restart the DOS tick. */

+	usTimer0Control = portINPUT_WORD( portTIMER_0_CONTROL_REGISTER );

+	usTimer0Control |= portTIMER_INTERRUPT_ENABLE;

+	portOUTPUT_WORD( portTIMER_0_CONTROL_REGISTER, usTimer0Control );

+

+

+	portENABLE_INTERRUPTS();

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequency( unsigned long ulTickRateHz )

+{

+const unsigned short usMaxCountRegister = 0xff5a;

+const unsigned short usTimerPriorityRegister = 0xff32;

+const unsigned short usTimerEnable = 0xC000;

+const unsigned short usRetrigger = 0x0001;

+const unsigned short usTimerHighPriority = 0x0000;

+unsigned short usTimer0Control;

+

+/* ( CPU frequency / 4 ) / clock 2 max count [inpw( 0xff62 ) = 7] */

+

+const unsigned long ulClockFrequency = ( unsigned long ) 0x7f31a0UL;

+

+unsigned long ulTimerCount = ulClockFrequency / ulTickRateHz;

+

+	portOUTPUT_WORD( portTIMER_1_CONTROL_REGISTER, usTimerEnable | portTIMER_INTERRUPT_ENABLE | usRetrigger );

+	portOUTPUT_WORD( usMaxCountRegister, ( unsigned short ) ulTimerCount );

+	portOUTPUT_WORD( usTimerPriorityRegister, usTimerHighPriority );

+

+	/* Stop the DOS tick - don't do this if you want to maintain a TOD clock. */

+	usTimer0Control = portINPUT_WORD( portTIMER_0_CONTROL_REGISTER );

+	usTimer0Control &= ~portTIMER_INTERRUPT_ENABLE;

+	portOUTPUT_WORD( portTIMER_0_CONTROL_REGISTER, usTimer0Control );

+}

+

+

+/*lint +e950 */

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/prtmacro.h b/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/prtmacro.h
new file mode 100644
index 0000000..5e4990b
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/Flsh186/prtmacro.h
@@ -0,0 +1,132 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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		long

+#define portLONG		long

+#define portSHORT		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENTER_CRITICAL()			__asm{ pushf }  \

+										__asm{ cli 	 }	\

+

+#define portEXIT_CRITICAL()				__asm{ popf }

+

+#define portDISABLE_INTERRUPTS()		__asm{ cli }

+

+#define portENABLE_INTERRUPTS()			__asm{ sti }

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portNOP()						__asm{ nop }

+#define portSTACK_GROWTH				( -1 )

+#define portSWITCH_INT_NUMBER 			0x80

+#define portYIELD()						__asm{ int portSWITCH_INT_NUMBER } 

+#define portTICK_RATE_MS		( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT      2

+#define portINITIAL_SW		( ( portSTACK_TYPE ) 0x0202 )	/* Start the tasks with interrupts enabled. */

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )				inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )	outp( xAddr, ucValue )

+#define portINPUT_WORD( xAddr )				inpw( xAddr )

+#define portOUTPUT_WORD( xAddr, usValue )	outpw( xAddr, usValue )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+#define portTASK_FUNCTION( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/PC/port.c b/FreeRTOS/Source/portable/BCC/16BitDOS/PC/port.c
new file mode 100644
index 0000000..912708a
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/PC/port.c
@@ -0,0 +1,326 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V2.6.1

+

+	+ Replaced the sUsingPreemption variable with the configUSE_PREEMPTION

+	  macro to be consistent with the later ports.

+

+Changes from V4.0.1

+	

+	+ Add function prvSetTickFrequencyDefault() to set the DOS tick back to

+	  its proper value when the scheduler exits. 

+*/

+

+#include <stdlib.h>

+#include <dos.h>

+#include <setjmp.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the industrial

+ * PC port.

+ *----------------------------------------------------------*/

+

+/*lint -e950 Non ANSI reserved words okay in this file only. */

+

+#define portTIMER_INT_NUMBER	0x08

+

+/* Setup hardware for required tick interrupt rate. */

+static void prvSetTickFrequency( unsigned long ulTickRateHz );

+

+/* Restore hardware to as it was prior to starting the scheduler. */

+static void prvExitFunction( void );

+

+/* Either chain to the DOS tick (which itself clears the PIC) or clear the PIC

+directly.  We chain to the DOS tick as close as possible to the standard DOS

+tick rate. */

+static void prvPortResetPIC( void );

+

+/* The ISR used depends on whether the preemptive or cooperative

+scheduler is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/* Set the tick frequency back so the floppy drive works correctly when the

+scheduler exits. */

+static void prvSetTickFrequencyDefault( void );

+

+/*lint -e956 File scopes necessary here. */

+

+/* Used to signal when to chain to the DOS tick, and when to just clear the PIC ourselves. */

+static short sDOSTickCounter;

+

+/* Set true when the vectors are set so the scheduler will service the tick. */

+static portBASE_TYPE xSchedulerRunning = pdFALSE;				

+

+/* Points to the original routine installed on the vector we use for manual context switches.  This is then used to restore the original routine during prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISR )();		

+

+/* Points to the original routine installed on the vector we use to chain to the DOS tick.  This is then used to restore the original routine during prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISRPlus1 )();	

+

+/* Used to restore the original DOS context when the scheduler is ended. */

+static jmp_buf xJumpBuf;

+

+/*lint +e956 */

+

+/*-----------------------------------------------------------*/

+portBASE_TYPE xPortStartScheduler( void )

+{

+pxISR pxOriginalTickISR;

+	

+	/* This is called with interrupts already disabled. */

+

+	/* Remember what was on the interrupts we are going to use

+	so we can put them back later if required. */

+	pxOldSwitchISR = _dos_getvect( portSWITCH_INT_NUMBER );

+	pxOriginalTickISR = _dos_getvect( portTIMER_INT_NUMBER );

+	pxOldSwitchISRPlus1 = _dos_getvect( portSWITCH_INT_NUMBER + 1 );

+

+	prvSetTickFrequency( configTICK_RATE_HZ );

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	_dos_setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	/* Put the old tick on a different interrupt number so we can

+	call it when we want. */

+	_dos_setvect( portSWITCH_INT_NUMBER + 1, pxOriginalTickISR );

+

+	/* The ISR used depends on whether the preemptive or cooperative

+	scheduler is being used. */

+	#if( configUSE_PREEMPTION == 1 )

+	{

+		/* Put our tick switch function on the timer interrupt. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvPreemptiveTick );

+	}

+	#else

+	{

+		/* We want the timer interrupt to just increment the tick count. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvNonPreemptiveTick );

+	}

+    #endif

+

+	/* Setup a counter that is used to call the DOS interrupt as close

+	to it's original frequency as can be achieved given our chosen tick

+	frequency. */

+	sDOSTickCounter = portTICKS_PER_DOS_TICK;

+

+	/* Clean up function if we want to return to DOS. */

+	if( setjmp( xJumpBuf ) != 0 )

+	{

+		prvExitFunction();

+		xSchedulerRunning = pdFALSE;

+	}

+	else

+	{

+		xSchedulerRunning = pdTRUE;

+

+		/* Kick off the scheduler by setting up the context of the first task. */

+		portFIRST_CONTEXT();

+	}

+

+	return xSchedulerRunning;

+}

+/*-----------------------------------------------------------*/

+

+/* The ISR used depends on whether the preemptive or cooperative

+scheduler is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portSWITCH_CONTEXT();

+

+		/* Reset the PIC ready for the next time. */

+		prvPortResetPIC();

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		prvPortResetPIC();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portSWITCH_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+static void prvPortResetPIC( void )

+{

+	/* We are going to call the DOS tick interrupt at as close a

+	frequency to the normal DOS tick as possible. */

+

+	/* WE SHOULD NOT DO THIS IF YIELD WAS CALLED. */

+	--sDOSTickCounter;

+	if( sDOSTickCounter <= 0 )

+	{

+		sDOSTickCounter = ( short ) portTICKS_PER_DOS_TICK;

+		__asm{ int	portSWITCH_INT_NUMBER + 1 };		 

+	}

+	else

+	{

+		/* Reset the PIC as the DOS tick is not being called to

+		do it. */

+		__asm

+		{

+			mov	al, 20H

+			out 20H, al

+		};

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Jump back to the processor state prior to starting the

+	scheduler.  This means we are not going to be using a

+	task stack frame so the task can be deleted. */

+	longjmp( xJumpBuf, 1 );

+}

+/*-----------------------------------------------------------*/

+

+static void prvExitFunction( void )

+{

+void ( __interrupt __far *pxOriginalTickISR )();

+

+	/* Interrupts should be disabled here anyway - but no 

+	harm in making sure. */

+	portDISABLE_INTERRUPTS();

+	if( xSchedulerRunning == pdTRUE )

+	{

+		/* Set the DOS tick back onto the timer ticker. */

+		pxOriginalTickISR = _dos_getvect( portSWITCH_INT_NUMBER + 1 );

+		_dos_setvect( portTIMER_INT_NUMBER, pxOriginalTickISR );

+		prvSetTickFrequencyDefault();

+

+		/* Put back the switch interrupt routines that was in place

+		before the scheduler started. */

+		_dos_setvect( portSWITCH_INT_NUMBER, pxOldSwitchISR );

+		_dos_setvect( portSWITCH_INT_NUMBER + 1, pxOldSwitchISRPlus1 );

+	}

+	/* The tick timer is back how DOS wants it.  We can re-enable

+	interrupts without the scheduler being called. */

+	portENABLE_INTERRUPTS();

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequency( unsigned long ulTickRateHz )

+{

+const unsigned short usPIT_MODE = ( unsigned short ) 0x43;

+const unsigned short usPIT0 = ( unsigned short ) 0x40;

+const unsigned long ulPIT_CONST = ( unsigned long ) 1193180UL;

+const unsigned short us8254_CTR0_MODE3 = ( unsigned short ) 0x36;

+unsigned long ulOutput;

+

+	/* Setup the 8245 to tick at the wanted frequency. */

+	portOUTPUT_BYTE( usPIT_MODE, us8254_CTR0_MODE3 );

+	ulOutput = ulPIT_CONST / ulTickRateHz;

+	portOUTPUT_BYTE( usPIT0, ( unsigned short )( ulOutput & ( unsigned long ) 0xff ) );

+	ulOutput >>= 8;

+	portOUTPUT_BYTE( usPIT0, ( unsigned short ) ( ulOutput & ( unsigned long ) 0xff ) );

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequencyDefault( void )

+{

+const unsigned short usPIT_MODE = ( unsigned short ) 0x43;

+const unsigned short usPIT0 = ( unsigned short ) 0x40;

+const unsigned short us8254_CTR0_MODE3 = ( unsigned short ) 0x36;

+

+	portOUTPUT_BYTE( usPIT_MODE, us8254_CTR0_MODE3 );

+	portOUTPUT_BYTE( usPIT0,0 );

+	portOUTPUT_BYTE( usPIT0,0 );

+}

+

+

+/*lint +e950 */

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/PC/prtmacro.h b/FreeRTOS/Source/portable/BCC/16BitDOS/PC/prtmacro.h
new file mode 100644
index 0000000..5c980d3
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/PC/prtmacro.h
@@ -0,0 +1,132 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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		long

+#define portDOUBLE		long

+#define portLONG		long

+#define portSHORT		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section management. */

+#define portENTER_CRITICAL()			__asm{ pushf }  \

+										__asm{ cli 	 }	\

+

+#define portEXIT_CRITICAL()				__asm{ popf }

+

+#define portDISABLE_INTERRUPTS()		__asm{ cli }

+

+#define portENABLE_INTERRUPTS()			__asm{ sti }

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portNOP()				__asm{ nop }

+#define portSTACK_GROWTH		( -1 )

+#define portSWITCH_INT_NUMBER 	0x80

+#define portYIELD()				__asm{ int portSWITCH_INT_NUMBER } 

+#define portDOS_TICK_RATE		( 18.20648 )

+#define portTICK_RATE_MS		( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portTICKS_PER_DOS_TICK	( ( unsigned portSHORT ) ( ( ( portDOUBLE ) configTICK_RATE_HZ / portDOS_TICK_RATE ) + 0.5 ) )

+#define portINITIAL_SW			( ( portSTACK_TYPE ) 0x0202 )	/* Start the tasks with interrupts enabled. */

+#define portBYTE_ALIGNMENT		( 2 )

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )				inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )	outp( xAddr, ucValue )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vTaskFunction, pvParameters ) void vTaskFunction( void *pvParameters )

+#define portTASK_FUNCTION( vTaskFunction, pvParameters ) void vTaskFunction( void *pvParameters )

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/common/portasm.h b/FreeRTOS/Source/portable/BCC/16BitDOS/common/portasm.h
new file mode 100644
index 0000000..1142ea4
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/common/portasm.h
@@ -0,0 +1,126 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORT_ASM_H

+#define PORT_ASM_H

+

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/*

+ * Saves the stack pointer for one task into its TCB, calls

+ * vTaskSwitchContext() to update the TCB being used, then restores the stack

+ * from the new TCB read to run the task.

+ */

+void portSWITCH_CONTEXT( void );

+

+/*

+ * Load the stack pointer from the TCB of the task which is going to be first

+ * to execute.  Then force an IRET so the registers and IP are popped off the

+ * stack.

+ */

+void portFIRST_CONTEXT( void );

+

+/* There are slightly different versions depending on whether you are building

+to include debugger information.  If debugger information is used then there

+are a couple of extra bytes left of the ISR stack (presumably for use by the

+debugger).  The true stack pointer is then stored in the bp register.  We add

+2 to the stack pointer to remove the extra bytes before we restore our context. */

+

+#define portSWITCH_CONTEXT()											\

+							asm { mov	ax, seg pxCurrentTCB		}	\

+							asm { mov	ds, ax						}	\

+							asm { les	bx, pxCurrentTCB			}	/* Save the stack pointer into the TCB. */		\

+							asm { mov	es:0x2[ bx ], ss			}	\

+							asm { mov	es:[ bx ], sp				}	\

+							asm { call  far ptr vTaskSwitchContext	}	/* Perform the switch. */						\

+							asm { mov	ax, seg pxCurrentTCB		}	/* Restore the stack pointer from the TCB. */	\

+							asm { mov	ds, ax						}	\

+							asm { les	bx, dword ptr pxCurrentTCB	}	\

+							asm { mov	ss, es:[ bx + 2 ]			}	\

+							asm { mov	sp, es:[ bx ]				}

+

+#define portFIRST_CONTEXT()												\

+							__asm { mov	ax, seg pxCurrentTCB		}	\

+							__asm { mov	ds, ax						}	\

+							__asm { les	bx, dword ptr pxCurrentTCB	}	\

+							__asm { mov	ss, es:[ bx + 2 ]			}	\

+							__asm { mov	sp, es:[ bx ]				}	\

+							__asm { pop	bp							}	\

+							__asm { pop	di							}	\

+							__asm { pop	si							}	\

+							__asm { pop	ds							}	\

+							__asm { pop	es							}	\

+							__asm { pop	dx							}	\

+							__asm { pop	cx							}	\

+							__asm { pop	bx							}	\

+							__asm { pop	ax							}	\

+							__asm { iret							}

+

+

+#endif

+

diff --git a/FreeRTOS/Source/portable/BCC/16BitDOS/common/portcomn.c b/FreeRTOS/Source/portable/BCC/16BitDOS/common/portcomn.c
new file mode 100644
index 0000000..fc41a77
--- /dev/null
+++ b/FreeRTOS/Source/portable/BCC/16BitDOS/common/portcomn.c
@@ -0,0 +1,159 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.00:

+

+	+ pxPortInitialiseStack() now initialises the stack of new tasks to the

+	  same format used by the compiler.  This allows the compiler generated

+	  interrupt mechanism to be used for context switches.

+

+Changes from V2.6.1

+

+	+ Move usPortCheckFreeStackSpace() to tasks.c.

+*/

+

+

+#include <dos.h>

+#include <stdlib.h>

+#include "FreeRTOS.h"

+

+/*-----------------------------------------------------------*/

+

+/* See header file for description. */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE DS_Reg = 0;

+

+	/* Place a few bytes of known values on the bottom of the stack.

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x1111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x2222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x3333;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x4444;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x5555;

+	pxTopOfStack--;

+

+

+	/*lint -e950 -e611 -e923 Lint doesn't like this much - but nothing I can do about it. */

+

+	/* We are going to start the scheduler using a return from interrupt

+	instruction to load the program counter, so first there would be the

+	function call with parameters preamble. */

+	

+	*pxTopOfStack = FP_SEG( pvParameters );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pvParameters );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* Next the status register and interrupt return address. */

+	*pxTopOfStack = portINITIAL_SW; 

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* The remaining registers would be pushed on the stack by our context

+	switch function.  These are loaded with values simply to make debugging

+	easier. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xAAAA;	/* AX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xCCCC;	/* CX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xEEEE;	/* ES */

+	pxTopOfStack--;

+

+	/* We need the true data segment. */

+	__asm{	MOV DS_Reg, DS };

+

+	*pxTopOfStack = DS_Reg;						/* DS */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0123;	/* SI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BP */

+

+	/*lint +e950 +e611 +e923 */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/CCS/MSP430X/data_model.h b/FreeRTOS/Source/portable/CCS/MSP430X/data_model.h
new file mode 100644
index 0000000..263a478
--- /dev/null
+++ b/FreeRTOS/Source/portable/CCS/MSP430X/data_model.h
@@ -0,0 +1,79 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	.if $DEFINED( __LARGE_DATA_MODEL__ )

+		.define "pushm.a", pushm_x

+		.define "popm.a", popm_x

+		.define "push.a", push_x

+		.define "pop.a", pop_x

+		.define "mov.a", mov_x

+	.else

+		.define "pushm.w", pushm_x

+		.define "popm.w", popm_x

+		.define "push.w", push_x

+		.define "pop.w", pop_x

+		.define "mov.w", mov_x

+	.endif

+	

+	.if $DEFINED( __LARGE_CODE_MODEL__ )

+		.define "calla", call_x

+		.define "reta", ret_x

+	.else

+		.define "call", call_x

+		.define "ret", ret_x

+	.endif

+	

+

+

+

+

diff --git a/FreeRTOS/Source/portable/CCS/MSP430X/port.c b/FreeRTOS/Source/portable/CCS/MSP430X/port.c
new file mode 100644
index 0000000..5753185
--- /dev/null
+++ b/FreeRTOS/Source/portable/CCS/MSP430X/port.c
@@ -0,0 +1,226 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MSP430X port.

+ *----------------------------------------------------------*/

+

+/* Constants required for hardware setup.  The tick ISR runs off the ACLK,

+not the MCLK. */

+#define portACLK_FREQUENCY_HZ			( ( portTickType ) 32768 )

+#define portINITIAL_CRITICAL_NESTING	( ( unsigned short ) 10 )

+#define portFLAGS_INT_ENABLED			( ( portSTACK_TYPE ) 0x08 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Each task maintains a count of the critical section nesting depth.  Each

+time a critical section is entered the count is incremented.  Each time a

+critical section is exited the count is decremented - with interrupts only

+being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+void vPortSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned short *pusTopOfStack;

+unsigned long *pulTopOfStack, ulTemp;

+

+	/*

+		Place a few bytes of known values on the bottom of the stack.

+		This is just useful for debugging and can be included if required.

+

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;

+		pxTopOfStack--;

+	*/

+

+	/* Data types are need either 16 bits or 32 bits depending on the data 

+	and code model used. */

+	if( sizeof( pxCode ) == sizeof( unsigned short ) )

+	{

+		pusTopOfStack = ( unsigned short * ) pxTopOfStack;

+		ulTemp = ( unsigned long ) pxCode;

+		*pusTopOfStack = ( unsigned short ) ulTemp;

+	}

+	else

+	{

+		/* Make room for a 20 bit value stored as a 32 bit value. */

+		pusTopOfStack = ( unsigned short * ) pxTopOfStack;		

+		pusTopOfStack--;

+		pulTopOfStack = ( unsigned long * ) pusTopOfStack;

+		*pulTopOfStack = ( unsigned long ) pxCode;

+	}

+

+	pusTopOfStack--;

+	*pusTopOfStack = portFLAGS_INT_ENABLED;

+	pusTopOfStack -= ( sizeof( portSTACK_TYPE ) / 2 );

+	

+	/* From here on the size of stacked items depends on the memory model. */

+	pxTopOfStack = ( portSTACK_TYPE * ) pusTopOfStack;

+

+	/* Next the general purpose registers. */

+	#ifdef PRELOAD_REGISTER_VALUES

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xffff;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xdddd;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;

+		pxTopOfStack--;	

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;

+		pxTopOfStack--;

+	#else

+		pxTopOfStack -= 3;

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack -= 9;

+	#endif

+

+	/* A variable is used to keep track of the critical section nesting.

+	This variable has to be stored as part of the task context and is

+	initially set to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the MSP430 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.

+ */

+void vPortSetupTimerInterrupt( void )

+{

+	vApplicationSetupTimerInterrupt();

+}

+/*-----------------------------------------------------------*/

+

+#pragma vector=configTICK_VECTOR

+interrupt void vTickISREntry( void )

+{

+extern void vPortTickISR( void );

+

+	__bic_SR_register_on_exit( SCG1 + SCG0 + OSCOFF + CPUOFF );

+	#if configUSE_PREEMPTION == 1

+		extern void vPortPreemptiveTickISR( void );

+		vPortPreemptiveTickISR();

+	#else

+		extern void vPortCooperativeTickISR( void );

+		vPortCooperativeTickISR();

+	#endif

+}

+

+	

diff --git a/FreeRTOS/Source/portable/CCS/MSP430X/portext.asm b/FreeRTOS/Source/portable/CCS/MSP430X/portext.asm
new file mode 100644
index 0000000..092b525
--- /dev/null
+++ b/FreeRTOS/Source/portable/CCS/MSP430X/portext.asm
@@ -0,0 +1,184 @@
+;

+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+; * The definition of the "register test" tasks, as described at the top of

+; * main.c

+

+	.include data_model.h

+

+	.global vTaskIncrementTick

+	.global vTaskSwitchContext

+	.global vPortSetupTimerInterrupt

+	.global pxCurrentTCB

+	.global usCriticalNesting

+

+	.def vPortPreemptiveTickISR

+	.def vPortCooperativeTickISR

+	.def vPortYield

+	.def xPortStartScheduler

+

+;-----------------------------------------------------------

+

+portSAVE_CONTEXT .macro

+

+	;Save the remaining registers.

+	pushm_x	#12, r15

+	mov.w	&usCriticalNesting, r14

+	push_x r14

+	mov_x	&pxCurrentTCB, r12

+	mov_x	sp, 0( r12 )

+	.endm

+;-----------------------------------------------------------

+		

+portRESTORE_CONTEXT .macro

+

+	mov_x	&pxCurrentTCB, r12

+	mov_x	@r12, sp

+	pop_x	r15

+	mov.w	r15, &usCriticalNesting

+	popm_x	#12, r15

+	pop.w	sr

+	ret_x

+	.endm

+;-----------------------------------------------------------

+

+;*

+;* The RTOS tick ISR.

+;*

+;* If the cooperative scheduler is in use this simply increments the tick

+;* count.

+;*

+;* If the preemptive scheduler is in use a context switch can also occur.

+;*/

+	

+	.text

+	.align 2

+	

+vPortPreemptiveTickISR: .asmfunc

+	

+	; The sr is not saved in portSAVE_CONTEXT() because vPortYield() needs

+	;to save it manually before it gets modified (interrupts get disabled).

+	push.w sr

+	portSAVE_CONTEXT

+				

+	call_x	#vTaskIncrementTick

+	call_x	#vTaskSwitchContext

+		

+	portRESTORE_CONTEXT

+	.endasmfunc

+;-----------------------------------------------------------

+

+	.align 2

+	

+vPortCooperativeTickISR: .asmfunc

+	

+	; The sr is not saved in portSAVE_CONTEXT() because vPortYield() needs

+	;to save it manually before it gets modified (interrupts get disabled).

+	push.w sr

+	portSAVE_CONTEXT

+				

+	call_x	#vTaskIncrementTick

+		

+	portRESTORE_CONTEXT

+	

+	.endasmfunc

+;-----------------------------------------------------------

+

+;

+; Manual context switch called by the portYIELD() macro.

+;

+

+	.align 2

+

+vPortYield: .asmfunc

+

+	; The sr needs saving before it is modified.

+	push.w	sr

+	

+	; Now the SR is stacked we can disable interrupts.

+	dint	

+	nop

+				

+	; Save the context of the current task.

+	portSAVE_CONTEXT			

+

+	; Select the next task to run.

+	call_x	#vTaskSwitchContext		

+

+	; Restore the context of the new task.

+	portRESTORE_CONTEXT

+	.endasmfunc

+;-----------------------------------------------------------

+

+

+;

+; Start off the scheduler by initialising the RTOS tick timer, then restoring

+; the context of the first task.

+;

+

+	.align 2

+	

+xPortStartScheduler: .asmfunc

+

+	; Setup the hardware to generate the tick.  Interrupts are disabled

+	; when this function is called.

+	call_x	#vPortSetupTimerInterrupt

+

+	; Restore the context of the first task that is going to run.

+	portRESTORE_CONTEXT

+	.endasmfunc

+;-----------------------------------------------------------

+      		

+	.end

+		

diff --git a/FreeRTOS/Source/portable/CCS/MSP430X/portmacro.h b/FreeRTOS/Source/portable/CCS/MSP430X/portmacro.h
new file mode 100644
index 0000000..f0e1b98
--- /dev/null
+++ b/FreeRTOS/Source/portable/CCS/MSP430X/portmacro.h
@@ -0,0 +1,177 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+

+/* Hardware includes. */

+#include "msp430.h"

+

+/* Type definitions. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		int

+#define portBASE_TYPE	portSHORT

+

+/* The stack type changes depending on the data model. */

+#ifdef __LARGE_DATA_MODEL__

+	#define portSTACK_TYPE unsigned long

+#else

+	#define portSTACK_TYPE unsigned short

+#endif

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()	_disable_interrupt(); _nop()

+#define portENABLE_INTERRUPTS()		_enable_interrupt()

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned short usCriticalNesting;								\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled usCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned short usCriticalNesting;								\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.

+ */

+extern void vPortYield( void );

+#define portYIELD() vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )	

+#define portNOP()					__no_operation()	

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( x ) if( x ) vPortYield()

+	

+void vApplicationSetupTimerInterrupt( void );

+

+/* sizeof( int ) != sizeof( long ) so a full printf() library is required if

+run time stats information is to be displayed. */

+#define portLU_PRINTF_SPECIFIER_REQUIRED

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/port.c b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/port.c
new file mode 100644
index 0000000..354746c
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/port.c
@@ -0,0 +1,227 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+

+#define portINITIAL_FORMAT_VECTOR		( ( portSTACK_TYPE ) 0x4000 )

+

+/* Supervisor mode set. */

+#define portINITIAL_STATUS_REGISTER		( ( portSTACK_TYPE ) 0x2000)

+

+/* The clock prescale into the timer peripheral. */

+#define portPRESCALE_VALUE				( ( unsigned char ) 10 )

+

+/* The clock frequency into the RTC. */

+#define portRTC_CLOCK_HZ				( ( unsigned long ) 1000 )

+

+asm void interrupt VectorNumber_VL1swi vPortYieldISR( void );

+static void prvSetupTimerInterrupt( void );

+

+/* Used to keep track of the number of nested calls to taskENTER_CRITICAL().  This

+will be set to 0 prior to the first task being started. */

+static unsigned long ulCriticalNesting = 0x9999UL;

+

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+

+unsigned long ulOriginalA5;

+

+	__asm{ MOVE.L A5, ulOriginalA5 };

+

+

+	*pxTopOfStack = (portSTACK_TYPE) 0xDEADBEEF;

+	pxTopOfStack--;

+

+	/* Exception stack frame starts with the return address. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portINITIAL_FORMAT_VECTOR << 16UL ) | ( portINITIAL_STATUS_REGISTER );

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0; /*FP*/

+	pxTopOfStack -= 14; /* A5 to D0. */

+

+	/* Parameter in A0. */

+	*( pxTopOfStack + 8 ) = ( portSTACK_TYPE ) pvParameters;

+

+	/* A5 must be maintained as it is resurved by the compiler. */

+	*( pxTopOfStack + 13 ) = ulOriginalA5;

+

+	return pxTopOfStack;  

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	ulCriticalNesting = 0UL;

+

+	/* Configure a timer to generate the tick interrupt. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task executing. */

+	vPortStartFirstTask();

+

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{				

+	/* Prescale by 1 - ie no prescale. */

+	RTCSC |= 8;

+	

+	/* Compare match value. */

+	RTCMOD = portRTC_CLOCK_HZ / configTICK_RATE_HZ;

+	

+	/* Enable the RTC to generate interrupts - interrupts are already disabled

+	when this code executes. */

+	RTCSC_RTIE = 1;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	if( ulCriticalNesting == 0UL )

+	{

+		/* Guard against context switches being pended simultaneously with a

+		critical section being entered. */

+		do

+		{

+			portDISABLE_INTERRUPTS();

+			if( INTC_FRC == 0UL )

+			{

+				break;

+			}

+

+			portENABLE_INTERRUPTS();

+

+		} while( 1 );

+	}

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	ulCriticalNesting--;

+	if( ulCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldHandler( void )

+{

+unsigned long ulSavedInterruptMask;

+

+	ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		/* Note this will clear all forced interrupts - this is done for speed. */

+		INTC_CFRC = 0x3E;

+		vTaskSwitchContext();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );

+}

+/*-----------------------------------------------------------*/

+

+void interrupt VectorNumber_Vrtc vPortTickISR( void )

+{

+unsigned long ulSavedInterruptMask;

+

+	/* Clear the interrupt. */

+	RTCSC |= RTCSC_RTIF_MASK;

+

+	/* Increment the RTOS tick. */

+	ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );

+

+	/* If we are using the pre-emptive scheduler then also request a

+	context switch as incrementing the tick could have unblocked a task. */

+	#if configUSE_PREEMPTION == 1

+	{

+		taskYIELD();

+	}

+	#endif

+}

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portasm.S b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portasm.S
new file mode 100644
index 0000000..04b4173
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portasm.S
@@ -0,0 +1,169 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * Purpose: Lowest level routines for all ColdFire processors.

+ *

+ * Notes:

+ * 

+ * ulPortSetIPL() and mcf5xxx_wr_cacr() copied with permission from FreeScale

+ * supplied source files.

+ */

+

+    .global ulPortSetIPL

+    .global _ulPortSetIPL

+    .global mcf5xxx_wr_cacrx

+    .global _mcf5xxx_wr_cacrx

+    .global vPortYieldISR

+    .global _vPortYieldISR

+    .global vPortStartFirstTask

+    .global _vPortStartFirstTask

+    .extern _pxCurrentTCB

+    .extern _vPortYieldHandler

+

+    .text

+

+.macro portSAVE_CONTEXT

+

+	lea.l		(-60, sp), sp

+	movem.l		d0-a6, (sp)

+	move.l		_pxCurrentTCB, a0

+	move.l		sp, (a0)

+

+	.endm

+

+.macro portRESTORE_CONTEXT

+

+	move.l		_pxCurrentTCB, a0

+	move.l		(a0), sp

+	movem.l		(sp), d0-a6

+	lea.l		(60, sp), sp

+	rte

+

+	.endm

+

+/********************************************************************/

+/*

+ * This routines changes the IPL to the value passed into the routine.

+ * It also returns the old IPL value back.

+ * Calling convention from C:

+ *   old_ipl = asm_set_ipl(new_ipl);

+ * For the Diab Data C compiler, it passes return value thru D0.

+ * Note that only the least significant three bits of the passed

+ * value are used.

+ */

+

+ulPortSetIPL:

+_ulPortSetIPL:

+    link    A6,#-8

+    movem.l D6-D7,(SP)

+

+    move.w  SR,D7       /* current sr    */

+

+    move.l  D7,D6       /* prepare return value  */

+    andi.l  #0x0700,D6  /* mask out IPL  */

+    lsr.l   #8,D6       /* IPL   */

+

+    andi.l  #0x07,D0    /* least significant three bits  */

+    lsl.l   #8,D0       /* move over to make mask    */

+

+    andi.l  #0x0000F8FF,D7  /* zero out current IPL  */

+    or.l    D0,D7           /* place new IPL in sr   */

+    move.w  D7,SR

+

+	move.l	D6, D0		/* Return value in D0. */

+    movem.l (SP),D6-D7

+    lea     8(SP),SP

+    unlk    A6

+    rts

+/********************************************************************/

+

+mcf5xxx_wr_cacrx:

+_mcf5xxx_wr_cacrx:

+    move.l  4(sp),d0

+    .long   0x4e7b0002  /* movec d0,cacr   */

+    nop

+    rts

+

+/********************************************************************/

+

+/* Yield interrupt. */

+_vPortYieldISR:

+vPortYieldISR:

+	portSAVE_CONTEXT

+	jsr _vPortYieldHandler

+	portRESTORE_CONTEXT

+

+/********************************************************************/

+

+

+vPortStartFirstTask:

+_vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+    .end

+

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portmacro.h b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portmacro.h
new file mode 100644
index 0000000..11227d1
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			4

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+/*-----------------------------------------------------------*/

+

+unsigned portLONG ulPortSetIPL( unsigned portLONG );

+#define portDISABLE_INTERRUPTS()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portENABLE_INTERRUPTS()		ulPortSetIPL( 0 )

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+extern unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR( void );

+extern void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE );

+#define portSET_INTERRUPT_MASK_FROM_ISR()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusRegister ) ulPortSetIPL( uxSavedStatusRegister )

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+#define portNOP()	asm volatile ( "nop" )

+

+/* Context switches are requested using the force register. */

+#define portYIELD()	INTC_SFRC = 0x3E; portNOP(); portNOP(); portNOP(); portNOP(); portNOP()

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters ) __attribute__((noreturn))

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+#define portEND_SWITCHING_ISR( xSwitchRequired )	if( xSwitchRequired != pdFALSE )	\

+													{									\

+														portYIELD();					\

+													}

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/port.c b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/port.c
new file mode 100644
index 0000000..f8d149e
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/port.c
@@ -0,0 +1,186 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+

+#define portINITIAL_FORMAT_VECTOR		( ( portSTACK_TYPE ) 0x4000 )

+

+/* Supervisor mode set. */

+#define portINITIAL_STATUS_REGISTER		( ( portSTACK_TYPE ) 0x2000)

+

+/* Used to keep track of the number of nested calls to taskENTER_CRITICAL().  This

+will be set to 0 prior to the first task being started. */

+static unsigned long ulCriticalNesting = 0x9999UL;

+

+

+#define portSAVE_CONTEXT()				\

+	lea.l		(-60, %sp), %sp;		\

+	movem.l		%d0-%fp, (%sp);			\

+	move.l		pxCurrentTCB, %a0;		\

+	move.l		%sp, (%a0);

+

+#define portRESTORE_CONTEXT()			\

+	move.l		pxCurrentTCB, %a0;		\

+	move.l		(%a0), %sp;				\

+	movem.l		(%sp), %d0-%fp;			\

+	lea.l		%sp@(60), %sp;			\

+	rte

+

+

+

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) 0xDEADBEEF;

+	pxTopOfStack--;

+

+	/* Exception stack frame starts with the return address. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portINITIAL_FORMAT_VECTOR << 16UL ) | ( portINITIAL_STATUS_REGISTER );

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0; /*FP*/

+	pxTopOfStack -= 14; /* A5 to D0. */

+

+    return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	ulCriticalNesting = 0UL;

+

+	/* Configure the interrupts used by this port. */

+	vApplicationSetupInterrupts();

+

+	/* Start the first task executing. */

+	vPortStartFirstTask();

+

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	if( ulCriticalNesting == 0UL )

+	{

+		/* Guard against context switches being pended simultaneously with a

+		critical section being entered. */

+		do

+		{

+			portDISABLE_INTERRUPTS();

+			if( MCF_INTC0_INTFRCH == 0UL )

+			{

+				break;

+			}

+

+			portENABLE_INTERRUPTS();

+

+		} while( 1 );

+	}

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	ulCriticalNesting--;

+	if( ulCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldHandler( void )

+{

+unsigned long ulSavedInterruptMask;

+

+	ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();

+		/* Note this will clear all forced interrupts - this is done for speed. */

+		MCF_INTC0_INTFRCL = 0;

+		vTaskSwitchContext();

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portasm.S b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portasm.S
new file mode 100644
index 0000000..eeada6c
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portasm.S
@@ -0,0 +1,169 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * Purpose: Lowest level routines for all ColdFire processors.

+ *

+ * Notes:

+ * 

+ * ulPortSetIPL() and mcf5xxx_wr_cacr() copied with permission from FreeScale

+ * supplied source files.

+ */

+

+    .global ulPortSetIPL

+    .global _ulPortSetIPL

+    .global mcf5xxx_wr_cacrx

+    .global _mcf5xxx_wr_cacrx

+    .global vPortYieldISR

+    .global _vPortYieldISR

+    .global vPortStartFirstTask

+    .global _vPortStartFirstTask

+    .extern _pxCurrentTCB

+    .extern _vPortYieldHandler

+

+    .text

+

+.macro portSAVE_CONTEXT

+

+	lea.l		(-60, sp), sp

+	movem.l		d0-a6, (sp)

+	move.l		_pxCurrentTCB, a0

+	move.l		sp, (a0)

+

+	.endm

+

+.macro portRESTORE_CONTEXT

+

+	move.l		_pxCurrentTCB, a0

+	move.l		(a0), sp

+	movem.l		(sp), d0-a6

+	lea.l		(60, sp), sp

+	rte

+

+	.endm

+

+/********************************************************************/

+/*

+ * This routines changes the IPL to the value passed into the routine.

+ * It also returns the old IPL value back.

+ * Calling convention from C:

+ *   old_ipl = asm_set_ipl(new_ipl);

+ * For the Diab Data C compiler, it passes return value thru D0.

+ * Note that only the least significant three bits of the passed

+ * value are used.

+ */

+

+ulPortSetIPL:

+_ulPortSetIPL:

+    link    A6,#-8

+    movem.l D6-D7,(SP)

+

+    move.w  SR,D7       /* current sr    */

+

+    move.l  D7,D0       /* prepare return value  */

+    andi.l  #0x0700,D0  /* mask out IPL  */

+    lsr.l   #8,D0       /* IPL   */

+

+    move.l  8(A6),D6    /* get argument  */

+    andi.l  #0x07,D6    /* least significant three bits  */

+    lsl.l   #8,D6       /* move over to make mask    */

+

+    andi.l  #0x0000F8FF,D7  /* zero out current IPL  */

+    or.l    D6,D7           /* place new IPL in sr   */

+    move.w  D7,SR

+

+    movem.l (SP),D6-D7

+    lea     8(SP),SP

+    unlk    A6

+    rts

+/********************************************************************/

+

+mcf5xxx_wr_cacrx:

+_mcf5xxx_wr_cacrx:

+    move.l  4(sp),d0

+    .long   0x4e7b0002  /* movec d0,cacr   */

+    nop

+    rts

+

+/********************************************************************/

+

+/* Yield interrupt. */

+_vPortYieldISR:

+vPortYieldISR:

+	portSAVE_CONTEXT

+	jsr _vPortYieldHandler

+	portRESTORE_CONTEXT

+

+/********************************************************************/

+

+

+vPortStartFirstTask:

+_vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+    .end

+

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portmacro.h b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portmacro.h
new file mode 100644
index 0000000..215b62d
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/ColdFire_V2/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			4

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+/*-----------------------------------------------------------*/

+unsigned portLONG ulPortSetIPL( unsigned portLONG );

+#define portDISABLE_INTERRUPTS()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portENABLE_INTERRUPTS()		ulPortSetIPL( 0 )

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+extern unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR( void );

+extern void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE );

+#define portSET_INTERRUPT_MASK_FROM_ISR()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusRegister ) ulPortSetIPL( uxSavedStatusRegister )

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+#define portNOP()	asm volatile ( 	"nop" )

+

+/* Note this will overwrite all other bits in the force register, it is done this way for speed. */

+#define portYIELD()			MCF_INTC0_INTFRCL = ( 1UL << configYIELD_INTERRUPT_VECTOR ); portNOP(); portNOP() /* -32 as we are using the high word of the 64bit mask. */

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters ) __attribute__((noreturn))

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+#define portEND_SWITCHING_ISR( xSwitchRequired )	if( xSwitchRequired != pdFALSE )	\

+													{									\

+														portYIELD();					\

+													}

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/HCS12/port.c b/FreeRTOS/Source/portable/CodeWarrior/HCS12/port.c
new file mode 100644
index 0000000..212ec5d
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/HCS12/port.c
@@ -0,0 +1,277 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the HCS12 port.

+ *----------------------------------------------------------*/

+

+

+/*

+ * Configure a timer to generate the RTOS tick at the frequency specified 

+ * within FreeRTOSConfig.h.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/* Interrupt service routines have to be in non-banked memory - as does the

+scheduler startup function. */

+#pragma CODE_SEG __NEAR_SEG NON_BANKED

+

+	/* Manual context switch function.  This is the SWI ISR. */

+	void interrupt vPortYield( void );

+

+	/* Tick context switch function.  This is the timer ISR. */

+	void interrupt vPortTickInterrupt( void );

+	

+	/* Simply called by xPortStartScheduler().  xPortStartScheduler() does not

+	start the scheduler directly because the header file containing the 

+	xPortStartScheduler() prototype is part of the common kernel code, and 

+	therefore cannot use the CODE_SEG pragma. */

+	static portBASE_TYPE xBankedStartScheduler( void );

+

+#pragma CODE_SEG DEFAULT

+

+/* Calls to portENTER_CRITICAL() can be nested.  When they are nested the 

+critical section should not be left (i.e. interrupts should not be re-enabled)

+until the nesting depth reaches 0.  This variable simply tracks the nesting 

+depth.  Each task maintains it's own critical nesting depth variable so 

+uxCriticalNesting is saved and restored from the task stack during a context

+switch. */

+volatile unsigned portBASE_TYPE uxCriticalNesting = 0xff;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* 

+		Place a few bytes of known values on the bottom of the stack.

+		This can be uncommented to provide useful stack markers when debugging.

+

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x11;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x22;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x33;

+		pxTopOfStack--;

+	*/

+

+

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro.  In this case the stack as

+	expected by the HCS12 RTI instruction. */

+

+

+	/* The address of the task function is placed in the stack byte at a time. */

+	*pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pxCode) ) + 1 );

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pxCode) ) + 0 );

+	pxTopOfStack--;

+

+	/* Next are all the registers that form part of the task context. */

+

+	/* Y register */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xff;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xee;

+	pxTopOfStack--;

+

+	/* X register */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xdd;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xcc;

+	pxTopOfStack--;

+ 

+	/* A register contains parameter high byte. */

+	*pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pvParameters) ) + 0 );

+	pxTopOfStack--;

+

+	/* B register contains parameter low byte. */

+	*pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pvParameters) ) + 1 );

+	pxTopOfStack--;

+

+	/* CCR: Note that when the task starts interrupts will be enabled since

+	"I" bit of CCR is cleared */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;

+	pxTopOfStack--;

+	

+	#ifdef BANKED_MODEL

+		/* The page of the task. */

+		*pxTopOfStack = ( portSTACK_TYPE ) ( ( int ) pxCode );

+		pxTopOfStack--;

+	#endif

+	

+	/* Finally the critical nesting depth is initialised with 0 (not within

+	a critical section). */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the HCS12 port will get stopped. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	TickTimer_SetFreqHz( configTICK_RATE_HZ );

+	TickTimer_Enable();

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* xPortStartScheduler() does not start the scheduler directly because 

+	the header file containing the xPortStartScheduler() prototype is part 

+	of the common kernel code, and therefore cannot use the CODE_SEG pragma. 

+	Instead it simply calls the locally defined xBankedStartScheduler() - 

+	which does use the CODE_SEG pragma. */

+

+	return xBankedStartScheduler();

+}

+/*-----------------------------------------------------------*/

+

+#pragma CODE_SEG __NEAR_SEG NON_BANKED

+

+static portBASE_TYPE xBankedStartScheduler( void )

+{

+	/* Configure the timer that will generate the RTOS tick.  Interrupts are

+	disabled when this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task. */

+	portRESTORE_CONTEXT();

+

+	/* Simulate the end of an interrupt to start the scheduler off. */

+	__asm( "rti" );

+

+	/* Should not get here! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Context switch functions.  These are both interrupt service routines.

+ */

+

+/*

+ * Manual context switch forced by calling portYIELD().  This is the SWI

+ * handler.

+ */

+void interrupt vPortYield( void )

+{

+	portSAVE_CONTEXT();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * RTOS tick interrupt service routine.  If the cooperative scheduler is 

+ * being used then this simply increments the tick count.  If the 

+ * preemptive scheduler is being used a context switch can occur.

+ */

+void interrupt vPortTickInterrupt( void )

+{

+	#if configUSE_PREEMPTION == 1

+	{

+		/* A context switch might happen so save the context. */

+		portSAVE_CONTEXT();

+

+		/* Increment the tick ... */

+		vTaskIncrementTick();

+

+		/* ... then see if the new tick value has necessitated a

+		context switch. */

+		vTaskSwitchContext();

+

+		TFLG1 = 1;								   

+

+		/* Restore the context of a task - which may be a different task

+		to that interrupted. */

+		portRESTORE_CONTEXT();	

+	}

+	#else

+	{

+		vTaskIncrementTick();

+		TFLG1 = 1;

+	}

+	#endif

+}

+

+#pragma CODE_SEG DEFAULT

+

+

diff --git a/FreeRTOS/Source/portable/CodeWarrior/HCS12/portmacro.h b/FreeRTOS/Source/portable/CodeWarrior/HCS12/portmacro.h
new file mode 100644
index 0000000..96035f1
--- /dev/null
+++ b/FreeRTOS/Source/portable/CodeWarrior/HCS12/portmacro.h
@@ -0,0 +1,237 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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	unsigned portCHAR

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			1

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portYIELD()					__asm( "swi" );

+#define portNOP()					__asm( "nop" );

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENABLE_INTERRUPTS()				__asm( "cli" )	

+#define portDISABLE_INTERRUPTS()			__asm( "sei" )

+

+/*

+ * Disable interrupts before incrementing the count of critical section nesting.

+ * The nesting count is maintained so we know when interrupts should be

+ * re-enabled.  Once interrupts are disabled the nesting count can be accessed

+ * directly.  Each task maintains its own nesting count.

+ */

+#define portENTER_CRITICAL()  									\

+{																\

+	extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																\

+	portDISABLE_INTERRUPTS();									\

+	uxCriticalNesting++;										\

+}

+

+/*

+ * Interrupts are disabled so we can access the nesting count directly.  If the

+ * nesting is found to be 0 (no nesting) then we are leaving the critical 

+ * section and interrupts can be re-enabled.

+ */

+#define  portEXIT_CRITICAL()									\

+{																\

+	extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																\

+	uxCriticalNesting--;										\

+	if( uxCriticalNesting == 0 )								\

+	{															\

+		portENABLE_INTERRUPTS();								\

+	}															\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/* 

+ * These macros are very simple as the processor automatically saves and 

+ * restores its registers as interrupts are entered and exited.  In

+ * addition to the (automatically stacked) registers we also stack the 

+ * critical nesting count.  Each task maintains its own critical nesting

+ * count as it is legitimate for a task to yield from within a critical

+ * section.  If the banked memory model is being used then the PPAGE

+ * register is also stored as part of the tasks context.

+ */

+

+#ifdef BANKED_MODEL

+	/* 

+	 * Load the stack pointer for the task, then pull the critical nesting

+	 * count and PPAGE register from the stack.  The remains of the 

+	 * context are restored by the RTI instruction.

+	 */

+	#define portRESTORE_CONTEXT()									\

+	{																\

+		extern volatile void * pxCurrentTCB;						\

+		extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																	\

+		__asm( "ldx pxCurrentTCB" );								\

+		__asm( "lds 0, x" );										\

+		__asm( "pula" );											\

+		__asm( "staa uxCriticalNesting" );							\

+		__asm( "pula" );											\

+		__asm( "staa 0x30" ); /* 0x30 = PPAGE */					\

+	}

+

+	/* 

+	 * By the time this macro is called the processor has already stacked the

+	 * registers.  Simply stack the nesting count and PPAGE value, then save 

+	 * the task stack pointer.

+	 */

+	#define portSAVE_CONTEXT()										\

+	{																\

+		extern volatile void * pxCurrentTCB;						\

+		extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																	\

+		__asm( "ldaa 0x30" );  /* 0x30 = PPAGE */					\

+		__asm( "psha" );											\

+		__asm( "ldaa uxCriticalNesting" );							\

+		__asm( "psha" );											\

+		__asm( "ldx pxCurrentTCB" );								\

+		__asm( "sts 0, x" );										\

+	}

+#else

+

+	/* 

+	 * These macros are as per the BANKED versions above, but without saving

+	 * and restoring the PPAGE register.

+	 */

+

+	#define portRESTORE_CONTEXT()									\

+	{																\

+		extern volatile void * pxCurrentTCB;						\

+		extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																	\

+		__asm( "ldx pxCurrentTCB" );								\

+		__asm( "lds 0, x" );										\

+		__asm( "pula" );											\

+		__asm( "staa uxCriticalNesting" );							\

+	}

+

+	#define portSAVE_CONTEXT()										\

+	{																\

+		extern volatile void * pxCurrentTCB;						\

+		extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																	\

+		__asm( "ldaa uxCriticalNesting" );							\

+		__asm( "psha" );											\

+		__asm( "ldx pxCurrentTCB" );								\

+		__asm( "sts 0, x" );										\

+	}

+#endif

+

+/*

+ * Utility macro to call macros above in correct order in order to perform a

+ * task switch from within a standard ISR.  This macro can only be used if

+ * the ISR does not use any local (stack) variables.  If the ISR uses stack

+ * variables portYIELD() should be used in it's place.

+ */

+#define portTASK_SWITCH_FROM_ISR()								\

+	portSAVE_CONTEXT();											\

+	vTaskSwitchContext();										\

+	portRESTORE_CONTEXT();

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/port.c b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/port.c
new file mode 100644
index 0000000..5948ac3
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/port.c
@@ -0,0 +1,277 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Atmel AT91R40008

+ * port.

+ *

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in this file.  The ISR routines, which can only be compiled

+ * to ARM mode are contained in portISR.c.

+ *----------------------------------------------------------*/

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Hardware specific definitions. */

+#include "AT91R40008.h"

+#include "pio.h"

+#include "aic.h"

+#include "tc.h"

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+#define portNO_CRITICAL_SECTION_NESTING	( ( portSTACK_TYPE ) 0 )

+#define portTICK_PRIORITY_6				( 6 )

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * The scheduler can only be started from ARM mode, so 

+ * vPortISRStartFirstSTask() is defined in portISR.c. 

+ */

+extern void vPortISRStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+	

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The last thing onto the stack is the status register, which is set for

+	system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	#ifdef THUMB_INTERWORK

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+	#endif

+

+	pxTopOfStack--;

+

+	/* Some optimisation levels use the stack differently to others.  This 

+	means the interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_SECTION_NESTING;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortISRStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the tick timer to generate the tick interrupts at the required frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+volatile unsigned long ulDummy;

+

+	/* Enable clock to the tick timer... */

+	AT91C_BASE_PS->PS_PCER = portTIMER_CLK_ENABLE_BIT;

+

+	/* Stop the tick timer... */

+	portTIMER_REG_BASE_PTR->TC_CCR = TC_CLKDIS;

+

+	/* Start with tick timer interrupts disabled... */

+	portTIMER_REG_BASE_PTR->TC_IDR = 0xFFFFFFFF;

+

+	/* Clear any pending tick timer interrupts... */

+	ulDummy = portTIMER_REG_BASE_PTR->TC_SR;

+

+	/* Store interrupt handler function address in tick timer vector register...

+	The ISR installed depends on whether the preemptive or cooperative

+	scheduler is being used. */

+	#if configUSE_PREEMPTION == 1

+	{

+		extern void ( vPreemptiveTick )( void );

+		AT91C_BASE_AIC->AIC_SVR[portTIMER_AIC_CHANNEL] = ( unsigned long ) vPreemptiveTick;

+	}

+	#else  // else use cooperative scheduler

+	{

+		extern void ( vNonPreemptiveTick )( void );

+		AT91C_BASE_AIC->AIC_SVR[portTIMER_AIC_CHANNEL] = ( unsigned long ) vNonPreemptiveTick;

+	}

+	#endif

+

+	/* Tick timer interrupt level-sensitive, priority 6... */

+	AT91C_BASE_AIC->AIC_SMR[ portTIMER_AIC_CHANNEL ] = AIC_SRCTYPE_INT_LEVEL_SENSITIVE | portTICK_PRIORITY_6;

+

+	/* Enable the tick timer interrupt...

+

+	First at timer level */

+	portTIMER_REG_BASE_PTR->TC_IER = TC_CPCS;

+

+	/* Then at the AIC level. */

+	AT91C_BASE_AIC->AIC_IECR = (1 << portTIMER_AIC_CHANNEL);

+

+	/* Calculate timer compare value to achieve the desired tick rate... */

+	if( (configCPU_CLOCK_HZ / (configTICK_RATE_HZ * 2) ) <= 0xFFFF )

+	{

+		/* The tick rate is fast enough for us to use the faster timer input

+		clock (main clock / 2). */

+		portTIMER_REG_BASE_PTR->TC_CMR = TC_WAVE | TC_CLKS_MCK2 | TC_BURST_NONE | TC_CPCTRG;

+		portTIMER_REG_BASE_PTR->TC_RC  = configCPU_CLOCK_HZ / (configTICK_RATE_HZ * 2);

+	}

+	else

+	{

+		/* We must use a slower timer input clock (main clock / 8) because the

+		tick rate is too slow for the faster input clock. */

+		portTIMER_REG_BASE_PTR->TC_CMR = TC_WAVE | TC_CLKS_MCK8 | TC_BURST_NONE | TC_CPCTRG;

+		portTIMER_REG_BASE_PTR->TC_RC  = configCPU_CLOCK_HZ / (configTICK_RATE_HZ * 8);

+	}

+

+	/* Start tick timer... */

+	portTIMER_REG_BASE_PTR->TC_CCR = TC_SWTRG | TC_CLKEN;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portISR.c b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portISR.c
new file mode 100644
index 0000000..8699ce4
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portISR.c
@@ -0,0 +1,270 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in port.c  The ISR routines, which can only be compiled

+ * to ARM mode, are contained in this file.

+ *----------------------------------------------------------*/

+

+/*

+	Changes from V3.2.4

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to handle interrupts. */

+#define portCLEAR_AIC_INTERRUPT		( ( unsigned long ) 0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING		( ( unsigned long ) 0 )

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* ISR to handle manual context switches (from a call to taskYIELD()). */

+void vPortYieldProcessor( void ) __attribute__((interrupt("SWI"), naked));

+

+/* 

+ * The scheduler can only be started from ARM mode, hence the inclusion of this

+ * function here.

+ */

+void vPortISRStartFirstTask( void );

+/*-----------------------------------------------------------*/

+

+void vPortISRStartFirstTask( void )

+{

+	/* Simply start the scheduler.  This is included here as it can only be

+	called from ARM mode. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Called by portYIELD() or taskYIELD() to manually force a context switch.

+ *

+ * When a context switch is performed from the task level the saved task 

+ * context is made to look as if it occurred from within the tick ISR.  This

+ * way the same restore context function can be used when restoring the context

+ * saved from the ISR or that saved from a call to vPortYieldProcessor.

+ */

+void vPortYieldProcessor( void )

+{

+	/* Within an IRQ ISR the link register has an offset from the true return 

+	address, but an SWI ISR does not.  Add the offset manually so the same 

+	ISR return code can be used in both cases. */

+	asm volatile ( "ADD		LR, LR, #4" );

+

+	/* Perform the context switch.  First save the context of the current task. */

+	portSAVE_CONTEXT();

+

+	/* Find the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();	

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+

+#if configUSE_PREEMPTION == 0

+

+	/* The cooperative scheduler requires a normal IRQ service routine to 

+	simply increment the system tick. */

+	void vNonPreemptiveTick( void ) __attribute__ ((interrupt ("IRQ")));

+	void vNonPreemptiveTick( void )

+	{		

+	static volatile unsigned long ulDummy;

+

+		/* Clear tick timer interrupt indication. */

+		ulDummy = portTIMER_REG_BASE_PTR->TC_SR;  

+

+		vTaskIncrementTick();

+

+		/* Acknowledge the interrupt at AIC level... */

+		AT91C_BASE_AIC->AIC_EOICR = portCLEAR_AIC_INTERRUPT;

+	}

+

+#else  /* else preemption is turned on */

+

+	/* The preemptive scheduler is defined as "naked" as the full context is

+	saved on entry as part of the context switch. */

+	void vPreemptiveTick( void ) __attribute__((naked));

+	void vPreemptiveTick( void )

+	{

+		/* Save the context of the interrupted task. */

+		portSAVE_CONTEXT();	

+

+		/* WARNING - Do not use local (stack) variables here.  Use globals

+					 if you must! */

+		static volatile unsigned long ulDummy;

+

+		/* Clear tick timer interrupt indication. */

+		ulDummy = portTIMER_REG_BASE_PTR->TC_SR;  

+

+		/* Increment the RTOS tick count, then look for the highest priority 

+		task that is ready to run. */

+		vTaskIncrementTick();

+		vTaskSwitchContext();

+

+		/* Acknowledge the interrupt at AIC level... */

+		AT91C_BASE_AIC->AIC_EOICR = portCLEAR_AIC_INTERRUPT;

+

+		/* Restore the context of the new task. */

+		portRESTORE_CONTEXT();

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions here to

+ * ensure a switch to ARM mode.  When THUMB_INTERWORK is not defined then

+ * the utilities are defined as macros in portmacro.h - as per other ports.

+ */

+#ifdef THUMB_INTERWORK

+

+	void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	void vPortDisableInterruptsFromThumb( void )

+	{

+		asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.						*/

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+			

+	void vPortEnableInterruptsFromThumb( void )

+	{

+		asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/	

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/	

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.							*/	

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/	

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+

+#endif /* THUMB_INTERWORK */

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	asm volatile ( 

+		"STMDB	SP!, {R0}			\n\t"	/* Push R0.								*/

+		"MRS	R0, CPSR			\n\t"	/* Get CPSR.							*/

+		"ORR	R0, R0, #0xC0		\n\t"	/* Disable IRQ, FIQ.					*/

+		"MSR	CPSR, R0			\n\t"	/* Write back modified value.			*/

+		"LDMIA	SP!, {R0}" );				/* Pop R0.								*/

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL().				*/

+			asm volatile ( 

+				"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	

+				"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	

+				"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	

+				"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	

+				"LDMIA	SP!, {R0}" );			/* Pop R0.						*/

+		}

+	}

+}

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portmacro.h
new file mode 100644
index 0000000..c31aae2
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91FR40008/portmacro.h
@@ -0,0 +1,290 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+	Changes from V3.2.3

+	

+	+ Modified portENTER_SWITCHING_ISR() to allow use with GCC V4.0.1.

+

+	Changes from V3.2.4

+

+	+ Removed the use of the %0 parameter within the assembler macros and 

+	  replaced them with hard coded registers.  This will ensure the

+	  assembler does not select the link register as the temp register as

+	  was occasionally happening previously.

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+

+	Changes from V4.5.0

+

+	+ Removed the portENTER_SWITCHING_ISR() and portEXIT_SWITCHING_ISR() macros

+	  and replaced them with portYIELD_FROM_ISR() macro.  Application code 

+	  should now make use of the portSAVE_CONTEXT() and portRESTORE_CONTEXT()

+	  macros as per the V4.5.1 demo code.

+*/

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm volatile ( "SWI 0" )

+#define portNOP()					asm volatile ( "NOP" )

+

+/*

+ * These define the timer to use for generating the tick interrupt.

+ * They are put in this file so they can be shared between "port.c"

+ * and "portisr.c".

+ */

+#define portTIMER_REG_BASE_PTR		AT91C_BASE_TC0

+#define portTIMER_CLK_ENABLE_BIT	AT91C_PS_TC0

+#define portTIMER_AIC_CHANNEL		( ( unsigned portLONG ) 4 )

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+

+/*

+ * portRESTORE_CONTEXT, portRESTORE_CONTEXT, portENTER_SWITCHING_ISR

+ * and portEXIT_SWITCHING_ISR can only be called from ARM mode, but

+ * are included here for efficiency.  An attempt to call one from

+ * THUMB mode code will result in a compile time error.

+ */

+

+#define portRESTORE_CONTEXT()											\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Set the LR to the task stack. */									\

+	asm volatile (														\

+	"LDR		R0, =pxCurrentTCB								\n\t"	\

+	"LDR		R0, [R0]										\n\t"	\

+	"LDR		LR, [R0]										\n\t"	\

+																		\

+	/* The critical nesting depth is the first item on the stack. */	\

+	/* Load it into the ulCriticalNesting variable. */					\

+	"LDR		R0, =ulCriticalNesting							\n\t"	\

+	"LDMFD	LR!, {R1}											\n\t"	\

+	"STR		R1, [R0]										\n\t"	\

+																		\

+	/* Get the SPSR from the stack. */									\

+	"LDMFD	LR!, {R0}											\n\t"	\

+	"MSR		SPSR, R0										\n\t"	\

+																		\

+	/* Restore all system mode registers for the task. */				\

+	"LDMFD	LR, {R0-R14}^										\n\t"	\

+	"NOP														\n\t"	\

+																		\

+	/* Restore the return address. */									\

+	"LDR		LR, [LR, #+60]									\n\t"	\

+																		\

+	/* And return - correcting the offset in the LR to obtain the */	\

+	/* correct address. */												\

+	"SUBS	PC, LR, #4											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+/*-----------------------------------------------------------*/

+

+#define portSAVE_CONTEXT()												\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Push R0 as we are going to use the register. */					\

+	asm volatile (														\

+	"STMDB	SP!, {R0}											\n\t"	\

+																		\

+	/* Set R0 to point to the task stack pointer. */					\

+	"STMDB	SP,{SP}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	SP, SP, #4											\n\t"	\

+	"LDMIA	SP!,{R0}											\n\t"	\

+																		\

+	/* Push the return address onto the stack. */						\

+	"STMDB	R0!, {LR}											\n\t"	\

+																		\

+	/* Now we have saved LR we can use it instead of R0. */				\

+	"MOV	LR, R0												\n\t"	\

+																		\

+	/* Pop R0 so we can save it onto the system mode stack. */			\

+	"LDMIA	SP!, {R0}											\n\t"	\

+																		\

+	/* Push all the system mode registers onto the task stack. */		\

+	"STMDB	LR,{R0-LR}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	LR, LR, #60											\n\t"	\

+																		\

+	/* Push the SPSR onto the task stack. */							\

+	"MRS	R0, SPSR											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	"LDR	R0, =ulCriticalNesting								\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	/* Store the new top of stack for the task. */						\

+	"LDR	R0, =pxCurrentTCB									\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STR	LR, [R0]											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+

+#define portYIELD_FROM_ISR() vTaskSwitchContext()

+

+/* Critical section handling. */

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions in 

+ * portISR.c to ensure a switch to ARM mode.  When THUMB_INTERWORK is not 

+ * defined then the utilities are defined as macros here - as per other ports.

+ */

+

+#ifdef THUMB_INTERWORK

+

+	extern void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	extern void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()

+	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

+	

+#else

+

+	#define portDISABLE_INTERRUPTS()											\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.			*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+			

+	#define portENABLE_INTERRUPTS()												\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+

+#endif /* THUMB_INTERWORK */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/AT91SAM7X256.h b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/AT91SAM7X256.h
new file mode 100644
index 0000000..a14279e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/AT91SAM7X256.h
@@ -0,0 +1,2731 @@
+//  ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+//  ----------------------------------------------------------------------------

+//  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//  ----------------------------------------------------------------------------

+// File Name           : AT91SAM7X256.h

+// Object              : AT91SAM7X256 definitions

+// Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+// 

+// CVS Reference       : /AT91SAM7X256.pl/1.11/Tue May 10 12:15:32 2005//

+// CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+//  ----------------------------------------------------------------------------

+

+#ifndef AT91SAM7X256_H

+#define AT91SAM7X256_H

+

+typedef volatile unsigned int AT91_REG;// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+typedef struct _AT91S_SYS {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+	AT91_REG	 Reserved2[45]; 	// 

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved3[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved4[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+	AT91_REG	 Reserved5[54]; 	// 

+	AT91_REG	 PIOA_PER; 	// PIO Enable Register

+	AT91_REG	 PIOA_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOA_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved6[1]; 	// 

+	AT91_REG	 PIOA_OER; 	// Output Enable Register

+	AT91_REG	 PIOA_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOA_OSR; 	// Output Status Register

+	AT91_REG	 Reserved7[1]; 	// 

+	AT91_REG	 PIOA_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOA_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOA_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved8[1]; 	// 

+	AT91_REG	 PIOA_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOA_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOA_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOA_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOA_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOA_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOA_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOA_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOA_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOA_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOA_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved9[1]; 	// 

+	AT91_REG	 PIOA_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOA_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOA_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved10[1]; 	// 

+	AT91_REG	 PIOA_ASR; 	// Select A Register

+	AT91_REG	 PIOA_BSR; 	// Select B Register

+	AT91_REG	 PIOA_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved11[9]; 	// 

+	AT91_REG	 PIOA_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOA_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOA_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved12[85]; 	// 

+	AT91_REG	 PIOB_PER; 	// PIO Enable Register

+	AT91_REG	 PIOB_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOB_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved13[1]; 	// 

+	AT91_REG	 PIOB_OER; 	// Output Enable Register

+	AT91_REG	 PIOB_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOB_OSR; 	// Output Status Register

+	AT91_REG	 Reserved14[1]; 	// 

+	AT91_REG	 PIOB_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOB_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOB_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved15[1]; 	// 

+	AT91_REG	 PIOB_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOB_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOB_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOB_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOB_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOB_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOB_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOB_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOB_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOB_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOB_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved16[1]; 	// 

+	AT91_REG	 PIOB_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOB_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOB_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved17[1]; 	// 

+	AT91_REG	 PIOB_ASR; 	// Select A Register

+	AT91_REG	 PIOB_BSR; 	// Select B Register

+	AT91_REG	 PIOB_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved18[9]; 	// 

+	AT91_REG	 PIOB_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOB_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOB_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved19[341]; 	// 

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved20[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved21[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved22[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved23[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved24[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved25[36]; 	// 

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+	AT91_REG	 Reserved26[5]; 	// 

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+	AT91_REG	 Reserved27[5]; 	// 

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_SYS, *AT91PS_SYS;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+typedef struct _AT91S_AIC {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+} AT91S_AIC, *AT91PS_AIC;

+

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR       ((unsigned int) 0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               ((unsigned int) 0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              ((unsigned int) 0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE     ((unsigned int) 0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       ((unsigned int) 0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        ((unsigned int) 0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           ((unsigned int) 0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        ((unsigned int) 0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ        ((unsigned int) 0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ        ((unsigned int) 0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT    ((unsigned int) 0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK    ((unsigned int) 0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+typedef struct _AT91S_PDC {

+	AT91_REG	 PDC_RPR; 	// Receive Pointer Register

+	AT91_REG	 PDC_RCR; 	// Receive Counter Register

+	AT91_REG	 PDC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 PDC_TCR; 	// Transmit Counter Register

+	AT91_REG	 PDC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 PDC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 PDC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 PDC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 PDC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 PDC_PTSR; 	// PDC Transfer Status Register

+} AT91S_PDC, *AT91PS_PDC;

+

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN       ((unsigned int) 0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS      ((unsigned int) 0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN       ((unsigned int) 0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS      ((unsigned int) 0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+typedef struct _AT91S_DBGU {

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved0[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved1[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+} AT91S_DBGU, *AT91PS_DBGU;

+

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX        ((unsigned int) 0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX        ((unsigned int) 0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN         ((unsigned int) 0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS        ((unsigned int) 0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN         ((unsigned int) 0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS        ((unsigned int) 0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA       ((unsigned int) 0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR          ((unsigned int) 0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 ((unsigned int) 0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  ((unsigned int) 0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                ((unsigned int) 0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 ((unsigned int) 0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 ((unsigned int) 0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           ((unsigned int) 0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE       ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY        ((unsigned int) 0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY        ((unsigned int) 0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX        ((unsigned int) 0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX        ((unsigned int) 0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE         ((unsigned int) 0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME        ((unsigned int) 0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE         ((unsigned int) 0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY      ((unsigned int) 0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE       ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF       ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX      ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX      ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST  ((unsigned int) 0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+typedef struct _AT91S_PIO {

+	AT91_REG	 PIO_PER; 	// PIO Enable Register

+	AT91_REG	 PIO_PDR; 	// PIO Disable Register

+	AT91_REG	 PIO_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PIO_OER; 	// Output Enable Register

+	AT91_REG	 PIO_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIO_OSR; 	// Output Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PIO_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIO_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIO_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PIO_SODR; 	// Set Output Data Register

+	AT91_REG	 PIO_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIO_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIO_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIO_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIO_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIO_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIO_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIO_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIO_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIO_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved3[1]; 	// 

+	AT91_REG	 PIO_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIO_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIO_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved4[1]; 	// 

+	AT91_REG	 PIO_ASR; 	// Select A Register

+	AT91_REG	 PIO_BSR; 	// Select B Register

+	AT91_REG	 PIO_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved5[9]; 	// 

+	AT91_REG	 PIO_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIO_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIO_OWSR; 	// Output Write Status Register

+} AT91S_PIO, *AT91PS_PIO;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+typedef struct _AT91S_CKGR {

+	AT91_REG	 CKGR_MOR; 	// Main Oscillator Register

+	AT91_REG	 CKGR_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 CKGR_PLLR; 	// PLL Register

+} AT91S_CKGR, *AT91PS_CKGR;

+

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN     ((unsigned int) 0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS  ((unsigned int) 0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT    ((unsigned int) 0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF      ((unsigned int) 0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY    ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV        ((unsigned int) 0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    ((unsigned int) 0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               ((unsigned int) 0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT   ((unsigned int) 0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT        ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL        ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV     ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+typedef struct _AT91S_PMC {

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved3[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved4[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+} AT91S_PMC, *AT91PS_PMC;

+

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK         ((unsigned int) 0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP         ((unsigned int) 0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0        ((unsigned int) 0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1        ((unsigned int) 0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2        ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3        ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS         ((unsigned int) 0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             ((unsigned int) 0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             ((unsigned int) 0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              ((unsigned int) 0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES        ((unsigned int) 0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  ((unsigned int) 0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                ((unsigned int) 0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                ((unsigned int) 0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                ((unsigned int) 0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               ((unsigned int) 0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               ((unsigned int) 0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               ((unsigned int) 0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS       ((unsigned int) 0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK        ((unsigned int) 0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY      ((unsigned int) 0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY     ((unsigned int) 0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY     ((unsigned int) 0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY     ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY     ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RSTC {

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+} AT91S_RSTC, *AT91PS_RSTC;

+

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST    ((unsigned int) 0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST     ((unsigned int) 0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST     ((unsigned int) 0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY        ((unsigned int) 0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS      ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS     ((unsigned int) 0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP     ((unsigned int) 0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              ((unsigned int) 0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               ((unsigned int) 0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             ((unsigned int) 0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             ((unsigned int) 0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 ((unsigned int) 0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             ((unsigned int) 0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL      ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP      ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN     ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN    ((unsigned int) 0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL      ((unsigned int) 0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN     ((unsigned int) 0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RTTC {

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+} AT91S_RTTC, *AT91PS_RTTC;

+

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES     ((unsigned int) 0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN     ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN  ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST     ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV       ((unsigned int) 0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV       ((unsigned int) 0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS       ((unsigned int) 0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC     ((unsigned int) 0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PITC {

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+} AT91S_PITC, *AT91PS_PITC;

+

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV        ((unsigned int) 0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN      ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN     ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS       ((unsigned int) 0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV       ((unsigned int) 0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT      ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_WDTC {

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+} AT91S_WDTC, *AT91PS_WDTC;

+

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT     ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY        ((unsigned int) 0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV        ((unsigned int) 0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN     ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN    ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC    ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS      ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD        ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT   ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT  ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF      ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR      ((unsigned int) 0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_VREG {

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_VREG, *AT91PS_VREG;

+

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY     ((unsigned int) 0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_MC {

+	AT91_REG	 MC_RCR; 	// MC Remap Control Register

+	AT91_REG	 MC_ASR; 	// MC Abort Status Register

+	AT91_REG	 MC_AASR; 	// MC Abort Address Status Register

+	AT91_REG	 Reserved0[21]; 	// 

+	AT91_REG	 MC_FMR; 	// MC Flash Mode Register

+	AT91_REG	 MC_FCR; 	// MC Flash Command Register

+	AT91_REG	 MC_FSR; 	// MC Flash Status Register

+} AT91S_MC, *AT91PS_MC;

+

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB          ((unsigned int) 0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD       ((unsigned int) 0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD       ((unsigned int) 0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ        ((unsigned int) 0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 ((unsigned int) 0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                ((unsigned int) 0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 ((unsigned int) 0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP       ((unsigned int) 0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                ((unsigned int) 0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                ((unsigned int) 0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                ((unsigned int) 0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0         ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1         ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0       ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1       ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY         ((unsigned int) 0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE        ((unsigned int) 0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE        ((unsigned int) 0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP         ((unsigned int) 0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS          ((unsigned int) 0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 ((unsigned int) 0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 ((unsigned int) 0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 ((unsigned int) 0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 ((unsigned int) 0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN         ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD         ((unsigned int) 0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         ((unsigned int) 0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN        ((unsigned int) 0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY          ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY     ((unsigned int) 0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0       ((unsigned int) 0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1       ((unsigned int) 0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2       ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3       ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4       ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5       ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6       ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7       ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0       ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1       ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2       ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3       ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4       ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5       ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6       ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7       ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8       ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9       ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10      ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11      ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12      ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13      ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14      ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15      ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+typedef struct _AT91S_SPI {

+	AT91_REG	 SPI_CR; 	// Control Register

+	AT91_REG	 SPI_MR; 	// Mode Register

+	AT91_REG	 SPI_RDR; 	// Receive Data Register

+	AT91_REG	 SPI_TDR; 	// Transmit Data Register

+	AT91_REG	 SPI_SR; 	// Status Register

+	AT91_REG	 SPI_IER; 	// Interrupt Enable Register

+	AT91_REG	 SPI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SPI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91_REG	 SPI_CSR[4]; 	// Chip Select Register

+	AT91_REG	 Reserved1[48]; 	// 

+	AT91_REG	 SPI_RPR; 	// Receive Pointer Register

+	AT91_REG	 SPI_RCR; 	// Receive Counter Register

+	AT91_REG	 SPI_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SPI_TCR; 	// Transmit Counter Register

+	AT91_REG	 SPI_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SPI_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SPI_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SPI_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SPI_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SPI_PTSR; 	// PDC Transfer Status Register

+} AT91S_SPI, *AT91PS_SPI;

+

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN       ((unsigned int) 0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS      ((unsigned int) 0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST       ((unsigned int) 0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER    ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR        ((unsigned int) 0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS          ((unsigned int) 0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                ((unsigned int) 0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             ((unsigned int) 0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC      ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV        ((unsigned int) 0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS     ((unsigned int) 0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB         ((unsigned int) 0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS         ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD          ((unsigned int) 0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD          ((unsigned int) 0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF        ((unsigned int) 0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE        ((unsigned int) 0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF        ((unsigned int) 0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES       ((unsigned int) 0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX       ((unsigned int) 0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX       ((unsigned int) 0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF      ((unsigned int) 0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE      ((unsigned int) 0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR        ((unsigned int) 0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY     ((unsigned int) 0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS      ((unsigned int) 0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL        ((unsigned int) 0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA       ((unsigned int) 0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT       ((unsigned int) 0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS        ((unsigned int) 0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    ((unsigned int) 0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    ((unsigned int) 0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   ((unsigned int) 0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   ((unsigned int) 0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   ((unsigned int) 0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   ((unsigned int) 0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   ((unsigned int) 0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   ((unsigned int) 0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   ((unsigned int) 0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR        ((unsigned int) 0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS       ((unsigned int) 0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+typedef struct _AT91S_USART {

+	AT91_REG	 US_CR; 	// Control Register

+	AT91_REG	 US_MR; 	// Mode Register

+	AT91_REG	 US_IER; 	// Interrupt Enable Register

+	AT91_REG	 US_IDR; 	// Interrupt Disable Register

+	AT91_REG	 US_IMR; 	// Interrupt Mask Register

+	AT91_REG	 US_CSR; 	// Channel Status Register

+	AT91_REG	 US_RHR; 	// Receiver Holding Register

+	AT91_REG	 US_THR; 	// Transmitter Holding Register

+	AT91_REG	 US_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 US_RTOR; 	// Receiver Time-out Register

+	AT91_REG	 US_TTGR; 	// Transmitter Time-guard Register

+	AT91_REG	 Reserved0[5]; 	// 

+	AT91_REG	 US_FIDI; 	// FI_DI_Ratio Register

+	AT91_REG	 US_NER; 	// Nb Errors Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 US_IF; 	// IRDA_FILTER Register

+	AT91_REG	 Reserved2[44]; 	// 

+	AT91_REG	 US_RPR; 	// Receive Pointer Register

+	AT91_REG	 US_RCR; 	// Receive Counter Register

+	AT91_REG	 US_TPR; 	// Transmit Pointer Register

+	AT91_REG	 US_TCR; 	// Transmit Counter Register

+	AT91_REG	 US_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 US_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 US_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 US_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 US_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 US_PTSR; 	// PDC Transfer Status Register

+} AT91S_USART, *AT91PS_USART;

+

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK       ((unsigned int) 0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK       ((unsigned int) 0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO        ((unsigned int) 0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA        ((unsigned int) 0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT        ((unsigned int) 0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK      ((unsigned int) 0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO        ((unsigned int) 0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN        ((unsigned int) 0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS       ((unsigned int) 0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN        ((unsigned int) 0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS       ((unsigned int) 0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE       ((unsigned int) 0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               ((unsigned int) 0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                ((unsigned int) 0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                ((unsigned int) 0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                ((unsigned int) 0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            ((unsigned int) 0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            ((unsigned int) 0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 ((unsigned int) 0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                ((unsigned int) 0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS         ((unsigned int) 0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                ((unsigned int) 0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                ((unsigned int) 0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 ((unsigned int) 0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  ((unsigned int) 0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL         ((unsigned int) 0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               ((unsigned int) 0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               ((unsigned int) 0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               ((unsigned int) 0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               ((unsigned int) 0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC         ((unsigned int) 0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP       ((unsigned int) 0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                ((unsigned int) 0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               ((unsigned int) 0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                ((unsigned int) 0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF         ((unsigned int) 0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9        ((unsigned int) 0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO         ((unsigned int) 0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER         ((unsigned int) 0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK        ((unsigned int) 0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK       ((unsigned int) 0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER     ((unsigned int) 0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER       ((unsigned int) 0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK        ((unsigned int) 0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT      ((unsigned int) 0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION    ((unsigned int) 0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK         ((unsigned int) 0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC         ((unsigned int) 0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC        ((unsigned int) 0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC        ((unsigned int) 0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC        ((unsigned int) 0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI           ((unsigned int) 0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR          ((unsigned int) 0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD          ((unsigned int) 0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS          ((unsigned int) 0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_SSC {

+	AT91_REG	 SSC_CR; 	// Control Register

+	AT91_REG	 SSC_CMR; 	// Clock Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SSC_RCMR; 	// Receive Clock ModeRegister

+	AT91_REG	 SSC_RFMR; 	// Receive Frame Mode Register

+	AT91_REG	 SSC_TCMR; 	// Transmit Clock Mode Register

+	AT91_REG	 SSC_TFMR; 	// Transmit Frame Mode Register

+	AT91_REG	 SSC_RHR; 	// Receive Holding Register

+	AT91_REG	 SSC_THR; 	// Transmit Holding Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 SSC_RSHR; 	// Receive Sync Holding Register

+	AT91_REG	 SSC_TSHR; 	// Transmit Sync Holding Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 SSC_SR; 	// Status Register

+	AT91_REG	 SSC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SSC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SSC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved3[44]; 	// 

+	AT91_REG	 SSC_RPR; 	// Receive Pointer Register

+	AT91_REG	 SSC_RCR; 	// Receive Counter Register

+	AT91_REG	 SSC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SSC_TCR; 	// Transmit Counter Register

+	AT91_REG	 SSC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SSC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SSC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SSC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SSC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SSC_PTSR; 	// PDC Transfer Status Register

+} AT91S_SSC, *AT91PS_SSC;

+

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN        ((unsigned int) 0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS       ((unsigned int) 0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN        ((unsigned int) 0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS       ((unsigned int) 0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST       ((unsigned int) 0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS         ((unsigned int) 0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  ((unsigned int) 0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   ((unsigned int) 0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   ((unsigned int) 0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO         ((unsigned int) 0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 ((unsigned int) 0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            ((unsigned int) 0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              ((unsigned int) 0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI         ((unsigned int) 0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START       ((unsigned int) 0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            ((unsigned int) 0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   ((unsigned int) 0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               ((unsigned int) 0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              ((unsigned int) 0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              ((unsigned int) 0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              ((unsigned int) 0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             ((unsigned int) 0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              ((unsigned int) 0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    ((unsigned int) 0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY      ((unsigned int) 0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD      ((unsigned int) 0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN      ((unsigned int) 0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP        ((unsigned int) 0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF        ((unsigned int) 0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB       ((unsigned int) 0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN       ((unsigned int) 0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS        ((unsigned int) 0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 ((unsigned int) 0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             ((unsigned int) 0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             ((unsigned int) 0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  ((unsigned int) 0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 ((unsigned int) 0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               ((unsigned int) 0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE      ((unsigned int) 0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF      ((unsigned int) 0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN       ((unsigned int) 0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY       ((unsigned int) 0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY     ((unsigned int) 0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX       ((unsigned int) 0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE      ((unsigned int) 0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY       ((unsigned int) 0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN       ((unsigned int) 0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX       ((unsigned int) 0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF      ((unsigned int) 0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN       ((unsigned int) 0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN       ((unsigned int) 0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA       ((unsigned int) 0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA       ((unsigned int) 0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+typedef struct _AT91S_TWI {

+	AT91_REG	 TWI_CR; 	// Control Register

+	AT91_REG	 TWI_MMR; 	// Master Mode Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 TWI_IADR; 	// Internal Address Register

+	AT91_REG	 TWI_CWGR; 	// Clock Waveform Generator Register

+	AT91_REG	 Reserved1[3]; 	// 

+	AT91_REG	 TWI_SR; 	// Status Register

+	AT91_REG	 TWI_IER; 	// Interrupt Enable Register

+	AT91_REG	 TWI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TWI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TWI_RHR; 	// Receive Holding Register

+	AT91_REG	 TWI_THR; 	// Transmit Holding Register

+} AT91S_TWI, *AT91PS_TWI;

+

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START       ((unsigned int) 0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP        ((unsigned int) 0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN        ((unsigned int) 0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS       ((unsigned int) 0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST       ((unsigned int) 0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ      ((unsigned int) 0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   ((unsigned int) 0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               ((unsigned int) 0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               ((unsigned int) 0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               ((unsigned int) 0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD       ((unsigned int) 0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR        ((unsigned int) 0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV       ((unsigned int) 0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV       ((unsigned int) 0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV       ((unsigned int) 0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP      ((unsigned int) 0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY       ((unsigned int) 0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY       ((unsigned int) 0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE        ((unsigned int) 0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE        ((unsigned int) 0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK        ((unsigned int) 0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC_CH {

+	AT91_REG	 PWMC_CMR; 	// Channel Mode Register

+	AT91_REG	 PWMC_CDTYR; 	// Channel Duty Cycle Register

+	AT91_REG	 PWMC_CPRDR; 	// Channel Period Register

+	AT91_REG	 PWMC_CCNTR; 	// Channel Counter Register

+	AT91_REG	 PWMC_CUPDR; 	// Channel Update Register

+	AT91_REG	 PWMC_Reserved[3]; 	// Reserved

+} AT91S_PWMC_CH, *AT91PS_PWMC_CH;

+

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE       ((unsigned int) 0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  ((unsigned int) 0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 ((unsigned int) 0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 ((unsigned int) 0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG       ((unsigned int) 0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL       ((unsigned int) 0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD        ((unsigned int) 0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC {

+	AT91_REG	 PWMC_MR; 	// PWMC Mode Register

+	AT91_REG	 PWMC_ENA; 	// PWMC Enable Register

+	AT91_REG	 PWMC_DIS; 	// PWMC Disable Register

+	AT91_REG	 PWMC_SR; 	// PWMC Status Register

+	AT91_REG	 PWMC_IER; 	// PWMC Interrupt Enable Register

+	AT91_REG	 PWMC_IDR; 	// PWMC Interrupt Disable Register

+	AT91_REG	 PWMC_IMR; 	// PWMC Interrupt Mask Register

+	AT91_REG	 PWMC_ISR; 	// PWMC Interrupt Status Register

+	AT91_REG	 Reserved0[55]; 	// 

+	AT91_REG	 PWMC_VR; 	// PWMC Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_PWMC_CH	 PWMC_CH[4]; 	// PWMC Channel

+} AT91S_PWMC, *AT91PS_PWMC;

+

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA       ((unsigned int) 0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA       ((unsigned int) 0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  ((unsigned int) 0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB       ((unsigned int) 0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB       ((unsigned int) 0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  ((unsigned int) 0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0      ((unsigned int) 0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1      ((unsigned int) 0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2      ((unsigned int) 0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3      ((unsigned int) 0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+typedef struct _AT91S_UDP {

+	AT91_REG	 UDP_NUM; 	// Frame Number Register

+	AT91_REG	 UDP_GLBSTATE; 	// Global State Register

+	AT91_REG	 UDP_FADDR; 	// Function Address Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 UDP_IER; 	// Interrupt Enable Register

+	AT91_REG	 UDP_IDR; 	// Interrupt Disable Register

+	AT91_REG	 UDP_IMR; 	// Interrupt Mask Register

+	AT91_REG	 UDP_ISR; 	// Interrupt Status Register

+	AT91_REG	 UDP_ICR; 	// Interrupt Clear Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 UDP_RSTEP; 	// Reset Endpoint Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 UDP_CSR[6]; 	// Endpoint Control and Status Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 UDP_FDR[6]; 	// Endpoint FIFO Data Register

+	AT91_REG	 Reserved4[3]; 	// 

+	AT91_REG	 UDP_TXVC; 	// Transceiver Control Register

+} AT91S_UDP, *AT91PS_UDP;

+

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM     ((unsigned int) 0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR     ((unsigned int) 0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK      ((unsigned int) 0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN      ((unsigned int) 0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG       ((unsigned int) 0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR         ((unsigned int) 0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR     ((unsigned int) 0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE      ((unsigned int) 0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD        ((unsigned int) 0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN         ((unsigned int) 0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0      ((unsigned int) 0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1      ((unsigned int) 0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2      ((unsigned int) 0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3      ((unsigned int) 0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4      ((unsigned int) 0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5      ((unsigned int) 0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP      ((unsigned int) 0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM       ((unsigned int) 0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM      ((unsigned int) 0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT      ((unsigned int) 0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP      ((unsigned int) 0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES   ((unsigned int) 0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0         ((unsigned int) 0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1         ((unsigned int) 0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2         ((unsigned int) 0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3         ((unsigned int) 0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4         ((unsigned int) 0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5         ((unsigned int) 0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP      ((unsigned int) 0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0 ((unsigned int) 0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP     ((unsigned int) 0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR    ((unsigned int) 0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY    ((unsigned int) 0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL  ((unsigned int) 0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1 ((unsigned int) 0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR         ((unsigned int) 0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE      ((unsigned int) 0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 ((unsigned int) 0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              ((unsigned int) 0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             ((unsigned int) 0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              ((unsigned int) 0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               ((unsigned int) 0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              ((unsigned int) 0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               ((unsigned int) 0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE       ((unsigned int) 0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS       ((unsigned int) 0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT   ((unsigned int) 0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS      ((unsigned int) 0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON        ((unsigned int) 0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_TC {

+	AT91_REG	 TC_CCR; 	// Channel Control Register

+	AT91_REG	 TC_CMR; 	// Channel Mode Register (Capture Mode / Waveform Mode)

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TC_CV; 	// Counter Value

+	AT91_REG	 TC_RA; 	// Register A

+	AT91_REG	 TC_RB; 	// Register B

+	AT91_REG	 TC_RC; 	// Register C

+	AT91_REG	 TC_SR; 	// Status Register

+	AT91_REG	 TC_IER; 	// Interrupt Enable Register

+	AT91_REG	 TC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TC_IMR; 	// Interrupt Mask Register

+} AT91S_TC, *AT91PS_TC;

+

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN        ((unsigned int) 0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS       ((unsigned int) 0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG        ((unsigned int) 0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS         ((unsigned int) 0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     ((unsigned int) 0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     ((unsigned int) 0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     ((unsigned int) 0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     ((unsigned int) 0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     ((unsigned int) 0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  ((unsigned int) 0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  ((unsigned int) 0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  ((unsigned int) 0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI         ((unsigned int) 0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST        ((unsigned int) 0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 ((unsigned int) 0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  ((unsigned int) 0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  ((unsigned int) 0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  ((unsigned int) 0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG      ((unsigned int) 0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG      ((unsigned int) 0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT         ((unsigned int) 0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 ((unsigned int) 0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  ((unsigned int) 0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  ((unsigned int) 0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  ((unsigned int) 0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG       ((unsigned int) 0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG       ((unsigned int) 0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL      ((unsigned int) 0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   ((unsigned int) 0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               ((unsigned int) 0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              ((unsigned int) 0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          ((unsigned int) 0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG       ((unsigned int) 0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE         ((unsigned int) 0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA         ((unsigned int) 0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  ((unsigned int) 0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                ((unsigned int) 0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               ((unsigned int) 0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA         ((unsigned int) 0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               ((unsigned int) 0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              ((unsigned int) 0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 ((unsigned int) 0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC         ((unsigned int) 0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 ((unsigned int) 0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  ((unsigned int) 0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                ((unsigned int) 0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               ((unsigned int) 0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB         ((unsigned int) 0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 ((unsigned int) 0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               ((unsigned int) 0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              ((unsigned int) 0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 ((unsigned int) 0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT        ((unsigned int) 0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 ((unsigned int) 0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  ((unsigned int) 0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                ((unsigned int) 0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               ((unsigned int) 0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG       ((unsigned int) 0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 ((unsigned int) 0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  ((unsigned int) 0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                ((unsigned int) 0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               ((unsigned int) 0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB         ((unsigned int) 0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 ((unsigned int) 0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  ((unsigned int) 0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                ((unsigned int) 0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               ((unsigned int) 0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC         ((unsigned int) 0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 ((unsigned int) 0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  ((unsigned int) 0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                ((unsigned int) 0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               ((unsigned int) 0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT        ((unsigned int) 0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 ((unsigned int) 0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  ((unsigned int) 0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                ((unsigned int) 0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               ((unsigned int) 0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG       ((unsigned int) 0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 ((unsigned int) 0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  ((unsigned int) 0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                ((unsigned int) 0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               ((unsigned int) 0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS        ((unsigned int) 0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS        ((unsigned int) 0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS         ((unsigned int) 0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS         ((unsigned int) 0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS         ((unsigned int) 0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS        ((unsigned int) 0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS        ((unsigned int) 0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS        ((unsigned int) 0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA       ((unsigned int) 0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA        ((unsigned int) 0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB        ((unsigned int) 0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+typedef struct _AT91S_TCB {

+	AT91S_TC	 TCB_TC0; 	// TC Channel 0

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91S_TC	 TCB_TC1; 	// TC Channel 1

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91S_TC	 TCB_TC2; 	// TC Channel 2

+	AT91_REG	 Reserved2[4]; 	// 

+	AT91_REG	 TCB_BCR; 	// TC Block Control Register

+	AT91_REG	 TCB_BMR; 	// TC Block Mode Register

+} AT91S_TCB, *AT91PS_TCB;

+

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC        ((unsigned int) 0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S     ((unsigned int) 0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                ((unsigned int) 0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 ((unsigned int) 0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                ((unsigned int) 0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                ((unsigned int) 0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S     ((unsigned int) 0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                ((unsigned int) 0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 ((unsigned int) 0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                ((unsigned int) 0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                ((unsigned int) 0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S     ((unsigned int) 0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                ((unsigned int) 0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 ((unsigned int) 0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                ((unsigned int) 0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                ((unsigned int) 0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN_MB {

+	AT91_REG	 CAN_MB_MMR; 	// MailBox Mode Register

+	AT91_REG	 CAN_MB_MAM; 	// MailBox Acceptance Mask Register

+	AT91_REG	 CAN_MB_MID; 	// MailBox ID Register

+	AT91_REG	 CAN_MB_MFID; 	// MailBox Family ID Register

+	AT91_REG	 CAN_MB_MSR; 	// MailBox Status Register

+	AT91_REG	 CAN_MB_MDL; 	// MailBox Data Low Register

+	AT91_REG	 CAN_MB_MDH; 	// MailBox Data High Register

+	AT91_REG	 CAN_MB_MCR; 	// MailBox Control Register

+} AT91S_CAN_MB, *AT91PS_CAN_MB;

+

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK   ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR       ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT         ((unsigned int) 0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  ((unsigned int) 0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   ((unsigned int) 0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          ((unsigned int) 0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   ((unsigned int) 0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             ((unsigned int) 0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             ((unsigned int) 0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB       ((unsigned int) 0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA       ((unsigned int) 0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE        ((unsigned int) 0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP  ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC        ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR        ((unsigned int) 0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT        ((unsigned int) 0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI         ((unsigned int) 0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR        ((unsigned int) 0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN {

+	AT91_REG	 CAN_MR; 	// Mode Register

+	AT91_REG	 CAN_IER; 	// Interrupt Enable Register

+	AT91_REG	 CAN_IDR; 	// Interrupt Disable Register

+	AT91_REG	 CAN_IMR; 	// Interrupt Mask Register

+	AT91_REG	 CAN_SR; 	// Status Register

+	AT91_REG	 CAN_BR; 	// Baudrate Register

+	AT91_REG	 CAN_TIM; 	// Timer Register

+	AT91_REG	 CAN_TIMESTP; 	// Time Stamp Register

+	AT91_REG	 CAN_ECR; 	// Error Counter Register

+	AT91_REG	 CAN_TCR; 	// Transfer Command Register

+	AT91_REG	 CAN_ACR; 	// Abort Command Register

+	AT91_REG	 Reserved0[52]; 	// 

+	AT91_REG	 CAN_VR; 	// Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_CAN_MB	 CAN_MB0; 	// CAN Mailbox 0

+	AT91S_CAN_MB	 CAN_MB1; 	// CAN Mailbox 1

+	AT91S_CAN_MB	 CAN_MB2; 	// CAN Mailbox 2

+	AT91S_CAN_MB	 CAN_MB3; 	// CAN Mailbox 3

+	AT91S_CAN_MB	 CAN_MB4; 	// CAN Mailbox 4

+	AT91S_CAN_MB	 CAN_MB5; 	// CAN Mailbox 5

+	AT91S_CAN_MB	 CAN_MB6; 	// CAN Mailbox 6

+	AT91S_CAN_MB	 CAN_MB7; 	// CAN Mailbox 7

+	AT91S_CAN_MB	 CAN_MB8; 	// CAN Mailbox 8

+	AT91S_CAN_MB	 CAN_MB9; 	// CAN Mailbox 9

+	AT91S_CAN_MB	 CAN_MB10; 	// CAN Mailbox 10

+	AT91S_CAN_MB	 CAN_MB11; 	// CAN Mailbox 11

+	AT91S_CAN_MB	 CAN_MB12; 	// CAN Mailbox 12

+	AT91S_CAN_MB	 CAN_MB13; 	// CAN Mailbox 13

+	AT91S_CAN_MB	 CAN_MB14; 	// CAN Mailbox 14

+	AT91S_CAN_MB	 CAN_MB15; 	// CAN Mailbox 15

+} AT91S_CAN, *AT91PS_CAN;

+

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN       ((unsigned int) 0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM         ((unsigned int) 0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM         ((unsigned int) 0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL         ((unsigned int) 0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF        ((unsigned int) 0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM         ((unsigned int) 0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ      ((unsigned int) 0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT        ((unsigned int) 0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0         ((unsigned int) 0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1         ((unsigned int) 0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2         ((unsigned int) 0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3         ((unsigned int) 0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4         ((unsigned int) 0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5         ((unsigned int) 0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6         ((unsigned int) 0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7         ((unsigned int) 0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8         ((unsigned int) 0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9         ((unsigned int) 0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10        ((unsigned int) 0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11        ((unsigned int) 0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12        ((unsigned int) 0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13        ((unsigned int) 0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14        ((unsigned int) 0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15        ((unsigned int) 0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA        ((unsigned int) 0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN        ((unsigned int) 0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP        ((unsigned int) 0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF        ((unsigned int) 0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP       ((unsigned int) 0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP      ((unsigned int) 0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF        ((unsigned int) 0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP        ((unsigned int) 0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR        ((unsigned int) 0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR        ((unsigned int) 0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR        ((unsigned int) 0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR        ((unsigned int) 0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR        ((unsigned int) 0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY        ((unsigned int) 0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY        ((unsigned int) 0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY        ((unsigned int) 0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2      ((unsigned int) 0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1      ((unsigned int) 0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG      ((unsigned int) 0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC        ((unsigned int) 0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP         ((unsigned int) 0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP         ((unsigned int) 0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER       ((unsigned int) 0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC         ((unsigned int) 0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC         ((unsigned int) 0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST      ((unsigned int) 0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+typedef struct _AT91S_EMAC {

+	AT91_REG	 EMAC_NCR; 	// Network Control Register

+	AT91_REG	 EMAC_NCFGR; 	// Network Configuration Register

+	AT91_REG	 EMAC_NSR; 	// Network Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 EMAC_TSR; 	// Transmit Status Register

+	AT91_REG	 EMAC_RBQP; 	// Receive Buffer Queue Pointer

+	AT91_REG	 EMAC_TBQP; 	// Transmit Buffer Queue Pointer

+	AT91_REG	 EMAC_RSR; 	// Receive Status Register

+	AT91_REG	 EMAC_ISR; 	// Interrupt Status Register

+	AT91_REG	 EMAC_IER; 	// Interrupt Enable Register

+	AT91_REG	 EMAC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 EMAC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 EMAC_MAN; 	// PHY Maintenance Register

+	AT91_REG	 EMAC_PTR; 	// Pause Time Register

+	AT91_REG	 EMAC_PFR; 	// Pause Frames received Register

+	AT91_REG	 EMAC_FTO; 	// Frames Transmitted OK Register

+	AT91_REG	 EMAC_SCF; 	// Single Collision Frame Register

+	AT91_REG	 EMAC_MCF; 	// Multiple Collision Frame Register

+	AT91_REG	 EMAC_FRO; 	// Frames Received OK Register

+	AT91_REG	 EMAC_FCSE; 	// Frame Check Sequence Error Register

+	AT91_REG	 EMAC_ALE; 	// Alignment Error Register

+	AT91_REG	 EMAC_DTF; 	// Deferred Transmission Frame Register

+	AT91_REG	 EMAC_LCOL; 	// Late Collision Register

+	AT91_REG	 EMAC_ECOL; 	// Excessive Collision Register

+	AT91_REG	 EMAC_TUND; 	// Transmit Underrun Error Register

+	AT91_REG	 EMAC_CSE; 	// Carrier Sense Error Register

+	AT91_REG	 EMAC_RRE; 	// Receive Ressource Error Register

+	AT91_REG	 EMAC_ROV; 	// Receive Overrun Errors Register

+	AT91_REG	 EMAC_RSE; 	// Receive Symbol Errors Register

+	AT91_REG	 EMAC_ELE; 	// Excessive Length Errors Register

+	AT91_REG	 EMAC_RJA; 	// Receive Jabbers Register

+	AT91_REG	 EMAC_USF; 	// Undersize Frames Register

+	AT91_REG	 EMAC_STE; 	// SQE Test Error Register

+	AT91_REG	 EMAC_RLE; 	// Receive Length Field Mismatch Register

+	AT91_REG	 EMAC_TPF; 	// Transmitted Pause Frames Register

+	AT91_REG	 EMAC_HRB; 	// Hash Address Bottom[31:0]

+	AT91_REG	 EMAC_HRT; 	// Hash Address Top[63:32]

+	AT91_REG	 EMAC_SA1L; 	// Specific Address 1 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA1H; 	// Specific Address 1 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA2L; 	// Specific Address 2 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA2H; 	// Specific Address 2 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA3L; 	// Specific Address 3 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA3H; 	// Specific Address 3 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA4L; 	// Specific Address 4 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA4H; 	// Specific Address 4 Top, Last 2 bytes

+	AT91_REG	 EMAC_TID; 	// Type ID Checking Register

+	AT91_REG	 EMAC_TPQ; 	// Transmit Pause Quantum Register

+	AT91_REG	 EMAC_USRIO; 	// USER Input/Output Register

+	AT91_REG	 EMAC_WOL; 	// Wake On LAN Register

+	AT91_REG	 Reserved1[13]; 	// 

+	AT91_REG	 EMAC_REV; 	// Revision Register

+} AT91S_EMAC, *AT91PS_EMAC;

+

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB         ((unsigned int) 0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB        ((unsigned int) 0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE         ((unsigned int) 0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE         ((unsigned int) 0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE        ((unsigned int) 0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT    ((unsigned int) 0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT    ((unsigned int) 0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT     ((unsigned int) 0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP         ((unsigned int) 0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART     ((unsigned int) 0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT      ((unsigned int) 0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR       ((unsigned int) 0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ        ((unsigned int) 0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD        ((unsigned int) 0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD         ((unsigned int) 0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME     ((unsigned int) 0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF        ((unsigned int) 0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC        ((unsigned int) 0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI        ((unsigned int) 0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI        ((unsigned int) 0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG        ((unsigned int) 0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE        ((unsigned int) 0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK        ((unsigned int) 0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               ((unsigned int) 0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              ((unsigned int) 0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              ((unsigned int) 0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              ((unsigned int) 0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY        ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE        ((unsigned int) 0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF       ((unsigned int) 0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             ((unsigned int) 0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             ((unsigned int) 0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             ((unsigned int) 0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             ((unsigned int) 0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE       ((unsigned int) 0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS      ((unsigned int) 0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD      ((unsigned int) 0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS     ((unsigned int) 0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR      ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO       ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE       ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES       ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO        ((unsigned int) 0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX        ((unsigned int) 0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND        ((unsigned int) 0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR        ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP      ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR      ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR      ((unsigned int) 0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR      ((unsigned int) 0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR      ((unsigned int) 0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP      ((unsigned int) 0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK       ((unsigned int) 0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR       ((unsigned int) 0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP      ((unsigned int) 0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE       ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ        ((unsigned int) 0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA       ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE       ((unsigned int) 0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA       ((unsigned int) 0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA       ((unsigned int) 0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW         ((unsigned int) 0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF        ((unsigned int) 0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII       ((unsigned int) 0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP         ((unsigned int) 0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG        ((unsigned int) 0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP        ((unsigned int) 0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1        ((unsigned int) 0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF     ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF    ((unsigned int) 0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+typedef struct _AT91S_ADC {

+	AT91_REG	 ADC_CR; 	// ADC Control Register

+	AT91_REG	 ADC_MR; 	// ADC Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 ADC_CHER; 	// ADC Channel Enable Register

+	AT91_REG	 ADC_CHDR; 	// ADC Channel Disable Register

+	AT91_REG	 ADC_CHSR; 	// ADC Channel Status Register

+	AT91_REG	 ADC_SR; 	// ADC Status Register

+	AT91_REG	 ADC_LCDR; 	// ADC Last Converted Data Register

+	AT91_REG	 ADC_IER; 	// ADC Interrupt Enable Register

+	AT91_REG	 ADC_IDR; 	// ADC Interrupt Disable Register

+	AT91_REG	 ADC_IMR; 	// ADC Interrupt Mask Register

+	AT91_REG	 ADC_CDR0; 	// ADC Channel Data Register 0

+	AT91_REG	 ADC_CDR1; 	// ADC Channel Data Register 1

+	AT91_REG	 ADC_CDR2; 	// ADC Channel Data Register 2

+	AT91_REG	 ADC_CDR3; 	// ADC Channel Data Register 3

+	AT91_REG	 ADC_CDR4; 	// ADC Channel Data Register 4

+	AT91_REG	 ADC_CDR5; 	// ADC Channel Data Register 5

+	AT91_REG	 ADC_CDR6; 	// ADC Channel Data Register 6

+	AT91_REG	 ADC_CDR7; 	// ADC Channel Data Register 7

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 ADC_RPR; 	// Receive Pointer Register

+	AT91_REG	 ADC_RCR; 	// Receive Counter Register

+	AT91_REG	 ADC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 ADC_TCR; 	// Transmit Counter Register

+	AT91_REG	 ADC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 ADC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 ADC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 ADC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 ADC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 ADC_PTSR; 	// PDC Transfer Status Register

+} AT91S_ADC, *AT91PS_ADC;

+

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST       ((unsigned int) 0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START       ((unsigned int) 0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN       ((unsigned int) 0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  ((unsigned int) 0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   ((unsigned int) 0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL      ((unsigned int) 0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                ((unsigned int) 0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                ((unsigned int) 0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                ((unsigned int) 0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                ((unsigned int) 0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                ((unsigned int) 0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                ((unsigned int) 0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  ((unsigned int) 0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES      ((unsigned int) 0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               ((unsigned int) 0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                ((unsigned int) 0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP       ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          ((unsigned int) 0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL     ((unsigned int) 0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP     ((unsigned int) 0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM       ((unsigned int) 0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0         ((unsigned int) 0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1         ((unsigned int) 0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2         ((unsigned int) 0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3         ((unsigned int) 0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4         ((unsigned int) 0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5         ((unsigned int) 0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6         ((unsigned int) 0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7         ((unsigned int) 0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0        ((unsigned int) 0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1        ((unsigned int) 0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2        ((unsigned int) 0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3        ((unsigned int) 0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4        ((unsigned int) 0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5        ((unsigned int) 0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6        ((unsigned int) 0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7        ((unsigned int) 0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0       ((unsigned int) 0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1       ((unsigned int) 0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2       ((unsigned int) 0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3       ((unsigned int) 0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4       ((unsigned int) 0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5       ((unsigned int) 0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6       ((unsigned int) 0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7       ((unsigned int) 0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY        ((unsigned int) 0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE       ((unsigned int) 0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX       ((unsigned int) 0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF      ((unsigned int) 0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA       ((unsigned int) 0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA        ((unsigned int) 0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_AES {

+	AT91_REG	 AES_CR; 	// Control Register

+	AT91_REG	 AES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AES_IER; 	// Interrupt Enable Register

+	AT91_REG	 AES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 AES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AES_ISR; 	// Interrupt Status Register

+	AT91_REG	 AES_KEYWxR[4]; 	// Key Word x Register

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91_REG	 AES_IDATAxR[4]; 	// Input Data x Register

+	AT91_REG	 AES_ODATAxR[4]; 	// Output Data x Register

+	AT91_REG	 AES_IVxR[4]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved2[35]; 	// 

+	AT91_REG	 AES_VR; 	// AES Version Register

+	AT91_REG	 AES_RPR; 	// Receive Pointer Register

+	AT91_REG	 AES_RCR; 	// Receive Counter Register

+	AT91_REG	 AES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 AES_TCR; 	// Transmit Counter Register

+	AT91_REG	 AES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 AES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 AES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 AES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 AES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 AES_PTSR; 	// PDC Transfer Status Register

+} AT91S_AES, *AT91PS_AES;

+

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START       ((unsigned int) 0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST       ((unsigned int) 0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED    ((unsigned int) 0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER      ((unsigned int) 0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY     ((unsigned int) 0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD        ((unsigned int) 0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD       ((unsigned int) 0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  ((unsigned int) 0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD         ((unsigned int) 0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS        ((unsigned int) 0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              ((unsigned int) 0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               ((unsigned int) 0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               ((unsigned int) 0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               ((unsigned int) 0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                ((unsigned int) 0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY        ((unsigned int) 0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE       ((unsigned int) 0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             ((unsigned int) 0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             ((unsigned int) 0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             ((unsigned int) 0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             ((unsigned int) 0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             ((unsigned int) 0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY      ((unsigned int) 0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX       ((unsigned int) 0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX       ((unsigned int) 0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF      ((unsigned int) 0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE      ((unsigned int) 0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD        ((unsigned int) 0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT        ((unsigned int) 0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  ((unsigned int) 0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY ((unsigned int) 0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          ((unsigned int) 0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_TDES {

+	AT91_REG	 TDES_CR; 	// Control Register

+	AT91_REG	 TDES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TDES_IER; 	// Interrupt Enable Register

+	AT91_REG	 TDES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TDES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TDES_ISR; 	// Interrupt Status Register

+	AT91_REG	 TDES_KEY1WxR[2]; 	// Key 1 Word x Register

+	AT91_REG	 TDES_KEY2WxR[2]; 	// Key 2 Word x Register

+	AT91_REG	 TDES_KEY3WxR[2]; 	// Key 3 Word x Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 TDES_IDATAxR[2]; 	// Input Data x Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 TDES_ODATAxR[2]; 	// Output Data x Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 TDES_IVxR[2]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved4[37]; 	// 

+	AT91_REG	 TDES_VR; 	// TDES Version Register

+	AT91_REG	 TDES_RPR; 	// Receive Pointer Register

+	AT91_REG	 TDES_RCR; 	// Receive Counter Register

+	AT91_REG	 TDES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 TDES_TCR; 	// Transmit Counter Register

+	AT91_REG	 TDES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 TDES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 TDES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 TDES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 TDES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 TDES_PTSR; 	// PDC Transfer Status Register

+} AT91S_TDES, *AT91PS_TDES;

+

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START      ((unsigned int) 0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST      ((unsigned int) 0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER     ((unsigned int) 0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD    ((unsigned int) 0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD     ((unsigned int) 0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD       ((unsigned int) 0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD      ((unsigned int) 0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD        ((unsigned int) 0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS       ((unsigned int) 0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               ((unsigned int) 0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               ((unsigned int) 0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               ((unsigned int) 0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                ((unsigned int) 0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY     ((unsigned int) 0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX      ((unsigned int) 0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX      ((unsigned int) 0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF     ((unsigned int) 0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE     ((unsigned int) 0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD       ((unsigned int) 0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT       ((unsigned int) 0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          ((unsigned int) 0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X256

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR   ((AT91_REG *) 	0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR   ((AT91_REG *) 	0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR   ((AT91_REG *) 	0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR   ((AT91_REG *) 	0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR ((AT91_REG *) 	0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR   ((AT91_REG *) 	0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR  ((AT91_REG *) 	0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR  ((AT91_REG *) 	0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR   ((AT91_REG *) 	0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR   ((AT91_REG *) 	0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR   ((AT91_REG *) 	0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER  ((AT91_REG *) 	0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR  ((AT91_REG *) 	0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR  ((AT91_REG *) 	0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR  ((AT91_REG *) 	0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR  ((AT91_REG *) 	0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR  ((AT91_REG *) 	0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU   ((AT91_REG *) 	0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR  ((AT91_REG *) 	0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR ((AT91_REG *) 	0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR ((AT91_REG *) 	0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR  ((AT91_REG *) 	0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR  ((AT91_REG *) 	0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR  ((AT91_REG *) 	0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR ((AT91_REG *) 	0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR ((AT91_REG *) 	0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR ((AT91_REG *) 	0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR ((AT91_REG *) 	0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID ((AT91_REG *) 	0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR ((AT91_REG *) 	0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR  ((AT91_REG *) 	0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR  ((AT91_REG *) 	0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR ((AT91_REG *) 	0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR   ((AT91_REG *) 	0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR  ((AT91_REG *) 	0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR   ((AT91_REG *) 	0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR ((AT91_REG *) 	0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR  ((AT91_REG *) 	0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR  ((AT91_REG *) 	0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER  ((AT91_REG *) 	0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR  ((AT91_REG *) 	0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR ((AT91_REG *) 	0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR  ((AT91_REG *) 	0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR ((AT91_REG *) 	0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER  ((AT91_REG *) 	0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR ((AT91_REG *) 	0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR  ((AT91_REG *) 	0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER  ((AT91_REG *) 	0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR ((AT91_REG *) 	0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR ((AT91_REG *) 	0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR ((AT91_REG *) 	0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR  ((AT91_REG *) 	0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR ((AT91_REG *) 	0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR ((AT91_REG *) 	0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR ((AT91_REG *) 	0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR  ((AT91_REG *) 	0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER ((AT91_REG *) 	0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER ((AT91_REG *) 	0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR ((AT91_REG *) 	0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER ((AT91_REG *) 	0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR  ((AT91_REG *) 	0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR  ((AT91_REG *) 	0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR ((AT91_REG *) 	0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR ((AT91_REG *) 	0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER ((AT91_REG *) 	0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR  ((AT91_REG *) 	0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR ((AT91_REG *) 	0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER  ((AT91_REG *) 	0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR  ((AT91_REG *) 	0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR ((AT91_REG *) 	0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER ((AT91_REG *) 	0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR ((AT91_REG *) 	0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR  ((AT91_REG *) 	0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR  ((AT91_REG *) 	0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR ((AT91_REG *) 	0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR  ((AT91_REG *) 	0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER  ((AT91_REG *) 	0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR ((AT91_REG *) 	0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER ((AT91_REG *) 	0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR ((AT91_REG *) 	0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR ((AT91_REG *) 	0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR ((AT91_REG *) 	0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR  ((AT91_REG *) 	0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR ((AT91_REG *) 	0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR  ((AT91_REG *) 	0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR  ((AT91_REG *) 	0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR ((AT91_REG *) 	0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER ((AT91_REG *) 	0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR ((AT91_REG *) 	0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR  ((AT91_REG *) 	0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR ((AT91_REG *) 	0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR  ((AT91_REG *) 	0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR ((AT91_REG *) 	0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER ((AT91_REG *) 	0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR  ((AT91_REG *) 	0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR ((AT91_REG *) 	0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER  ((AT91_REG *) 	0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER  ((AT91_REG *) 	0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR  ((AT91_REG *) 	0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR ((AT91_REG *) 	0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR ((AT91_REG *) 	0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR   ((AT91_REG *) 	0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR   ((AT91_REG *) 	0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR  ((AT91_REG *) 	0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER  ((AT91_REG *) 	0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR  ((AT91_REG *) 	0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR  ((AT91_REG *) 	0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR  ((AT91_REG *) 	0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR  ((AT91_REG *) 	0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR  ((AT91_REG *) 	0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR  ((AT91_REG *) 	0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR  ((AT91_REG *) 	0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER  ((AT91_REG *) 	0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR   ((AT91_REG *) 	0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER   ((AT91_REG *) 	0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR    ((AT91_REG *) 	0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR  ((AT91_REG *) 	0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR  ((AT91_REG *) 	0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR  ((AT91_REG *) 	0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR ((AT91_REG *) 	0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR ((AT91_REG *) 	0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR ((AT91_REG *) 	0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR ((AT91_REG *) 	0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR ((AT91_REG *) 	0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR ((AT91_REG *) 	0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR ((AT91_REG *) 	0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR ((AT91_REG *) 	0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR ((AT91_REG *) 	0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR ((AT91_REG *) 	0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR ((AT91_REG *) 	0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR   ((AT91_REG *) 	0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR    ((AT91_REG *) 	0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR    ((AT91_REG *) 	0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR    ((AT91_REG *) 	0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR   ((AT91_REG *) 	0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR    ((AT91_REG *) 	0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR    ((AT91_REG *) 	0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR ((AT91_REG *) 	0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR  ((AT91_REG *) 	0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR ((AT91_REG *) 	0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR  ((AT91_REG *) 	0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR ((AT91_REG *) 	0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR  ((AT91_REG *) 	0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR  ((AT91_REG *) 	0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR ((AT91_REG *) 	0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR ((AT91_REG *) 	0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR ((AT91_REG *) 	0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR  ((AT91_REG *) 	0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER  ((AT91_REG *) 	0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR   ((AT91_REG *) 	0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR  ((AT91_REG *) 	0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR  ((AT91_REG *) 	0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR   ((AT91_REG *) 	0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR  ((AT91_REG *) 	0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR   ((AT91_REG *) 	0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR  ((AT91_REG *) 	0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR ((AT91_REG *) 	0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR  ((AT91_REG *) 	0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR  ((AT91_REG *) 	0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR  ((AT91_REG *) 	0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR ((AT91_REG *) 	0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR ((AT91_REG *) 	0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR  ((AT91_REG *) 	0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR ((AT91_REG *) 	0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR ((AT91_REG *) 	0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR ((AT91_REG *) 	0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER  ((AT91_REG *) 	0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR   ((AT91_REG *) 	0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR  ((AT91_REG *) 	0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR   ((AT91_REG *) 	0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR   ((AT91_REG *) 	0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR  ((AT91_REG *) 	0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR  ((AT91_REG *) 	0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR  ((AT91_REG *) 	0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR  ((AT91_REG *) 	0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR  ((AT91_REG *) 	0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR  ((AT91_REG *) 	0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR   ((AT91_REG *) 	0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR  ((AT91_REG *) 	0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR  ((AT91_REG *) 	0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR   ((AT91_REG *) 	0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR  ((AT91_REG *) 	0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR   ((AT91_REG *) 	0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR  ((AT91_REG *) 	0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR   ((AT91_REG *) 	0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF    ((AT91_REG *) 	0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER   ((AT91_REG *) 	0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR  ((AT91_REG *) 	0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR   ((AT91_REG *) 	0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR   ((AT91_REG *) 	0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER   ((AT91_REG *) 	0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR   ((AT91_REG *) 	0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR  ((AT91_REG *) 	0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR   ((AT91_REG *) 	0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR  ((AT91_REG *) 	0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR   ((AT91_REG *) 	0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI  ((AT91_REG *) 	0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR    ((AT91_REG *) 	0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR    ((AT91_REG *) 	0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR  ((AT91_REG *) 	0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR  ((AT91_REG *) 	0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR   ((AT91_REG *) 	0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR  ((AT91_REG *) 	0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR  ((AT91_REG *) 	0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR  ((AT91_REG *) 	0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR   ((AT91_REG *) 	0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR   ((AT91_REG *) 	0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR   ((AT91_REG *) 	0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR  ((AT91_REG *) 	0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR  ((AT91_REG *) 	0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER   ((AT91_REG *) 	0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR    ((AT91_REG *) 	0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR   ((AT91_REG *) 	0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI  ((AT91_REG *) 	0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR  ((AT91_REG *) 	0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR    ((AT91_REG *) 	0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR  ((AT91_REG *) 	0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR   ((AT91_REG *) 	0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR   ((AT91_REG *) 	0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR   ((AT91_REG *) 	0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR   ((AT91_REG *) 	0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF    ((AT91_REG *) 	0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER   ((AT91_REG *) 	0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR  ((AT91_REG *) 	0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR   ((AT91_REG *) 	0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR  ((AT91_REG *) 	0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR   ((AT91_REG *) 	0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR  ((AT91_REG *) 	0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR   ((AT91_REG *) 	0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR   ((AT91_REG *) 	0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR  ((AT91_REG *) 	0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR  ((AT91_REG *) 	0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR  ((AT91_REG *) 	0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR   ((AT91_REG *) 	0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR  ((AT91_REG *) 	0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR  ((AT91_REG *) 	0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR   ((AT91_REG *) 	0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR   ((AT91_REG *) 	0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR  ((AT91_REG *) 	0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER   ((AT91_REG *) 	0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR  ((AT91_REG *) 	0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR    ((AT91_REG *) 	0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR   ((AT91_REG *) 	0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR  ((AT91_REG *) 	0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR    ((AT91_REG *) 	0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR   ((AT91_REG *) 	0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR  ((AT91_REG *) 	0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER   ((AT91_REG *) 	0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR    ((AT91_REG *) 	0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR    ((AT91_REG *) 	0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR   ((AT91_REG *) 	0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR   ((AT91_REG *) 	0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR   ((AT91_REG *) 	0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR  ((AT91_REG *) 	0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR   ((AT91_REG *) 	0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR  ((AT91_REG *) 	0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR   ((AT91_REG *) 	0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR ((AT91_REG *) 	0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved ((AT91_REG *) 	0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR ((AT91_REG *) 	0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR ((AT91_REG *) 	0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR ((AT91_REG *) 	0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR ((AT91_REG *) 	0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved ((AT91_REG *) 	0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR ((AT91_REG *) 	0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR ((AT91_REG *) 	0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR ((AT91_REG *) 	0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR ((AT91_REG *) 	0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR ((AT91_REG *) 	0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved ((AT91_REG *) 	0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR ((AT91_REG *) 	0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR ((AT91_REG *) 	0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR ((AT91_REG *) 	0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR ((AT91_REG *) 	0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR ((AT91_REG *) 	0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved ((AT91_REG *) 	0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR ((AT91_REG *) 	0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR ((AT91_REG *) 	0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR ((AT91_REG *) 	0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR ((AT91_REG *) 	0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR ((AT91_REG *) 	0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR  ((AT91_REG *) 	0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS  ((AT91_REG *) 	0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER  ((AT91_REG *) 	0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR   ((AT91_REG *) 	0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR  ((AT91_REG *) 	0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR   ((AT91_REG *) 	0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR  ((AT91_REG *) 	0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR   ((AT91_REG *) 	0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA  ((AT91_REG *) 	0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR   ((AT91_REG *) 	0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR ((AT91_REG *) 	0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM   ((AT91_REG *) 	0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR   ((AT91_REG *) 	0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR   ((AT91_REG *) 	0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR   ((AT91_REG *) 	0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR   ((AT91_REG *) 	0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR   ((AT91_REG *) 	0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP ((AT91_REG *) 	0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC  ((AT91_REG *) 	0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE ((AT91_REG *) 	0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER   ((AT91_REG *) 	0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR    ((AT91_REG *) 	0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC    ((AT91_REG *) 	0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB    ((AT91_REG *) 	0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR   ((AT91_REG *) 	0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR   ((AT91_REG *) 	0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER   ((AT91_REG *) 	0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA    ((AT91_REG *) 	0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR   ((AT91_REG *) 	0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV    ((AT91_REG *) 	0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR   ((AT91_REG *) 	0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB    ((AT91_REG *) 	0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR   ((AT91_REG *) 	0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER   ((AT91_REG *) 	0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR   ((AT91_REG *) 	0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR    ((AT91_REG *) 	0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR   ((AT91_REG *) 	0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA    ((AT91_REG *) 	0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC    ((AT91_REG *) 	0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR   ((AT91_REG *) 	0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV    ((AT91_REG *) 	0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR   ((AT91_REG *) 	0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR   ((AT91_REG *) 	0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV    ((AT91_REG *) 	0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA    ((AT91_REG *) 	0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB    ((AT91_REG *) 	0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR   ((AT91_REG *) 	0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR   ((AT91_REG *) 	0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC    ((AT91_REG *) 	0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER   ((AT91_REG *) 	0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR    ((AT91_REG *) 	0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR   ((AT91_REG *) 	0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR   ((AT91_REG *) 	0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL ((AT91_REG *) 	0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM ((AT91_REG *) 	0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR ((AT91_REG *) 	0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID ((AT91_REG *) 	0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR ((AT91_REG *) 	0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID ((AT91_REG *) 	0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH ((AT91_REG *) 	0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR ((AT91_REG *) 	0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL ((AT91_REG *) 	0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID ((AT91_REG *) 	0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR ((AT91_REG *) 	0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR ((AT91_REG *) 	0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM ((AT91_REG *) 	0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH ((AT91_REG *) 	0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR ((AT91_REG *) 	0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID ((AT91_REG *) 	0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR ((AT91_REG *) 	0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH ((AT91_REG *) 	0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID ((AT91_REG *) 	0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL ((AT91_REG *) 	0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR ((AT91_REG *) 	0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM ((AT91_REG *) 	0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID ((AT91_REG *) 	0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR ((AT91_REG *) 	0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID ((AT91_REG *) 	0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM ((AT91_REG *) 	0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID ((AT91_REG *) 	0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR ((AT91_REG *) 	0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR ((AT91_REG *) 	0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR ((AT91_REG *) 	0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL ((AT91_REG *) 	0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH ((AT91_REG *) 	0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID ((AT91_REG *) 	0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR ((AT91_REG *) 	0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH ((AT91_REG *) 	0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID ((AT91_REG *) 	0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR ((AT91_REG *) 	0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR ((AT91_REG *) 	0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL ((AT91_REG *) 	0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM ((AT91_REG *) 	0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR ((AT91_REG *) 	0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR ((AT91_REG *) 	0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID ((AT91_REG *) 	0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH ((AT91_REG *) 	0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID ((AT91_REG *) 	0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR ((AT91_REG *) 	0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL ((AT91_REG *) 	0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM ((AT91_REG *) 	0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID ((AT91_REG *) 	0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID ((AT91_REG *) 	0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM ((AT91_REG *) 	0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR ((AT91_REG *) 	0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL ((AT91_REG *) 	0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR ((AT91_REG *) 	0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH ((AT91_REG *) 	0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR ((AT91_REG *) 	0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR ((AT91_REG *) 	0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH ((AT91_REG *) 	0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID ((AT91_REG *) 	0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL ((AT91_REG *) 	0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID ((AT91_REG *) 	0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR ((AT91_REG *) 	0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM ((AT91_REG *) 	0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR ((AT91_REG *) 	0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR   ((AT91_REG *) 	0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR   ((AT91_REG *) 	0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER   ((AT91_REG *) 	0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR   ((AT91_REG *) 	0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP ((AT91_REG *) 	0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR    ((AT91_REG *) 	0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR   ((AT91_REG *) 	0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR   ((AT91_REG *) 	0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM   ((AT91_REG *) 	0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR    ((AT91_REG *) 	0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR    ((AT91_REG *) 	0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR    ((AT91_REG *) 	0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR  ((AT91_REG *) 	0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H ((AT91_REG *) 	0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L ((AT91_REG *) 	0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE  ((AT91_REG *) 	0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL ((AT91_REG *) 	0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE  ((AT91_REG *) 	0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL  ((AT91_REG *) 	0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF  ((AT91_REG *) 	0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND ((AT91_REG *) 	0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR  ((AT91_REG *) 	0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L ((AT91_REG *) 	0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR  ((AT91_REG *) 	0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L ((AT91_REG *) 	0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR  ((AT91_REG *) 	0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR  ((AT91_REG *) 	0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE  ((AT91_REG *) 	0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL ((AT91_REG *) 	0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID  ((AT91_REG *) 	0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB  ((AT91_REG *) 	0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP ((AT91_REG *) 	0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO ((AT91_REG *) 	0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR  ((AT91_REG *) 	0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H ((AT91_REG *) 	0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV  ((AT91_REG *) 	0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE  ((AT91_REG *) 	0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA  ((AT91_REG *) 	0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP ((AT91_REG *) 	0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF  ((AT91_REG *) 	0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR ((AT91_REG *) 	0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT  ((AT91_REG *) 	0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF  ((AT91_REG *) 	0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE ((AT91_REG *) 	0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ  ((AT91_REG *) 	0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN  ((AT91_REG *) 	0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO  ((AT91_REG *) 	0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV  ((AT91_REG *) 	0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR  ((AT91_REG *) 	0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF  ((AT91_REG *) 	0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR  ((AT91_REG *) 	0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF  ((AT91_REG *) 	0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR  ((AT91_REG *) 	0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L ((AT91_REG *) 	0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO  ((AT91_REG *) 	0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER  ((AT91_REG *) 	0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H ((AT91_REG *) 	0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE  ((AT91_REG *) 	0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H ((AT91_REG *) 	0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE  ((AT91_REG *) 	0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE  ((AT91_REG *) 	0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR  ((AT91_REG *) 	0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR  ((AT91_REG *) 	0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR  ((AT91_REG *) 	0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR  ((AT91_REG *) 	0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR  ((AT91_REG *) 	0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR  ((AT91_REG *) 	0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR   ((AT91_REG *) 	0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR   ((AT91_REG *) 	0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR   ((AT91_REG *) 	0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR   ((AT91_REG *) 	0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2  ((AT91_REG *) 	0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3  ((AT91_REG *) 	0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0  ((AT91_REG *) 	0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5  ((AT91_REG *) 	0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR  ((AT91_REG *) 	0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR    ((AT91_REG *) 	0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4  ((AT91_REG *) 	0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1  ((AT91_REG *) 	0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR  ((AT91_REG *) 	0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR   ((AT91_REG *) 	0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR    ((AT91_REG *) 	0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7  ((AT91_REG *) 	0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6  ((AT91_REG *) 	0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER   ((AT91_REG *) 	0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER  ((AT91_REG *) 	0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR  ((AT91_REG *) 	0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR    ((AT91_REG *) 	0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR   ((AT91_REG *) 	0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR   ((AT91_REG *) 	0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR  ((AT91_REG *) 	0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR  ((AT91_REG *) 	0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR  ((AT91_REG *) 	0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR   ((AT91_REG *) 	0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR   ((AT91_REG *) 	0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR  ((AT91_REG *) 	0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR  ((AT91_REG *) 	0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR   ((AT91_REG *) 	0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR  ((AT91_REG *) 	0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR  ((AT91_REG *) 	0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR    ((AT91_REG *) 	0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR    ((AT91_REG *) 	0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR ((AT91_REG *) 	0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR ((AT91_REG *) 	0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR    ((AT91_REG *) 	0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR   ((AT91_REG *) 	0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR   ((AT91_REG *) 	0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER   ((AT91_REG *) 	0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR ((AT91_REG *) 	0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR   ((AT91_REG *) 	0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR ((AT91_REG *) 	0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR  ((AT91_REG *) 	0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR  ((AT91_REG *) 	0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR ((AT91_REG *) 	0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR ((AT91_REG *) 	0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR  ((AT91_REG *) 	0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR ((AT91_REG *) 	0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR  ((AT91_REG *) 	0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR ((AT91_REG *) 	0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR ((AT91_REG *) 	0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR ((AT91_REG *) 	0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR ((AT91_REG *) 	0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR  ((AT91_REG *) 	0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR   ((AT91_REG *) 	0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR ((AT91_REG *) 	0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR ((AT91_REG *) 	0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR  ((AT91_REG *) 	0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR   ((AT91_REG *) 	0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR   ((AT91_REG *) 	0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER  ((AT91_REG *) 	0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR  ((AT91_REG *) 	0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR ((AT91_REG *) 	0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR ((AT91_REG *) 	0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_PIO_PA0        ((unsigned int) 1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0     ((unsigned int) AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1        ((unsigned int) 1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0     ((unsigned int) AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10       ((unsigned int) 1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD      ((unsigned int) AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11       ((unsigned int) 1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK     ((unsigned int) AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12       ((unsigned int) 1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00   ((unsigned int) AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13       ((unsigned int) 1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01   ((unsigned int) AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1     ((unsigned int) AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14       ((unsigned int) 1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02   ((unsigned int) AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1     ((unsigned int) AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15       ((unsigned int) 1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03   ((unsigned int) AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2    ((unsigned int) AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16       ((unsigned int) 1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0    ((unsigned int) AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17       ((unsigned int) 1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0    ((unsigned int) AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18       ((unsigned int) 1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0    ((unsigned int) AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19       ((unsigned int) 1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX    ((unsigned int) AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2        ((unsigned int) 1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0     ((unsigned int) AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11   ((unsigned int) AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20       ((unsigned int) 1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX    ((unsigned int) AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21       ((unsigned int) 1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF       ((unsigned int) AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10   ((unsigned int) AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22       ((unsigned int) 1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK       ((unsigned int) AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1    ((unsigned int) AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23       ((unsigned int) 1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD       ((unsigned int) AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1    ((unsigned int) AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24       ((unsigned int) 1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD       ((unsigned int) AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1    ((unsigned int) AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25       ((unsigned int) 1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK       ((unsigned int) AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11   ((unsigned int) AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26       ((unsigned int) 1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF       ((unsigned int) AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12   ((unsigned int) AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27       ((unsigned int) 1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD     ((unsigned int) AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3     ((unsigned int) AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28       ((unsigned int) 1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD     ((unsigned int) AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29       ((unsigned int) 1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ      ((unsigned int) AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13   ((unsigned int) AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3        ((unsigned int) 1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0     ((unsigned int) AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12   ((unsigned int) AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30       ((unsigned int) 1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0     ((unsigned int) AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2     ((unsigned int) AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4        ((unsigned int) 1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0     ((unsigned int) AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13   ((unsigned int) AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5        ((unsigned int) 1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1     ((unsigned int) AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6        ((unsigned int) 1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1     ((unsigned int) AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7        ((unsigned int) 1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1     ((unsigned int) AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01   ((unsigned int) AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8        ((unsigned int) 1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1     ((unsigned int) AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02   ((unsigned int) AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9        ((unsigned int) 1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1     ((unsigned int) AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03   ((unsigned int) AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0        ((unsigned int) 1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK ((unsigned int) AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0     ((unsigned int) AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1        ((unsigned int) 1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN    ((unsigned int) AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10       ((unsigned int) 1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2     ((unsigned int) AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11   ((unsigned int) AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11       ((unsigned int) 1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3     ((unsigned int) AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12   ((unsigned int) AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12       ((unsigned int) 1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER    ((unsigned int) AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0    ((unsigned int) AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13       ((unsigned int) 1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2     ((unsigned int) AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01   ((unsigned int) AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14       ((unsigned int) 1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3     ((unsigned int) AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02   ((unsigned int) AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15       ((unsigned int) 1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV    ((unsigned int) AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16       ((unsigned int) 1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL     ((unsigned int) AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13   ((unsigned int) AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17       ((unsigned int) 1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK    ((unsigned int) AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03   ((unsigned int) AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18       ((unsigned int) 1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100    ((unsigned int) AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG    ((unsigned int) AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19       ((unsigned int) 1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0     ((unsigned int) AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1    ((unsigned int) AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2        ((unsigned int) 1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0     ((unsigned int) AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20       ((unsigned int) 1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1     ((unsigned int) AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0     ((unsigned int) AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21       ((unsigned int) 1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2     ((unsigned int) AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1     ((unsigned int) AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22       ((unsigned int) 1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3     ((unsigned int) AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2     ((unsigned int) AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23       ((unsigned int) 1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0    ((unsigned int) AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1     ((unsigned int) AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24       ((unsigned int) 1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0    ((unsigned int) AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1     ((unsigned int) AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25       ((unsigned int) 1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1    ((unsigned int) AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1     ((unsigned int) AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26       ((unsigned int) 1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1    ((unsigned int) AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1      ((unsigned int) AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27       ((unsigned int) 1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2    ((unsigned int) AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0     ((unsigned int) AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28       ((unsigned int) 1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2    ((unsigned int) AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1     ((unsigned int) AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29       ((unsigned int) 1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1     ((unsigned int) AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2     ((unsigned int) AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3        ((unsigned int) 1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1     ((unsigned int) AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30       ((unsigned int) 1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2     ((unsigned int) AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3     ((unsigned int) AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4        ((unsigned int) 1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV ((unsigned int) AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5        ((unsigned int) 1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0     ((unsigned int) AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6        ((unsigned int) 1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1     ((unsigned int) AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7        ((unsigned int) 1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER    ((unsigned int) AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8        ((unsigned int) 1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC     ((unsigned int) AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9        ((unsigned int) 1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO    ((unsigned int) AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ID_FIQ    ((unsigned int)  0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS    ((unsigned int)  1) // System Peripheral

+#define AT91C_ID_PIOA   ((unsigned int)  2) // Parallel IO Controller A

+#define AT91C_ID_PIOB   ((unsigned int)  3) // Parallel IO Controller B

+#define AT91C_ID_SPI0   ((unsigned int)  4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1   ((unsigned int)  5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0    ((unsigned int)  6) // USART 0

+#define AT91C_ID_US1    ((unsigned int)  7) // USART 1

+#define AT91C_ID_SSC    ((unsigned int)  8) // Serial Synchronous Controller

+#define AT91C_ID_TWI    ((unsigned int)  9) // Two-Wire Interface

+#define AT91C_ID_PWMC   ((unsigned int) 10) // PWM Controller

+#define AT91C_ID_UDP    ((unsigned int) 11) // USB Device Port

+#define AT91C_ID_TC0    ((unsigned int) 12) // Timer Counter 0

+#define AT91C_ID_TC1    ((unsigned int) 13) // Timer Counter 1

+#define AT91C_ID_TC2    ((unsigned int) 14) // Timer Counter 2

+#define AT91C_ID_CAN    ((unsigned int) 15) // Control Area Network Controller

+#define AT91C_ID_EMAC   ((unsigned int) 16) // Ethernet MAC

+#define AT91C_ID_ADC    ((unsigned int) 17) // Analog-to-Digital Converter

+#define AT91C_ID_AES    ((unsigned int) 18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES   ((unsigned int) 19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved ((unsigned int) 20) // Reserved

+#define AT91C_ID_21_Reserved ((unsigned int) 21) // Reserved

+#define AT91C_ID_22_Reserved ((unsigned int) 22) // Reserved

+#define AT91C_ID_23_Reserved ((unsigned int) 23) // Reserved

+#define AT91C_ID_24_Reserved ((unsigned int) 24) // Reserved

+#define AT91C_ID_25_Reserved ((unsigned int) 25) // Reserved

+#define AT91C_ID_26_Reserved ((unsigned int) 26) // Reserved

+#define AT91C_ID_27_Reserved ((unsigned int) 27) // Reserved

+#define AT91C_ID_28_Reserved ((unsigned int) 28) // Reserved

+#define AT91C_ID_29_Reserved ((unsigned int) 29) // Reserved

+#define AT91C_ID_IRQ0   ((unsigned int) 30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1   ((unsigned int) 31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_BASE_SYS       ((AT91PS_SYS) 	0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC       ((AT91PS_AIC) 	0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU  ((AT91PS_PDC) 	0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU      ((AT91PS_DBGU) 	0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA      ((AT91PS_PIO) 	0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB      ((AT91PS_PIO) 	0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR      ((AT91PS_CKGR) 	0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC       ((AT91PS_PMC) 	0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC      ((AT91PS_RSTC) 	0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC      ((AT91PS_RTTC) 	0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC      ((AT91PS_PITC) 	0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC      ((AT91PS_WDTC) 	0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG      ((AT91PS_VREG) 	0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC        ((AT91PS_MC) 	0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1  ((AT91PS_PDC) 	0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1      ((AT91PS_SPI) 	0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0  ((AT91PS_PDC) 	0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0      ((AT91PS_SPI) 	0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1   ((AT91PS_PDC) 	0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1       ((AT91PS_USART) 	0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0   ((AT91PS_PDC) 	0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0       ((AT91PS_USART) 	0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC   ((AT91PS_PDC) 	0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC       ((AT91PS_SSC) 	0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI       ((AT91PS_TWI) 	0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3  ((AT91PS_PWMC_CH) 	0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2  ((AT91PS_PWMC_CH) 	0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1  ((AT91PS_PWMC_CH) 	0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0  ((AT91PS_PWMC_CH) 	0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC      ((AT91PS_PWMC) 	0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP       ((AT91PS_UDP) 	0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0       ((AT91PS_TC) 	0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1       ((AT91PS_TC) 	0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2       ((AT91PS_TC) 	0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB       ((AT91PS_TCB) 	0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0   ((AT91PS_CAN_MB) 	0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1   ((AT91PS_CAN_MB) 	0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2   ((AT91PS_CAN_MB) 	0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3   ((AT91PS_CAN_MB) 	0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4   ((AT91PS_CAN_MB) 	0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5   ((AT91PS_CAN_MB) 	0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6   ((AT91PS_CAN_MB) 	0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7   ((AT91PS_CAN_MB) 	0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN       ((AT91PS_CAN) 	0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC      ((AT91PS_EMAC) 	0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC   ((AT91PS_PDC) 	0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC       ((AT91PS_ADC) 	0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES   ((AT91PS_PDC) 	0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES       ((AT91PS_AES) 	0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES  ((AT91PS_PDC) 	0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES      ((AT91PS_TDES) 	0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ISRAM	 ((char *) 	0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	 ((unsigned int) 0x00010000) // Internal SRAM size in byte (64 Kbyte)

+#define AT91C_IFLASH	 ((char *) 	0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	 ((unsigned int) 0x00040000) // Internal ROM size in byte (256 Kbyte)

+

+#define AT91F_AIC_ConfigureIt( irq_id, priority, src_type, newHandler )		\

+{																			\

+    unsigned int mask ;														\

+																			\

+    mask = 0x1 << irq_id;													\

+    /* Disable the interrupt on the interrupt controller */					\

+    AT91C_BASE_AIC->AIC_IDCR = mask ;										\

+    /* Save the interrupt handler routine pointer and the interrupt priority */	\

+    AT91C_BASE_AIC->AIC_SVR[irq_id] = (unsigned int) newHandler ;			\

+    /* Store the Source Mode Register */									\

+    AT91C_BASE_AIC->AIC_SMR[irq_id] = src_type | priority  ;				\

+    /* Clear the interrupt on the interrupt controller */					\

+    AT91C_BASE_AIC->AIC_ICCR = mask ;										\

+}

+

+

+#endif

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/ioat91sam7x256.h b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/ioat91sam7x256.h
new file mode 100644
index 0000000..8ea721e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/ioat91sam7x256.h
@@ -0,0 +1,4698 @@
+// - ----------------------------------------------------------------------------

+// -          ATMEL Microcontroller Software Support  -  ROUSSET  -

+// - ----------------------------------------------------------------------------

+// -  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+// -  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+// -  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+// -  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+// -  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+// -  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+// -  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+// -  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+// -  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+// -  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+// - ----------------------------------------------------------------------------

+// - File Name           : AT91SAM7X256.h

+// - Object              : AT91SAM7X256 definitions

+// - Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+// - 

+// - CVS Reference       : /AT91SAM7X256.pl/1.11/Tue May 10 12:15:32 2005//

+// - CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// - CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// - CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// - CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// - CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// - CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// - CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// - CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// - CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// - CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// - CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// - CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// - CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// - CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// - CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// - CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// - CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// - CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// - CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// - CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// - CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// - CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// - CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// - CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+// - ----------------------------------------------------------------------------

+

+#ifndef AT91SAM7X256_H

+#define AT91SAM7X256_H

+

+typedef volatile unsigned int AT91_REG;// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+typedef struct _AT91S_SYS {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+	AT91_REG	 Reserved2[45]; 	// 

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved3[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved4[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+	AT91_REG	 Reserved5[54]; 	// 

+	AT91_REG	 PIOA_PER; 	// PIO Enable Register

+	AT91_REG	 PIOA_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOA_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved6[1]; 	// 

+	AT91_REG	 PIOA_OER; 	// Output Enable Register

+	AT91_REG	 PIOA_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOA_OSR; 	// Output Status Register

+	AT91_REG	 Reserved7[1]; 	// 

+	AT91_REG	 PIOA_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOA_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOA_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved8[1]; 	// 

+	AT91_REG	 PIOA_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOA_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOA_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOA_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOA_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOA_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOA_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOA_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOA_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOA_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOA_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved9[1]; 	// 

+	AT91_REG	 PIOA_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOA_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOA_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved10[1]; 	// 

+	AT91_REG	 PIOA_ASR; 	// Select A Register

+	AT91_REG	 PIOA_BSR; 	// Select B Register

+	AT91_REG	 PIOA_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved11[9]; 	// 

+	AT91_REG	 PIOA_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOA_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOA_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved12[85]; 	// 

+	AT91_REG	 PIOB_PER; 	// PIO Enable Register

+	AT91_REG	 PIOB_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOB_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved13[1]; 	// 

+	AT91_REG	 PIOB_OER; 	// Output Enable Register

+	AT91_REG	 PIOB_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOB_OSR; 	// Output Status Register

+	AT91_REG	 Reserved14[1]; 	// 

+	AT91_REG	 PIOB_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOB_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOB_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved15[1]; 	// 

+	AT91_REG	 PIOB_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOB_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOB_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOB_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOB_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOB_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOB_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOB_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOB_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOB_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOB_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved16[1]; 	// 

+	AT91_REG	 PIOB_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOB_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOB_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved17[1]; 	// 

+	AT91_REG	 PIOB_ASR; 	// Select A Register

+	AT91_REG	 PIOB_BSR; 	// Select B Register

+	AT91_REG	 PIOB_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved18[9]; 	// 

+	AT91_REG	 PIOB_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOB_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOB_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved19[341]; 	// 

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved20[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved21[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved22[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved23[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved24[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved25[36]; 	// 

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+	AT91_REG	 Reserved26[5]; 	// 

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+	AT91_REG	 Reserved27[5]; 	// 

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_SYS, *AT91PS_SYS;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+typedef struct _AT91S_AIC {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+} AT91S_AIC, *AT91PS_AIC;

+

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR       ((unsigned int) 0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               ((unsigned int) 0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              ((unsigned int) 0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE     ((unsigned int) 0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       ((unsigned int) 0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        ((unsigned int) 0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           ((unsigned int) 0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        ((unsigned int) 0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ        ((unsigned int) 0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ        ((unsigned int) 0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT    ((unsigned int) 0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK    ((unsigned int) 0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+typedef struct _AT91S_PDC {

+	AT91_REG	 PDC_RPR; 	// Receive Pointer Register

+	AT91_REG	 PDC_RCR; 	// Receive Counter Register

+	AT91_REG	 PDC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 PDC_TCR; 	// Transmit Counter Register

+	AT91_REG	 PDC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 PDC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 PDC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 PDC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 PDC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 PDC_PTSR; 	// PDC Transfer Status Register

+} AT91S_PDC, *AT91PS_PDC;

+

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN       ((unsigned int) 0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS      ((unsigned int) 0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN       ((unsigned int) 0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS      ((unsigned int) 0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+typedef struct _AT91S_DBGU {

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved0[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved1[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+} AT91S_DBGU, *AT91PS_DBGU;

+

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX        ((unsigned int) 0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX        ((unsigned int) 0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN         ((unsigned int) 0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS        ((unsigned int) 0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN         ((unsigned int) 0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS        ((unsigned int) 0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA       ((unsigned int) 0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR          ((unsigned int) 0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 ((unsigned int) 0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  ((unsigned int) 0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                ((unsigned int) 0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 ((unsigned int) 0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 ((unsigned int) 0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           ((unsigned int) 0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE       ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY        ((unsigned int) 0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY        ((unsigned int) 0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX        ((unsigned int) 0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX        ((unsigned int) 0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE         ((unsigned int) 0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME        ((unsigned int) 0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE         ((unsigned int) 0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY      ((unsigned int) 0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE       ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF       ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX      ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX      ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST  ((unsigned int) 0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+typedef struct _AT91S_PIO {

+	AT91_REG	 PIO_PER; 	// PIO Enable Register

+	AT91_REG	 PIO_PDR; 	// PIO Disable Register

+	AT91_REG	 PIO_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PIO_OER; 	// Output Enable Register

+	AT91_REG	 PIO_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIO_OSR; 	// Output Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PIO_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIO_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIO_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PIO_SODR; 	// Set Output Data Register

+	AT91_REG	 PIO_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIO_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIO_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIO_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIO_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIO_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIO_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIO_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIO_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIO_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved3[1]; 	// 

+	AT91_REG	 PIO_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIO_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIO_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved4[1]; 	// 

+	AT91_REG	 PIO_ASR; 	// Select A Register

+	AT91_REG	 PIO_BSR; 	// Select B Register

+	AT91_REG	 PIO_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved5[9]; 	// 

+	AT91_REG	 PIO_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIO_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIO_OWSR; 	// Output Write Status Register

+} AT91S_PIO, *AT91PS_PIO;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+typedef struct _AT91S_CKGR {

+	AT91_REG	 CKGR_MOR; 	// Main Oscillator Register

+	AT91_REG	 CKGR_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 CKGR_PLLR; 	// PLL Register

+} AT91S_CKGR, *AT91PS_CKGR;

+

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN     ((unsigned int) 0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS  ((unsigned int) 0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT    ((unsigned int) 0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF      ((unsigned int) 0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY    ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV        ((unsigned int) 0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    ((unsigned int) 0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               ((unsigned int) 0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT   ((unsigned int) 0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT        ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL        ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV     ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+typedef struct _AT91S_PMC {

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved3[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved4[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+} AT91S_PMC, *AT91PS_PMC;

+

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK         ((unsigned int) 0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP         ((unsigned int) 0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0        ((unsigned int) 0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1        ((unsigned int) 0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2        ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3        ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS         ((unsigned int) 0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             ((unsigned int) 0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             ((unsigned int) 0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              ((unsigned int) 0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES        ((unsigned int) 0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  ((unsigned int) 0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                ((unsigned int) 0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                ((unsigned int) 0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                ((unsigned int) 0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               ((unsigned int) 0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               ((unsigned int) 0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               ((unsigned int) 0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS       ((unsigned int) 0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK        ((unsigned int) 0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY      ((unsigned int) 0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY     ((unsigned int) 0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY     ((unsigned int) 0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY     ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY     ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RSTC {

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+} AT91S_RSTC, *AT91PS_RSTC;

+

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST    ((unsigned int) 0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST     ((unsigned int) 0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST     ((unsigned int) 0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY        ((unsigned int) 0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS      ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS     ((unsigned int) 0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP     ((unsigned int) 0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              ((unsigned int) 0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               ((unsigned int) 0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             ((unsigned int) 0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             ((unsigned int) 0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 ((unsigned int) 0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             ((unsigned int) 0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL      ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP      ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN     ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN    ((unsigned int) 0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL      ((unsigned int) 0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN     ((unsigned int) 0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RTTC {

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+} AT91S_RTTC, *AT91PS_RTTC;

+

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES     ((unsigned int) 0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN     ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN  ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST     ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV       ((unsigned int) 0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV       ((unsigned int) 0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS       ((unsigned int) 0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC     ((unsigned int) 0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PITC {

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+} AT91S_PITC, *AT91PS_PITC;

+

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV        ((unsigned int) 0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN      ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN     ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS       ((unsigned int) 0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV       ((unsigned int) 0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT      ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_WDTC {

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+} AT91S_WDTC, *AT91PS_WDTC;

+

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT     ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY        ((unsigned int) 0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV        ((unsigned int) 0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN     ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN    ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC    ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS      ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD        ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT   ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT  ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF      ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR      ((unsigned int) 0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_VREG {

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_VREG, *AT91PS_VREG;

+

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY     ((unsigned int) 0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_MC {

+	AT91_REG	 MC_RCR; 	// MC Remap Control Register

+	AT91_REG	 MC_ASR; 	// MC Abort Status Register

+	AT91_REG	 MC_AASR; 	// MC Abort Address Status Register

+	AT91_REG	 Reserved0[21]; 	// 

+	AT91_REG	 MC_FMR; 	// MC Flash Mode Register

+	AT91_REG	 MC_FCR; 	// MC Flash Command Register

+	AT91_REG	 MC_FSR; 	// MC Flash Status Register

+} AT91S_MC, *AT91PS_MC;

+

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB          ((unsigned int) 0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD       ((unsigned int) 0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD       ((unsigned int) 0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ        ((unsigned int) 0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 ((unsigned int) 0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                ((unsigned int) 0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 ((unsigned int) 0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP       ((unsigned int) 0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                ((unsigned int) 0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                ((unsigned int) 0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                ((unsigned int) 0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0         ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1         ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0       ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1       ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY         ((unsigned int) 0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE        ((unsigned int) 0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE        ((unsigned int) 0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP         ((unsigned int) 0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS          ((unsigned int) 0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 ((unsigned int) 0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 ((unsigned int) 0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 ((unsigned int) 0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 ((unsigned int) 0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN         ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD         ((unsigned int) 0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         ((unsigned int) 0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN        ((unsigned int) 0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY          ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY     ((unsigned int) 0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0       ((unsigned int) 0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1       ((unsigned int) 0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2       ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3       ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4       ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5       ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6       ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7       ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0       ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1       ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2       ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3       ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4       ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5       ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6       ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7       ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8       ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9       ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10      ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11      ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12      ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13      ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14      ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15      ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+typedef struct _AT91S_SPI {

+	AT91_REG	 SPI_CR; 	// Control Register

+	AT91_REG	 SPI_MR; 	// Mode Register

+	AT91_REG	 SPI_RDR; 	// Receive Data Register

+	AT91_REG	 SPI_TDR; 	// Transmit Data Register

+	AT91_REG	 SPI_SR; 	// Status Register

+	AT91_REG	 SPI_IER; 	// Interrupt Enable Register

+	AT91_REG	 SPI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SPI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91_REG	 SPI_CSR[4]; 	// Chip Select Register

+	AT91_REG	 Reserved1[48]; 	// 

+	AT91_REG	 SPI_RPR; 	// Receive Pointer Register

+	AT91_REG	 SPI_RCR; 	// Receive Counter Register

+	AT91_REG	 SPI_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SPI_TCR; 	// Transmit Counter Register

+	AT91_REG	 SPI_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SPI_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SPI_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SPI_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SPI_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SPI_PTSR; 	// PDC Transfer Status Register

+} AT91S_SPI, *AT91PS_SPI;

+

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN       ((unsigned int) 0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS      ((unsigned int) 0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST       ((unsigned int) 0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER    ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR        ((unsigned int) 0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS          ((unsigned int) 0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                ((unsigned int) 0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             ((unsigned int) 0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC      ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV        ((unsigned int) 0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS     ((unsigned int) 0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB         ((unsigned int) 0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS         ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD          ((unsigned int) 0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD          ((unsigned int) 0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF        ((unsigned int) 0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE        ((unsigned int) 0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF        ((unsigned int) 0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES       ((unsigned int) 0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX       ((unsigned int) 0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX       ((unsigned int) 0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF      ((unsigned int) 0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE      ((unsigned int) 0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR        ((unsigned int) 0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY     ((unsigned int) 0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS      ((unsigned int) 0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL        ((unsigned int) 0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA       ((unsigned int) 0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT       ((unsigned int) 0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS        ((unsigned int) 0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    ((unsigned int) 0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    ((unsigned int) 0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   ((unsigned int) 0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   ((unsigned int) 0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   ((unsigned int) 0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   ((unsigned int) 0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   ((unsigned int) 0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   ((unsigned int) 0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   ((unsigned int) 0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR        ((unsigned int) 0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS       ((unsigned int) 0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+typedef struct _AT91S_USART {

+	AT91_REG	 US_CR; 	// Control Register

+	AT91_REG	 US_MR; 	// Mode Register

+	AT91_REG	 US_IER; 	// Interrupt Enable Register

+	AT91_REG	 US_IDR; 	// Interrupt Disable Register

+	AT91_REG	 US_IMR; 	// Interrupt Mask Register

+	AT91_REG	 US_CSR; 	// Channel Status Register

+	AT91_REG	 US_RHR; 	// Receiver Holding Register

+	AT91_REG	 US_THR; 	// Transmitter Holding Register

+	AT91_REG	 US_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 US_RTOR; 	// Receiver Time-out Register

+	AT91_REG	 US_TTGR; 	// Transmitter Time-guard Register

+	AT91_REG	 Reserved0[5]; 	// 

+	AT91_REG	 US_FIDI; 	// FI_DI_Ratio Register

+	AT91_REG	 US_NER; 	// Nb Errors Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 US_IF; 	// IRDA_FILTER Register

+	AT91_REG	 Reserved2[44]; 	// 

+	AT91_REG	 US_RPR; 	// Receive Pointer Register

+	AT91_REG	 US_RCR; 	// Receive Counter Register

+	AT91_REG	 US_TPR; 	// Transmit Pointer Register

+	AT91_REG	 US_TCR; 	// Transmit Counter Register

+	AT91_REG	 US_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 US_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 US_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 US_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 US_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 US_PTSR; 	// PDC Transfer Status Register

+} AT91S_USART, *AT91PS_USART;

+

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK       ((unsigned int) 0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK       ((unsigned int) 0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO        ((unsigned int) 0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA        ((unsigned int) 0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT        ((unsigned int) 0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK      ((unsigned int) 0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO        ((unsigned int) 0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN        ((unsigned int) 0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS       ((unsigned int) 0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN        ((unsigned int) 0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS       ((unsigned int) 0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE       ((unsigned int) 0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               ((unsigned int) 0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                ((unsigned int) 0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                ((unsigned int) 0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                ((unsigned int) 0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            ((unsigned int) 0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            ((unsigned int) 0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 ((unsigned int) 0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                ((unsigned int) 0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS         ((unsigned int) 0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                ((unsigned int) 0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                ((unsigned int) 0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 ((unsigned int) 0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  ((unsigned int) 0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL         ((unsigned int) 0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               ((unsigned int) 0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               ((unsigned int) 0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               ((unsigned int) 0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               ((unsigned int) 0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC         ((unsigned int) 0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP       ((unsigned int) 0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                ((unsigned int) 0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               ((unsigned int) 0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                ((unsigned int) 0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF         ((unsigned int) 0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9        ((unsigned int) 0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO         ((unsigned int) 0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER         ((unsigned int) 0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK        ((unsigned int) 0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK       ((unsigned int) 0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER     ((unsigned int) 0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER       ((unsigned int) 0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK        ((unsigned int) 0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT      ((unsigned int) 0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION    ((unsigned int) 0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK         ((unsigned int) 0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC         ((unsigned int) 0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC        ((unsigned int) 0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC        ((unsigned int) 0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC        ((unsigned int) 0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI           ((unsigned int) 0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR          ((unsigned int) 0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD          ((unsigned int) 0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS          ((unsigned int) 0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_SSC {

+	AT91_REG	 SSC_CR; 	// Control Register

+	AT91_REG	 SSC_CMR; 	// Clock Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SSC_RCMR; 	// Receive Clock ModeRegister

+	AT91_REG	 SSC_RFMR; 	// Receive Frame Mode Register

+	AT91_REG	 SSC_TCMR; 	// Transmit Clock Mode Register

+	AT91_REG	 SSC_TFMR; 	// Transmit Frame Mode Register

+	AT91_REG	 SSC_RHR; 	// Receive Holding Register

+	AT91_REG	 SSC_THR; 	// Transmit Holding Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 SSC_RSHR; 	// Receive Sync Holding Register

+	AT91_REG	 SSC_TSHR; 	// Transmit Sync Holding Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 SSC_SR; 	// Status Register

+	AT91_REG	 SSC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SSC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SSC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved3[44]; 	// 

+	AT91_REG	 SSC_RPR; 	// Receive Pointer Register

+	AT91_REG	 SSC_RCR; 	// Receive Counter Register

+	AT91_REG	 SSC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SSC_TCR; 	// Transmit Counter Register

+	AT91_REG	 SSC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SSC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SSC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SSC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SSC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SSC_PTSR; 	// PDC Transfer Status Register

+} AT91S_SSC, *AT91PS_SSC;

+

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN        ((unsigned int) 0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS       ((unsigned int) 0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN        ((unsigned int) 0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS       ((unsigned int) 0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST       ((unsigned int) 0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS         ((unsigned int) 0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  ((unsigned int) 0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   ((unsigned int) 0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   ((unsigned int) 0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO         ((unsigned int) 0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 ((unsigned int) 0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            ((unsigned int) 0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              ((unsigned int) 0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI         ((unsigned int) 0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START       ((unsigned int) 0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            ((unsigned int) 0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   ((unsigned int) 0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               ((unsigned int) 0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              ((unsigned int) 0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              ((unsigned int) 0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              ((unsigned int) 0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             ((unsigned int) 0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              ((unsigned int) 0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    ((unsigned int) 0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY      ((unsigned int) 0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD      ((unsigned int) 0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN      ((unsigned int) 0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP        ((unsigned int) 0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF        ((unsigned int) 0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB       ((unsigned int) 0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN       ((unsigned int) 0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS        ((unsigned int) 0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 ((unsigned int) 0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             ((unsigned int) 0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             ((unsigned int) 0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  ((unsigned int) 0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 ((unsigned int) 0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               ((unsigned int) 0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE      ((unsigned int) 0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF      ((unsigned int) 0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN       ((unsigned int) 0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY       ((unsigned int) 0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY     ((unsigned int) 0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX       ((unsigned int) 0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE      ((unsigned int) 0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY       ((unsigned int) 0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN       ((unsigned int) 0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX       ((unsigned int) 0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF      ((unsigned int) 0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN       ((unsigned int) 0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN       ((unsigned int) 0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA       ((unsigned int) 0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA       ((unsigned int) 0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+typedef struct _AT91S_TWI {

+	AT91_REG	 TWI_CR; 	// Control Register

+	AT91_REG	 TWI_MMR; 	// Master Mode Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 TWI_IADR; 	// Internal Address Register

+	AT91_REG	 TWI_CWGR; 	// Clock Waveform Generator Register

+	AT91_REG	 Reserved1[3]; 	// 

+	AT91_REG	 TWI_SR; 	// Status Register

+	AT91_REG	 TWI_IER; 	// Interrupt Enable Register

+	AT91_REG	 TWI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TWI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TWI_RHR; 	// Receive Holding Register

+	AT91_REG	 TWI_THR; 	// Transmit Holding Register

+} AT91S_TWI, *AT91PS_TWI;

+

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START       ((unsigned int) 0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP        ((unsigned int) 0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN        ((unsigned int) 0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS       ((unsigned int) 0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST       ((unsigned int) 0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ      ((unsigned int) 0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   ((unsigned int) 0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               ((unsigned int) 0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               ((unsigned int) 0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               ((unsigned int) 0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD       ((unsigned int) 0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR        ((unsigned int) 0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV       ((unsigned int) 0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV       ((unsigned int) 0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV       ((unsigned int) 0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP      ((unsigned int) 0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY       ((unsigned int) 0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY       ((unsigned int) 0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE        ((unsigned int) 0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE        ((unsigned int) 0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK        ((unsigned int) 0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC_CH {

+	AT91_REG	 PWMC_CMR; 	// Channel Mode Register

+	AT91_REG	 PWMC_CDTYR; 	// Channel Duty Cycle Register

+	AT91_REG	 PWMC_CPRDR; 	// Channel Period Register

+	AT91_REG	 PWMC_CCNTR; 	// Channel Counter Register

+	AT91_REG	 PWMC_CUPDR; 	// Channel Update Register

+	AT91_REG	 PWMC_Reserved[3]; 	// Reserved

+} AT91S_PWMC_CH, *AT91PS_PWMC_CH;

+

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE       ((unsigned int) 0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  ((unsigned int) 0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 ((unsigned int) 0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 ((unsigned int) 0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG       ((unsigned int) 0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL       ((unsigned int) 0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD        ((unsigned int) 0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC {

+	AT91_REG	 PWMC_MR; 	// PWMC Mode Register

+	AT91_REG	 PWMC_ENA; 	// PWMC Enable Register

+	AT91_REG	 PWMC_DIS; 	// PWMC Disable Register

+	AT91_REG	 PWMC_SR; 	// PWMC Status Register

+	AT91_REG	 PWMC_IER; 	// PWMC Interrupt Enable Register

+	AT91_REG	 PWMC_IDR; 	// PWMC Interrupt Disable Register

+	AT91_REG	 PWMC_IMR; 	// PWMC Interrupt Mask Register

+	AT91_REG	 PWMC_ISR; 	// PWMC Interrupt Status Register

+	AT91_REG	 Reserved0[55]; 	// 

+	AT91_REG	 PWMC_VR; 	// PWMC Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_PWMC_CH	 PWMC_CH[4]; 	// PWMC Channel

+} AT91S_PWMC, *AT91PS_PWMC;

+

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA       ((unsigned int) 0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA       ((unsigned int) 0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  ((unsigned int) 0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB       ((unsigned int) 0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB       ((unsigned int) 0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  ((unsigned int) 0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0      ((unsigned int) 0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1      ((unsigned int) 0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2      ((unsigned int) 0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3      ((unsigned int) 0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+typedef struct _AT91S_UDP {

+	AT91_REG	 UDP_NUM; 	// Frame Number Register

+	AT91_REG	 UDP_GLBSTATE; 	// Global State Register

+	AT91_REG	 UDP_FADDR; 	// Function Address Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 UDP_IER; 	// Interrupt Enable Register

+	AT91_REG	 UDP_IDR; 	// Interrupt Disable Register

+	AT91_REG	 UDP_IMR; 	// Interrupt Mask Register

+	AT91_REG	 UDP_ISR; 	// Interrupt Status Register

+	AT91_REG	 UDP_ICR; 	// Interrupt Clear Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 UDP_RSTEP; 	// Reset Endpoint Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 UDP_CSR[6]; 	// Endpoint Control and Status Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 UDP_FDR[6]; 	// Endpoint FIFO Data Register

+	AT91_REG	 Reserved4[3]; 	// 

+	AT91_REG	 UDP_TXVC; 	// Transceiver Control Register

+} AT91S_UDP, *AT91PS_UDP;

+

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM     ((unsigned int) 0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR     ((unsigned int) 0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK      ((unsigned int) 0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN      ((unsigned int) 0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG       ((unsigned int) 0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR         ((unsigned int) 0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR     ((unsigned int) 0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE      ((unsigned int) 0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD        ((unsigned int) 0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN         ((unsigned int) 0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0      ((unsigned int) 0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1      ((unsigned int) 0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2      ((unsigned int) 0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3      ((unsigned int) 0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4      ((unsigned int) 0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5      ((unsigned int) 0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP      ((unsigned int) 0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM       ((unsigned int) 0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM      ((unsigned int) 0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT      ((unsigned int) 0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP      ((unsigned int) 0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES   ((unsigned int) 0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0         ((unsigned int) 0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1         ((unsigned int) 0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2         ((unsigned int) 0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3         ((unsigned int) 0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4         ((unsigned int) 0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5         ((unsigned int) 0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP      ((unsigned int) 0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0 ((unsigned int) 0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP     ((unsigned int) 0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR    ((unsigned int) 0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY    ((unsigned int) 0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL  ((unsigned int) 0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1 ((unsigned int) 0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR         ((unsigned int) 0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE      ((unsigned int) 0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 ((unsigned int) 0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              ((unsigned int) 0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             ((unsigned int) 0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              ((unsigned int) 0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               ((unsigned int) 0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              ((unsigned int) 0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               ((unsigned int) 0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE       ((unsigned int) 0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS       ((unsigned int) 0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT   ((unsigned int) 0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS      ((unsigned int) 0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON        ((unsigned int) 0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_TC {

+	AT91_REG	 TC_CCR; 	// Channel Control Register

+	AT91_REG	 TC_CMR; 	// Channel Mode Register (Capture Mode / Waveform Mode)

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TC_CV; 	// Counter Value

+	AT91_REG	 TC_RA; 	// Register A

+	AT91_REG	 TC_RB; 	// Register B

+	AT91_REG	 TC_RC; 	// Register C

+	AT91_REG	 TC_SR; 	// Status Register

+	AT91_REG	 TC_IER; 	// Interrupt Enable Register

+	AT91_REG	 TC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TC_IMR; 	// Interrupt Mask Register

+} AT91S_TC, *AT91PS_TC;

+

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN        ((unsigned int) 0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS       ((unsigned int) 0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG        ((unsigned int) 0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS         ((unsigned int) 0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     ((unsigned int) 0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     ((unsigned int) 0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     ((unsigned int) 0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     ((unsigned int) 0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     ((unsigned int) 0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  ((unsigned int) 0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  ((unsigned int) 0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  ((unsigned int) 0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI         ((unsigned int) 0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST        ((unsigned int) 0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 ((unsigned int) 0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  ((unsigned int) 0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  ((unsigned int) 0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  ((unsigned int) 0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG      ((unsigned int) 0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG      ((unsigned int) 0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT         ((unsigned int) 0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 ((unsigned int) 0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  ((unsigned int) 0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  ((unsigned int) 0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  ((unsigned int) 0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG       ((unsigned int) 0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG       ((unsigned int) 0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL      ((unsigned int) 0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   ((unsigned int) 0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               ((unsigned int) 0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              ((unsigned int) 0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          ((unsigned int) 0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG       ((unsigned int) 0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE         ((unsigned int) 0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA         ((unsigned int) 0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  ((unsigned int) 0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                ((unsigned int) 0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               ((unsigned int) 0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA         ((unsigned int) 0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               ((unsigned int) 0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              ((unsigned int) 0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 ((unsigned int) 0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC         ((unsigned int) 0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 ((unsigned int) 0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  ((unsigned int) 0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                ((unsigned int) 0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               ((unsigned int) 0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB         ((unsigned int) 0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 ((unsigned int) 0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               ((unsigned int) 0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              ((unsigned int) 0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 ((unsigned int) 0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT        ((unsigned int) 0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 ((unsigned int) 0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  ((unsigned int) 0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                ((unsigned int) 0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               ((unsigned int) 0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG       ((unsigned int) 0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 ((unsigned int) 0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  ((unsigned int) 0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                ((unsigned int) 0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               ((unsigned int) 0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB         ((unsigned int) 0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 ((unsigned int) 0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  ((unsigned int) 0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                ((unsigned int) 0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               ((unsigned int) 0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC         ((unsigned int) 0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 ((unsigned int) 0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  ((unsigned int) 0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                ((unsigned int) 0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               ((unsigned int) 0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT        ((unsigned int) 0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 ((unsigned int) 0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  ((unsigned int) 0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                ((unsigned int) 0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               ((unsigned int) 0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG       ((unsigned int) 0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 ((unsigned int) 0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  ((unsigned int) 0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                ((unsigned int) 0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               ((unsigned int) 0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS        ((unsigned int) 0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS        ((unsigned int) 0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS         ((unsigned int) 0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS         ((unsigned int) 0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS         ((unsigned int) 0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS        ((unsigned int) 0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS        ((unsigned int) 0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS        ((unsigned int) 0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA       ((unsigned int) 0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA        ((unsigned int) 0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB        ((unsigned int) 0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+typedef struct _AT91S_TCB {

+	AT91S_TC	 TCB_TC0; 	// TC Channel 0

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91S_TC	 TCB_TC1; 	// TC Channel 1

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91S_TC	 TCB_TC2; 	// TC Channel 2

+	AT91_REG	 Reserved2[4]; 	// 

+	AT91_REG	 TCB_BCR; 	// TC Block Control Register

+	AT91_REG	 TCB_BMR; 	// TC Block Mode Register

+} AT91S_TCB, *AT91PS_TCB;

+

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC        ((unsigned int) 0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S     ((unsigned int) 0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                ((unsigned int) 0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 ((unsigned int) 0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                ((unsigned int) 0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                ((unsigned int) 0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S     ((unsigned int) 0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                ((unsigned int) 0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 ((unsigned int) 0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                ((unsigned int) 0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                ((unsigned int) 0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S     ((unsigned int) 0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                ((unsigned int) 0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 ((unsigned int) 0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                ((unsigned int) 0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                ((unsigned int) 0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN_MB {

+	AT91_REG	 CAN_MB_MMR; 	// MailBox Mode Register

+	AT91_REG	 CAN_MB_MAM; 	// MailBox Acceptance Mask Register

+	AT91_REG	 CAN_MB_MID; 	// MailBox ID Register

+	AT91_REG	 CAN_MB_MFID; 	// MailBox Family ID Register

+	AT91_REG	 CAN_MB_MSR; 	// MailBox Status Register

+	AT91_REG	 CAN_MB_MDL; 	// MailBox Data Low Register

+	AT91_REG	 CAN_MB_MDH; 	// MailBox Data High Register

+	AT91_REG	 CAN_MB_MCR; 	// MailBox Control Register

+} AT91S_CAN_MB, *AT91PS_CAN_MB;

+

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK   ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR       ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT         ((unsigned int) 0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  ((unsigned int) 0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   ((unsigned int) 0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          ((unsigned int) 0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   ((unsigned int) 0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             ((unsigned int) 0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             ((unsigned int) 0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB       ((unsigned int) 0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA       ((unsigned int) 0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE        ((unsigned int) 0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP  ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC        ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR        ((unsigned int) 0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT        ((unsigned int) 0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI         ((unsigned int) 0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR        ((unsigned int) 0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN {

+	AT91_REG	 CAN_MR; 	// Mode Register

+	AT91_REG	 CAN_IER; 	// Interrupt Enable Register

+	AT91_REG	 CAN_IDR; 	// Interrupt Disable Register

+	AT91_REG	 CAN_IMR; 	// Interrupt Mask Register

+	AT91_REG	 CAN_SR; 	// Status Register

+	AT91_REG	 CAN_BR; 	// Baudrate Register

+	AT91_REG	 CAN_TIM; 	// Timer Register

+	AT91_REG	 CAN_TIMESTP; 	// Time Stamp Register

+	AT91_REG	 CAN_ECR; 	// Error Counter Register

+	AT91_REG	 CAN_TCR; 	// Transfer Command Register

+	AT91_REG	 CAN_ACR; 	// Abort Command Register

+	AT91_REG	 Reserved0[52]; 	// 

+	AT91_REG	 CAN_VR; 	// Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_CAN_MB	 CAN_MB0; 	// CAN Mailbox 0

+	AT91S_CAN_MB	 CAN_MB1; 	// CAN Mailbox 1

+	AT91S_CAN_MB	 CAN_MB2; 	// CAN Mailbox 2

+	AT91S_CAN_MB	 CAN_MB3; 	// CAN Mailbox 3

+	AT91S_CAN_MB	 CAN_MB4; 	// CAN Mailbox 4

+	AT91S_CAN_MB	 CAN_MB5; 	// CAN Mailbox 5

+	AT91S_CAN_MB	 CAN_MB6; 	// CAN Mailbox 6

+	AT91S_CAN_MB	 CAN_MB7; 	// CAN Mailbox 7

+	AT91S_CAN_MB	 CAN_MB8; 	// CAN Mailbox 8

+	AT91S_CAN_MB	 CAN_MB9; 	// CAN Mailbox 9

+	AT91S_CAN_MB	 CAN_MB10; 	// CAN Mailbox 10

+	AT91S_CAN_MB	 CAN_MB11; 	// CAN Mailbox 11

+	AT91S_CAN_MB	 CAN_MB12; 	// CAN Mailbox 12

+	AT91S_CAN_MB	 CAN_MB13; 	// CAN Mailbox 13

+	AT91S_CAN_MB	 CAN_MB14; 	// CAN Mailbox 14

+	AT91S_CAN_MB	 CAN_MB15; 	// CAN Mailbox 15

+} AT91S_CAN, *AT91PS_CAN;

+

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN       ((unsigned int) 0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM         ((unsigned int) 0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM         ((unsigned int) 0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL         ((unsigned int) 0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF        ((unsigned int) 0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM         ((unsigned int) 0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ      ((unsigned int) 0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT        ((unsigned int) 0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0         ((unsigned int) 0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1         ((unsigned int) 0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2         ((unsigned int) 0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3         ((unsigned int) 0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4         ((unsigned int) 0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5         ((unsigned int) 0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6         ((unsigned int) 0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7         ((unsigned int) 0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8         ((unsigned int) 0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9         ((unsigned int) 0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10        ((unsigned int) 0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11        ((unsigned int) 0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12        ((unsigned int) 0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13        ((unsigned int) 0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14        ((unsigned int) 0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15        ((unsigned int) 0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA        ((unsigned int) 0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN        ((unsigned int) 0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP        ((unsigned int) 0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF        ((unsigned int) 0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP       ((unsigned int) 0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP      ((unsigned int) 0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF        ((unsigned int) 0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP        ((unsigned int) 0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR        ((unsigned int) 0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR        ((unsigned int) 0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR        ((unsigned int) 0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR        ((unsigned int) 0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR        ((unsigned int) 0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY        ((unsigned int) 0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY        ((unsigned int) 0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY        ((unsigned int) 0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2      ((unsigned int) 0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1      ((unsigned int) 0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG      ((unsigned int) 0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC        ((unsigned int) 0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP         ((unsigned int) 0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP         ((unsigned int) 0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER       ((unsigned int) 0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC         ((unsigned int) 0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC         ((unsigned int) 0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST      ((unsigned int) 0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+typedef struct _AT91S_EMAC {

+	AT91_REG	 EMAC_NCR; 	// Network Control Register

+	AT91_REG	 EMAC_NCFGR; 	// Network Configuration Register

+	AT91_REG	 EMAC_NSR; 	// Network Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 EMAC_TSR; 	// Transmit Status Register

+	AT91_REG	 EMAC_RBQP; 	// Receive Buffer Queue Pointer

+	AT91_REG	 EMAC_TBQP; 	// Transmit Buffer Queue Pointer

+	AT91_REG	 EMAC_RSR; 	// Receive Status Register

+	AT91_REG	 EMAC_ISR; 	// Interrupt Status Register

+	AT91_REG	 EMAC_IER; 	// Interrupt Enable Register

+	AT91_REG	 EMAC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 EMAC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 EMAC_MAN; 	// PHY Maintenance Register

+	AT91_REG	 EMAC_PTR; 	// Pause Time Register

+	AT91_REG	 EMAC_PFR; 	// Pause Frames received Register

+	AT91_REG	 EMAC_FTO; 	// Frames Transmitted OK Register

+	AT91_REG	 EMAC_SCF; 	// Single Collision Frame Register

+	AT91_REG	 EMAC_MCF; 	// Multiple Collision Frame Register

+	AT91_REG	 EMAC_FRO; 	// Frames Received OK Register

+	AT91_REG	 EMAC_FCSE; 	// Frame Check Sequence Error Register

+	AT91_REG	 EMAC_ALE; 	// Alignment Error Register

+	AT91_REG	 EMAC_DTF; 	// Deferred Transmission Frame Register

+	AT91_REG	 EMAC_LCOL; 	// Late Collision Register

+	AT91_REG	 EMAC_ECOL; 	// Excessive Collision Register

+	AT91_REG	 EMAC_TUND; 	// Transmit Underrun Error Register

+	AT91_REG	 EMAC_CSE; 	// Carrier Sense Error Register

+	AT91_REG	 EMAC_RRE; 	// Receive Ressource Error Register

+	AT91_REG	 EMAC_ROV; 	// Receive Overrun Errors Register

+	AT91_REG	 EMAC_RSE; 	// Receive Symbol Errors Register

+	AT91_REG	 EMAC_ELE; 	// Excessive Length Errors Register

+	AT91_REG	 EMAC_RJA; 	// Receive Jabbers Register

+	AT91_REG	 EMAC_USF; 	// Undersize Frames Register

+	AT91_REG	 EMAC_STE; 	// SQE Test Error Register

+	AT91_REG	 EMAC_RLE; 	// Receive Length Field Mismatch Register

+	AT91_REG	 EMAC_TPF; 	// Transmitted Pause Frames Register

+	AT91_REG	 EMAC_HRB; 	// Hash Address Bottom[31:0]

+	AT91_REG	 EMAC_HRT; 	// Hash Address Top[63:32]

+	AT91_REG	 EMAC_SA1L; 	// Specific Address 1 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA1H; 	// Specific Address 1 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA2L; 	// Specific Address 2 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA2H; 	// Specific Address 2 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA3L; 	// Specific Address 3 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA3H; 	// Specific Address 3 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA4L; 	// Specific Address 4 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA4H; 	// Specific Address 4 Top, Last 2 bytes

+	AT91_REG	 EMAC_TID; 	// Type ID Checking Register

+	AT91_REG	 EMAC_TPQ; 	// Transmit Pause Quantum Register

+	AT91_REG	 EMAC_USRIO; 	// USER Input/Output Register

+	AT91_REG	 EMAC_WOL; 	// Wake On LAN Register

+	AT91_REG	 Reserved1[13]; 	// 

+	AT91_REG	 EMAC_REV; 	// Revision Register

+} AT91S_EMAC, *AT91PS_EMAC;

+

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB         ((unsigned int) 0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB        ((unsigned int) 0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE         ((unsigned int) 0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE         ((unsigned int) 0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE        ((unsigned int) 0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT    ((unsigned int) 0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT    ((unsigned int) 0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT     ((unsigned int) 0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP         ((unsigned int) 0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART     ((unsigned int) 0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT      ((unsigned int) 0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR       ((unsigned int) 0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ        ((unsigned int) 0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD        ((unsigned int) 0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD         ((unsigned int) 0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME     ((unsigned int) 0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF        ((unsigned int) 0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC        ((unsigned int) 0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI        ((unsigned int) 0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI        ((unsigned int) 0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG        ((unsigned int) 0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE        ((unsigned int) 0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK        ((unsigned int) 0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               ((unsigned int) 0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              ((unsigned int) 0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              ((unsigned int) 0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              ((unsigned int) 0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY        ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE        ((unsigned int) 0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF       ((unsigned int) 0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             ((unsigned int) 0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             ((unsigned int) 0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             ((unsigned int) 0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             ((unsigned int) 0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE       ((unsigned int) 0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS      ((unsigned int) 0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD      ((unsigned int) 0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS     ((unsigned int) 0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR      ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO       ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE       ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES       ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO        ((unsigned int) 0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX        ((unsigned int) 0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND        ((unsigned int) 0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR        ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP      ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR      ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR      ((unsigned int) 0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR      ((unsigned int) 0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR      ((unsigned int) 0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP      ((unsigned int) 0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK       ((unsigned int) 0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR       ((unsigned int) 0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP      ((unsigned int) 0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE       ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ        ((unsigned int) 0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA       ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE       ((unsigned int) 0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA       ((unsigned int) 0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA       ((unsigned int) 0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW         ((unsigned int) 0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF        ((unsigned int) 0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII       ((unsigned int) 0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP         ((unsigned int) 0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG        ((unsigned int) 0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP        ((unsigned int) 0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1        ((unsigned int) 0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF     ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF    ((unsigned int) 0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+typedef struct _AT91S_ADC {

+	AT91_REG	 ADC_CR; 	// ADC Control Register

+	AT91_REG	 ADC_MR; 	// ADC Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 ADC_CHER; 	// ADC Channel Enable Register

+	AT91_REG	 ADC_CHDR; 	// ADC Channel Disable Register

+	AT91_REG	 ADC_CHSR; 	// ADC Channel Status Register

+	AT91_REG	 ADC_SR; 	// ADC Status Register

+	AT91_REG	 ADC_LCDR; 	// ADC Last Converted Data Register

+	AT91_REG	 ADC_IER; 	// ADC Interrupt Enable Register

+	AT91_REG	 ADC_IDR; 	// ADC Interrupt Disable Register

+	AT91_REG	 ADC_IMR; 	// ADC Interrupt Mask Register

+	AT91_REG	 ADC_CDR0; 	// ADC Channel Data Register 0

+	AT91_REG	 ADC_CDR1; 	// ADC Channel Data Register 1

+	AT91_REG	 ADC_CDR2; 	// ADC Channel Data Register 2

+	AT91_REG	 ADC_CDR3; 	// ADC Channel Data Register 3

+	AT91_REG	 ADC_CDR4; 	// ADC Channel Data Register 4

+	AT91_REG	 ADC_CDR5; 	// ADC Channel Data Register 5

+	AT91_REG	 ADC_CDR6; 	// ADC Channel Data Register 6

+	AT91_REG	 ADC_CDR7; 	// ADC Channel Data Register 7

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 ADC_RPR; 	// Receive Pointer Register

+	AT91_REG	 ADC_RCR; 	// Receive Counter Register

+	AT91_REG	 ADC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 ADC_TCR; 	// Transmit Counter Register

+	AT91_REG	 ADC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 ADC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 ADC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 ADC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 ADC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 ADC_PTSR; 	// PDC Transfer Status Register

+} AT91S_ADC, *AT91PS_ADC;

+

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST       ((unsigned int) 0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START       ((unsigned int) 0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN       ((unsigned int) 0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  ((unsigned int) 0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   ((unsigned int) 0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL      ((unsigned int) 0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                ((unsigned int) 0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                ((unsigned int) 0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                ((unsigned int) 0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                ((unsigned int) 0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                ((unsigned int) 0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                ((unsigned int) 0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  ((unsigned int) 0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES      ((unsigned int) 0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               ((unsigned int) 0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                ((unsigned int) 0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP       ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          ((unsigned int) 0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL     ((unsigned int) 0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP     ((unsigned int) 0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM       ((unsigned int) 0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0         ((unsigned int) 0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1         ((unsigned int) 0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2         ((unsigned int) 0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3         ((unsigned int) 0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4         ((unsigned int) 0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5         ((unsigned int) 0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6         ((unsigned int) 0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7         ((unsigned int) 0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0        ((unsigned int) 0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1        ((unsigned int) 0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2        ((unsigned int) 0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3        ((unsigned int) 0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4        ((unsigned int) 0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5        ((unsigned int) 0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6        ((unsigned int) 0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7        ((unsigned int) 0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0       ((unsigned int) 0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1       ((unsigned int) 0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2       ((unsigned int) 0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3       ((unsigned int) 0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4       ((unsigned int) 0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5       ((unsigned int) 0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6       ((unsigned int) 0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7       ((unsigned int) 0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY        ((unsigned int) 0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE       ((unsigned int) 0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX       ((unsigned int) 0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF      ((unsigned int) 0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA       ((unsigned int) 0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA        ((unsigned int) 0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_AES {

+	AT91_REG	 AES_CR; 	// Control Register

+	AT91_REG	 AES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AES_IER; 	// Interrupt Enable Register

+	AT91_REG	 AES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 AES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AES_ISR; 	// Interrupt Status Register

+	AT91_REG	 AES_KEYWxR[4]; 	// Key Word x Register

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91_REG	 AES_IDATAxR[4]; 	// Input Data x Register

+	AT91_REG	 AES_ODATAxR[4]; 	// Output Data x Register

+	AT91_REG	 AES_IVxR[4]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved2[35]; 	// 

+	AT91_REG	 AES_VR; 	// AES Version Register

+	AT91_REG	 AES_RPR; 	// Receive Pointer Register

+	AT91_REG	 AES_RCR; 	// Receive Counter Register

+	AT91_REG	 AES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 AES_TCR; 	// Transmit Counter Register

+	AT91_REG	 AES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 AES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 AES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 AES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 AES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 AES_PTSR; 	// PDC Transfer Status Register

+} AT91S_AES, *AT91PS_AES;

+

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START       ((unsigned int) 0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST       ((unsigned int) 0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED    ((unsigned int) 0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER      ((unsigned int) 0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY     ((unsigned int) 0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD        ((unsigned int) 0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD       ((unsigned int) 0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  ((unsigned int) 0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD         ((unsigned int) 0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS        ((unsigned int) 0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              ((unsigned int) 0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               ((unsigned int) 0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               ((unsigned int) 0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               ((unsigned int) 0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                ((unsigned int) 0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY        ((unsigned int) 0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE       ((unsigned int) 0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             ((unsigned int) 0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             ((unsigned int) 0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             ((unsigned int) 0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             ((unsigned int) 0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             ((unsigned int) 0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY      ((unsigned int) 0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX       ((unsigned int) 0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX       ((unsigned int) 0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF      ((unsigned int) 0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE      ((unsigned int) 0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD        ((unsigned int) 0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT        ((unsigned int) 0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  ((unsigned int) 0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY ((unsigned int) 0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          ((unsigned int) 0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_TDES {

+	AT91_REG	 TDES_CR; 	// Control Register

+	AT91_REG	 TDES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TDES_IER; 	// Interrupt Enable Register

+	AT91_REG	 TDES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TDES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TDES_ISR; 	// Interrupt Status Register

+	AT91_REG	 TDES_KEY1WxR[2]; 	// Key 1 Word x Register

+	AT91_REG	 TDES_KEY2WxR[2]; 	// Key 2 Word x Register

+	AT91_REG	 TDES_KEY3WxR[2]; 	// Key 3 Word x Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 TDES_IDATAxR[2]; 	// Input Data x Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 TDES_ODATAxR[2]; 	// Output Data x Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 TDES_IVxR[2]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved4[37]; 	// 

+	AT91_REG	 TDES_VR; 	// TDES Version Register

+	AT91_REG	 TDES_RPR; 	// Receive Pointer Register

+	AT91_REG	 TDES_RCR; 	// Receive Counter Register

+	AT91_REG	 TDES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 TDES_TCR; 	// Transmit Counter Register

+	AT91_REG	 TDES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 TDES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 TDES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 TDES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 TDES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 TDES_PTSR; 	// PDC Transfer Status Register

+} AT91S_TDES, *AT91PS_TDES;

+

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START      ((unsigned int) 0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST      ((unsigned int) 0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER     ((unsigned int) 0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD    ((unsigned int) 0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD     ((unsigned int) 0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD       ((unsigned int) 0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD      ((unsigned int) 0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD        ((unsigned int) 0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS       ((unsigned int) 0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               ((unsigned int) 0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               ((unsigned int) 0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               ((unsigned int) 0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                ((unsigned int) 0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY     ((unsigned int) 0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX      ((unsigned int) 0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX      ((unsigned int) 0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF     ((unsigned int) 0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE     ((unsigned int) 0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD       ((unsigned int) 0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT       ((unsigned int) 0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          ((unsigned int) 0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X256

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR   ((AT91_REG *) 	0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR   ((AT91_REG *) 	0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR   ((AT91_REG *) 	0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR   ((AT91_REG *) 	0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR ((AT91_REG *) 	0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR   ((AT91_REG *) 	0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR  ((AT91_REG *) 	0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR  ((AT91_REG *) 	0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR   ((AT91_REG *) 	0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR   ((AT91_REG *) 	0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR   ((AT91_REG *) 	0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER  ((AT91_REG *) 	0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR  ((AT91_REG *) 	0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR  ((AT91_REG *) 	0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR  ((AT91_REG *) 	0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR  ((AT91_REG *) 	0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR  ((AT91_REG *) 	0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU   ((AT91_REG *) 	0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR  ((AT91_REG *) 	0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR ((AT91_REG *) 	0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR ((AT91_REG *) 	0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR  ((AT91_REG *) 	0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR  ((AT91_REG *) 	0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR  ((AT91_REG *) 	0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR ((AT91_REG *) 	0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR ((AT91_REG *) 	0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR ((AT91_REG *) 	0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR ((AT91_REG *) 	0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID ((AT91_REG *) 	0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR ((AT91_REG *) 	0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR  ((AT91_REG *) 	0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR  ((AT91_REG *) 	0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR ((AT91_REG *) 	0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR   ((AT91_REG *) 	0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR  ((AT91_REG *) 	0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR   ((AT91_REG *) 	0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR ((AT91_REG *) 	0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR  ((AT91_REG *) 	0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR  ((AT91_REG *) 	0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER  ((AT91_REG *) 	0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR  ((AT91_REG *) 	0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR ((AT91_REG *) 	0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR  ((AT91_REG *) 	0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR ((AT91_REG *) 	0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER  ((AT91_REG *) 	0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR ((AT91_REG *) 	0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR  ((AT91_REG *) 	0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER  ((AT91_REG *) 	0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR ((AT91_REG *) 	0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR ((AT91_REG *) 	0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR ((AT91_REG *) 	0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR  ((AT91_REG *) 	0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR ((AT91_REG *) 	0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR ((AT91_REG *) 	0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR ((AT91_REG *) 	0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR  ((AT91_REG *) 	0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER ((AT91_REG *) 	0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER ((AT91_REG *) 	0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR ((AT91_REG *) 	0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER ((AT91_REG *) 	0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR  ((AT91_REG *) 	0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR  ((AT91_REG *) 	0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR ((AT91_REG *) 	0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR ((AT91_REG *) 	0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER ((AT91_REG *) 	0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR  ((AT91_REG *) 	0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR ((AT91_REG *) 	0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER  ((AT91_REG *) 	0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR  ((AT91_REG *) 	0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR ((AT91_REG *) 	0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER ((AT91_REG *) 	0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR ((AT91_REG *) 	0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR  ((AT91_REG *) 	0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR  ((AT91_REG *) 	0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR ((AT91_REG *) 	0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR  ((AT91_REG *) 	0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER  ((AT91_REG *) 	0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR ((AT91_REG *) 	0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER ((AT91_REG *) 	0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR ((AT91_REG *) 	0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR ((AT91_REG *) 	0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR ((AT91_REG *) 	0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR  ((AT91_REG *) 	0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR ((AT91_REG *) 	0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR  ((AT91_REG *) 	0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR  ((AT91_REG *) 	0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR ((AT91_REG *) 	0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER ((AT91_REG *) 	0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR ((AT91_REG *) 	0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR  ((AT91_REG *) 	0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR ((AT91_REG *) 	0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR  ((AT91_REG *) 	0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR ((AT91_REG *) 	0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER ((AT91_REG *) 	0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR  ((AT91_REG *) 	0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR ((AT91_REG *) 	0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER  ((AT91_REG *) 	0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER  ((AT91_REG *) 	0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR  ((AT91_REG *) 	0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR ((AT91_REG *) 	0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR ((AT91_REG *) 	0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR   ((AT91_REG *) 	0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR   ((AT91_REG *) 	0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR  ((AT91_REG *) 	0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER  ((AT91_REG *) 	0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR  ((AT91_REG *) 	0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR  ((AT91_REG *) 	0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR  ((AT91_REG *) 	0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR  ((AT91_REG *) 	0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR  ((AT91_REG *) 	0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR  ((AT91_REG *) 	0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR  ((AT91_REG *) 	0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER  ((AT91_REG *) 	0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR   ((AT91_REG *) 	0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER   ((AT91_REG *) 	0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR    ((AT91_REG *) 	0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR  ((AT91_REG *) 	0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR  ((AT91_REG *) 	0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR  ((AT91_REG *) 	0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR ((AT91_REG *) 	0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR ((AT91_REG *) 	0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR ((AT91_REG *) 	0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR ((AT91_REG *) 	0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR ((AT91_REG *) 	0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR ((AT91_REG *) 	0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR ((AT91_REG *) 	0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR ((AT91_REG *) 	0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR ((AT91_REG *) 	0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR ((AT91_REG *) 	0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR ((AT91_REG *) 	0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR   ((AT91_REG *) 	0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR    ((AT91_REG *) 	0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR    ((AT91_REG *) 	0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR    ((AT91_REG *) 	0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR   ((AT91_REG *) 	0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR    ((AT91_REG *) 	0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR    ((AT91_REG *) 	0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR ((AT91_REG *) 	0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR  ((AT91_REG *) 	0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR ((AT91_REG *) 	0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR  ((AT91_REG *) 	0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR ((AT91_REG *) 	0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR  ((AT91_REG *) 	0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR  ((AT91_REG *) 	0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR ((AT91_REG *) 	0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR ((AT91_REG *) 	0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR ((AT91_REG *) 	0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR  ((AT91_REG *) 	0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER  ((AT91_REG *) 	0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR   ((AT91_REG *) 	0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR  ((AT91_REG *) 	0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR  ((AT91_REG *) 	0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR   ((AT91_REG *) 	0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR  ((AT91_REG *) 	0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR   ((AT91_REG *) 	0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR  ((AT91_REG *) 	0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR ((AT91_REG *) 	0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR  ((AT91_REG *) 	0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR  ((AT91_REG *) 	0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR  ((AT91_REG *) 	0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR ((AT91_REG *) 	0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR ((AT91_REG *) 	0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR  ((AT91_REG *) 	0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR ((AT91_REG *) 	0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR ((AT91_REG *) 	0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR ((AT91_REG *) 	0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER  ((AT91_REG *) 	0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR   ((AT91_REG *) 	0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR  ((AT91_REG *) 	0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR   ((AT91_REG *) 	0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR   ((AT91_REG *) 	0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR  ((AT91_REG *) 	0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR  ((AT91_REG *) 	0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR  ((AT91_REG *) 	0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR  ((AT91_REG *) 	0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR  ((AT91_REG *) 	0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR  ((AT91_REG *) 	0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR   ((AT91_REG *) 	0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR  ((AT91_REG *) 	0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR  ((AT91_REG *) 	0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR   ((AT91_REG *) 	0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR  ((AT91_REG *) 	0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR   ((AT91_REG *) 	0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR  ((AT91_REG *) 	0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR   ((AT91_REG *) 	0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF    ((AT91_REG *) 	0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER   ((AT91_REG *) 	0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR  ((AT91_REG *) 	0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR   ((AT91_REG *) 	0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR   ((AT91_REG *) 	0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER   ((AT91_REG *) 	0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR   ((AT91_REG *) 	0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR  ((AT91_REG *) 	0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR   ((AT91_REG *) 	0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR  ((AT91_REG *) 	0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR   ((AT91_REG *) 	0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI  ((AT91_REG *) 	0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR    ((AT91_REG *) 	0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR    ((AT91_REG *) 	0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR  ((AT91_REG *) 	0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR  ((AT91_REG *) 	0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR   ((AT91_REG *) 	0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR  ((AT91_REG *) 	0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR  ((AT91_REG *) 	0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR  ((AT91_REG *) 	0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR   ((AT91_REG *) 	0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR   ((AT91_REG *) 	0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR   ((AT91_REG *) 	0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR  ((AT91_REG *) 	0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR  ((AT91_REG *) 	0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER   ((AT91_REG *) 	0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR    ((AT91_REG *) 	0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR   ((AT91_REG *) 	0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI  ((AT91_REG *) 	0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR  ((AT91_REG *) 	0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR    ((AT91_REG *) 	0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR  ((AT91_REG *) 	0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR   ((AT91_REG *) 	0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR   ((AT91_REG *) 	0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR   ((AT91_REG *) 	0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR   ((AT91_REG *) 	0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF    ((AT91_REG *) 	0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER   ((AT91_REG *) 	0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR  ((AT91_REG *) 	0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR   ((AT91_REG *) 	0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR  ((AT91_REG *) 	0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR   ((AT91_REG *) 	0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR  ((AT91_REG *) 	0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR   ((AT91_REG *) 	0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR   ((AT91_REG *) 	0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR  ((AT91_REG *) 	0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR  ((AT91_REG *) 	0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR  ((AT91_REG *) 	0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR   ((AT91_REG *) 	0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR  ((AT91_REG *) 	0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR  ((AT91_REG *) 	0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR   ((AT91_REG *) 	0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR   ((AT91_REG *) 	0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR  ((AT91_REG *) 	0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER   ((AT91_REG *) 	0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR  ((AT91_REG *) 	0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR    ((AT91_REG *) 	0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR   ((AT91_REG *) 	0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR  ((AT91_REG *) 	0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR    ((AT91_REG *) 	0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR   ((AT91_REG *) 	0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR  ((AT91_REG *) 	0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER   ((AT91_REG *) 	0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR    ((AT91_REG *) 	0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR    ((AT91_REG *) 	0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR   ((AT91_REG *) 	0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR   ((AT91_REG *) 	0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR   ((AT91_REG *) 	0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR  ((AT91_REG *) 	0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR   ((AT91_REG *) 	0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR  ((AT91_REG *) 	0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR   ((AT91_REG *) 	0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR ((AT91_REG *) 	0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved ((AT91_REG *) 	0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR ((AT91_REG *) 	0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR ((AT91_REG *) 	0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR ((AT91_REG *) 	0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR ((AT91_REG *) 	0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved ((AT91_REG *) 	0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR ((AT91_REG *) 	0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR ((AT91_REG *) 	0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR ((AT91_REG *) 	0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR ((AT91_REG *) 	0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR ((AT91_REG *) 	0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved ((AT91_REG *) 	0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR ((AT91_REG *) 	0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR ((AT91_REG *) 	0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR ((AT91_REG *) 	0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR ((AT91_REG *) 	0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR ((AT91_REG *) 	0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved ((AT91_REG *) 	0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR ((AT91_REG *) 	0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR ((AT91_REG *) 	0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR ((AT91_REG *) 	0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR ((AT91_REG *) 	0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR ((AT91_REG *) 	0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR  ((AT91_REG *) 	0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS  ((AT91_REG *) 	0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER  ((AT91_REG *) 	0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR   ((AT91_REG *) 	0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR  ((AT91_REG *) 	0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR   ((AT91_REG *) 	0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR  ((AT91_REG *) 	0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR   ((AT91_REG *) 	0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA  ((AT91_REG *) 	0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR   ((AT91_REG *) 	0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR ((AT91_REG *) 	0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM   ((AT91_REG *) 	0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR   ((AT91_REG *) 	0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR   ((AT91_REG *) 	0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR   ((AT91_REG *) 	0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR   ((AT91_REG *) 	0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR   ((AT91_REG *) 	0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP ((AT91_REG *) 	0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC  ((AT91_REG *) 	0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE ((AT91_REG *) 	0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER   ((AT91_REG *) 	0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR    ((AT91_REG *) 	0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC    ((AT91_REG *) 	0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB    ((AT91_REG *) 	0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR   ((AT91_REG *) 	0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR   ((AT91_REG *) 	0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER   ((AT91_REG *) 	0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA    ((AT91_REG *) 	0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR   ((AT91_REG *) 	0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV    ((AT91_REG *) 	0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR   ((AT91_REG *) 	0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB    ((AT91_REG *) 	0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR   ((AT91_REG *) 	0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER   ((AT91_REG *) 	0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR   ((AT91_REG *) 	0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR    ((AT91_REG *) 	0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR   ((AT91_REG *) 	0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA    ((AT91_REG *) 	0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC    ((AT91_REG *) 	0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR   ((AT91_REG *) 	0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV    ((AT91_REG *) 	0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR   ((AT91_REG *) 	0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR   ((AT91_REG *) 	0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV    ((AT91_REG *) 	0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA    ((AT91_REG *) 	0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB    ((AT91_REG *) 	0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR   ((AT91_REG *) 	0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR   ((AT91_REG *) 	0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC    ((AT91_REG *) 	0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER   ((AT91_REG *) 	0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR    ((AT91_REG *) 	0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR   ((AT91_REG *) 	0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR   ((AT91_REG *) 	0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL ((AT91_REG *) 	0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM ((AT91_REG *) 	0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR ((AT91_REG *) 	0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID ((AT91_REG *) 	0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR ((AT91_REG *) 	0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID ((AT91_REG *) 	0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH ((AT91_REG *) 	0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR ((AT91_REG *) 	0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL ((AT91_REG *) 	0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID ((AT91_REG *) 	0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR ((AT91_REG *) 	0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR ((AT91_REG *) 	0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM ((AT91_REG *) 	0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH ((AT91_REG *) 	0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR ((AT91_REG *) 	0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID ((AT91_REG *) 	0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR ((AT91_REG *) 	0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH ((AT91_REG *) 	0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID ((AT91_REG *) 	0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL ((AT91_REG *) 	0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR ((AT91_REG *) 	0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM ((AT91_REG *) 	0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID ((AT91_REG *) 	0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR ((AT91_REG *) 	0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID ((AT91_REG *) 	0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM ((AT91_REG *) 	0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID ((AT91_REG *) 	0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR ((AT91_REG *) 	0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR ((AT91_REG *) 	0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR ((AT91_REG *) 	0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL ((AT91_REG *) 	0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH ((AT91_REG *) 	0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID ((AT91_REG *) 	0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR ((AT91_REG *) 	0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH ((AT91_REG *) 	0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID ((AT91_REG *) 	0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR ((AT91_REG *) 	0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR ((AT91_REG *) 	0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL ((AT91_REG *) 	0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM ((AT91_REG *) 	0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR ((AT91_REG *) 	0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR ((AT91_REG *) 	0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID ((AT91_REG *) 	0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH ((AT91_REG *) 	0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID ((AT91_REG *) 	0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR ((AT91_REG *) 	0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL ((AT91_REG *) 	0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM ((AT91_REG *) 	0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID ((AT91_REG *) 	0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID ((AT91_REG *) 	0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM ((AT91_REG *) 	0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR ((AT91_REG *) 	0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL ((AT91_REG *) 	0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR ((AT91_REG *) 	0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH ((AT91_REG *) 	0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR ((AT91_REG *) 	0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR ((AT91_REG *) 	0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH ((AT91_REG *) 	0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID ((AT91_REG *) 	0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL ((AT91_REG *) 	0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID ((AT91_REG *) 	0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR ((AT91_REG *) 	0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM ((AT91_REG *) 	0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR ((AT91_REG *) 	0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR   ((AT91_REG *) 	0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR   ((AT91_REG *) 	0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER   ((AT91_REG *) 	0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR   ((AT91_REG *) 	0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP ((AT91_REG *) 	0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR    ((AT91_REG *) 	0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR   ((AT91_REG *) 	0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR   ((AT91_REG *) 	0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM   ((AT91_REG *) 	0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR    ((AT91_REG *) 	0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR    ((AT91_REG *) 	0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR    ((AT91_REG *) 	0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR  ((AT91_REG *) 	0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H ((AT91_REG *) 	0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L ((AT91_REG *) 	0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE  ((AT91_REG *) 	0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL ((AT91_REG *) 	0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE  ((AT91_REG *) 	0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL  ((AT91_REG *) 	0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF  ((AT91_REG *) 	0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND ((AT91_REG *) 	0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR  ((AT91_REG *) 	0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L ((AT91_REG *) 	0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR  ((AT91_REG *) 	0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L ((AT91_REG *) 	0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR  ((AT91_REG *) 	0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR  ((AT91_REG *) 	0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE  ((AT91_REG *) 	0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL ((AT91_REG *) 	0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID  ((AT91_REG *) 	0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB  ((AT91_REG *) 	0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP ((AT91_REG *) 	0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO ((AT91_REG *) 	0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR  ((AT91_REG *) 	0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H ((AT91_REG *) 	0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV  ((AT91_REG *) 	0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE  ((AT91_REG *) 	0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA  ((AT91_REG *) 	0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP ((AT91_REG *) 	0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF  ((AT91_REG *) 	0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR ((AT91_REG *) 	0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT  ((AT91_REG *) 	0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF  ((AT91_REG *) 	0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE ((AT91_REG *) 	0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ  ((AT91_REG *) 	0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN  ((AT91_REG *) 	0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO  ((AT91_REG *) 	0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV  ((AT91_REG *) 	0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR  ((AT91_REG *) 	0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF  ((AT91_REG *) 	0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR  ((AT91_REG *) 	0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF  ((AT91_REG *) 	0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR  ((AT91_REG *) 	0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L ((AT91_REG *) 	0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO  ((AT91_REG *) 	0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER  ((AT91_REG *) 	0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H ((AT91_REG *) 	0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE  ((AT91_REG *) 	0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H ((AT91_REG *) 	0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE  ((AT91_REG *) 	0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE  ((AT91_REG *) 	0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR  ((AT91_REG *) 	0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR  ((AT91_REG *) 	0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR  ((AT91_REG *) 	0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR  ((AT91_REG *) 	0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR  ((AT91_REG *) 	0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR  ((AT91_REG *) 	0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR   ((AT91_REG *) 	0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR   ((AT91_REG *) 	0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR   ((AT91_REG *) 	0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR   ((AT91_REG *) 	0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2  ((AT91_REG *) 	0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3  ((AT91_REG *) 	0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0  ((AT91_REG *) 	0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5  ((AT91_REG *) 	0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR  ((AT91_REG *) 	0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR    ((AT91_REG *) 	0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4  ((AT91_REG *) 	0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1  ((AT91_REG *) 	0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR  ((AT91_REG *) 	0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR   ((AT91_REG *) 	0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR    ((AT91_REG *) 	0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7  ((AT91_REG *) 	0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6  ((AT91_REG *) 	0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER   ((AT91_REG *) 	0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER  ((AT91_REG *) 	0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR  ((AT91_REG *) 	0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR    ((AT91_REG *) 	0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR   ((AT91_REG *) 	0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR   ((AT91_REG *) 	0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR  ((AT91_REG *) 	0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR  ((AT91_REG *) 	0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR  ((AT91_REG *) 	0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR   ((AT91_REG *) 	0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR   ((AT91_REG *) 	0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR  ((AT91_REG *) 	0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR  ((AT91_REG *) 	0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR   ((AT91_REG *) 	0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR  ((AT91_REG *) 	0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR  ((AT91_REG *) 	0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR    ((AT91_REG *) 	0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR    ((AT91_REG *) 	0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR ((AT91_REG *) 	0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR ((AT91_REG *) 	0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR    ((AT91_REG *) 	0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR   ((AT91_REG *) 	0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR   ((AT91_REG *) 	0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER   ((AT91_REG *) 	0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR ((AT91_REG *) 	0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR   ((AT91_REG *) 	0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR ((AT91_REG *) 	0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR  ((AT91_REG *) 	0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR  ((AT91_REG *) 	0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR ((AT91_REG *) 	0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR ((AT91_REG *) 	0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR  ((AT91_REG *) 	0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR ((AT91_REG *) 	0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR  ((AT91_REG *) 	0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR ((AT91_REG *) 	0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR ((AT91_REG *) 	0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR ((AT91_REG *) 	0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR ((AT91_REG *) 	0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR  ((AT91_REG *) 	0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR   ((AT91_REG *) 	0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR ((AT91_REG *) 	0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR ((AT91_REG *) 	0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR  ((AT91_REG *) 	0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR   ((AT91_REG *) 	0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR   ((AT91_REG *) 	0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER  ((AT91_REG *) 	0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR  ((AT91_REG *) 	0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR ((AT91_REG *) 	0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR ((AT91_REG *) 	0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_PIO_PA0        ((unsigned int) 1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0     ((unsigned int) AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1        ((unsigned int) 1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0     ((unsigned int) AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10       ((unsigned int) 1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD      ((unsigned int) AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11       ((unsigned int) 1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK     ((unsigned int) AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12       ((unsigned int) 1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00   ((unsigned int) AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13       ((unsigned int) 1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01   ((unsigned int) AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1     ((unsigned int) AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14       ((unsigned int) 1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02   ((unsigned int) AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1     ((unsigned int) AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15       ((unsigned int) 1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03   ((unsigned int) AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2    ((unsigned int) AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16       ((unsigned int) 1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0    ((unsigned int) AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17       ((unsigned int) 1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0    ((unsigned int) AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18       ((unsigned int) 1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0    ((unsigned int) AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19       ((unsigned int) 1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX    ((unsigned int) AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2        ((unsigned int) 1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0     ((unsigned int) AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11   ((unsigned int) AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20       ((unsigned int) 1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX    ((unsigned int) AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21       ((unsigned int) 1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF       ((unsigned int) AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10   ((unsigned int) AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22       ((unsigned int) 1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK       ((unsigned int) AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1    ((unsigned int) AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23       ((unsigned int) 1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD       ((unsigned int) AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1    ((unsigned int) AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24       ((unsigned int) 1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD       ((unsigned int) AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1    ((unsigned int) AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25       ((unsigned int) 1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK       ((unsigned int) AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11   ((unsigned int) AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26       ((unsigned int) 1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF       ((unsigned int) AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12   ((unsigned int) AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27       ((unsigned int) 1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD     ((unsigned int) AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3     ((unsigned int) AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28       ((unsigned int) 1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD     ((unsigned int) AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29       ((unsigned int) 1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ      ((unsigned int) AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13   ((unsigned int) AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3        ((unsigned int) 1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0     ((unsigned int) AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12   ((unsigned int) AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30       ((unsigned int) 1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0     ((unsigned int) AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2     ((unsigned int) AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4        ((unsigned int) 1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0     ((unsigned int) AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13   ((unsigned int) AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5        ((unsigned int) 1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1     ((unsigned int) AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6        ((unsigned int) 1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1     ((unsigned int) AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7        ((unsigned int) 1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1     ((unsigned int) AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01   ((unsigned int) AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8        ((unsigned int) 1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1     ((unsigned int) AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02   ((unsigned int) AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9        ((unsigned int) 1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1     ((unsigned int) AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03   ((unsigned int) AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0        ((unsigned int) 1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK ((unsigned int) AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0     ((unsigned int) AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1        ((unsigned int) 1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN    ((unsigned int) AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10       ((unsigned int) 1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2     ((unsigned int) AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11   ((unsigned int) AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11       ((unsigned int) 1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3     ((unsigned int) AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12   ((unsigned int) AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12       ((unsigned int) 1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER    ((unsigned int) AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0    ((unsigned int) AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13       ((unsigned int) 1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2     ((unsigned int) AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01   ((unsigned int) AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14       ((unsigned int) 1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3     ((unsigned int) AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02   ((unsigned int) AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15       ((unsigned int) 1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV    ((unsigned int) AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16       ((unsigned int) 1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL     ((unsigned int) AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13   ((unsigned int) AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17       ((unsigned int) 1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK    ((unsigned int) AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03   ((unsigned int) AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18       ((unsigned int) 1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100    ((unsigned int) AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG    ((unsigned int) AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19       ((unsigned int) 1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0     ((unsigned int) AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1    ((unsigned int) AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2        ((unsigned int) 1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0     ((unsigned int) AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20       ((unsigned int) 1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1     ((unsigned int) AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0     ((unsigned int) AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21       ((unsigned int) 1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2     ((unsigned int) AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1     ((unsigned int) AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22       ((unsigned int) 1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3     ((unsigned int) AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2     ((unsigned int) AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23       ((unsigned int) 1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0    ((unsigned int) AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1     ((unsigned int) AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24       ((unsigned int) 1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0    ((unsigned int) AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1     ((unsigned int) AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25       ((unsigned int) 1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1    ((unsigned int) AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1     ((unsigned int) AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26       ((unsigned int) 1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1    ((unsigned int) AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1      ((unsigned int) AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27       ((unsigned int) 1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2    ((unsigned int) AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0     ((unsigned int) AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28       ((unsigned int) 1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2    ((unsigned int) AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1     ((unsigned int) AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29       ((unsigned int) 1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1     ((unsigned int) AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2     ((unsigned int) AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3        ((unsigned int) 1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1     ((unsigned int) AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30       ((unsigned int) 1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2     ((unsigned int) AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3     ((unsigned int) AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4        ((unsigned int) 1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV ((unsigned int) AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5        ((unsigned int) 1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0     ((unsigned int) AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6        ((unsigned int) 1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1     ((unsigned int) AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7        ((unsigned int) 1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER    ((unsigned int) AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8        ((unsigned int) 1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC     ((unsigned int) AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9        ((unsigned int) 1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO    ((unsigned int) AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ID_FIQ    ((unsigned int)  0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS    ((unsigned int)  1) // System Peripheral

+#define AT91C_ID_PIOA   ((unsigned int)  2) // Parallel IO Controller A

+#define AT91C_ID_PIOB   ((unsigned int)  3) // Parallel IO Controller B

+#define AT91C_ID_SPI0   ((unsigned int)  4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1   ((unsigned int)  5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0    ((unsigned int)  6) // USART 0

+#define AT91C_ID_US1    ((unsigned int)  7) // USART 1

+#define AT91C_ID_SSC    ((unsigned int)  8) // Serial Synchronous Controller

+#define AT91C_ID_TWI    ((unsigned int)  9) // Two-Wire Interface

+#define AT91C_ID_PWMC   ((unsigned int) 10) // PWM Controller

+#define AT91C_ID_UDP    ((unsigned int) 11) // USB Device Port

+#define AT91C_ID_TC0    ((unsigned int) 12) // Timer Counter 0

+#define AT91C_ID_TC1    ((unsigned int) 13) // Timer Counter 1

+#define AT91C_ID_TC2    ((unsigned int) 14) // Timer Counter 2

+#define AT91C_ID_CAN    ((unsigned int) 15) // Control Area Network Controller

+#define AT91C_ID_EMAC   ((unsigned int) 16) // Ethernet MAC

+#define AT91C_ID_ADC    ((unsigned int) 17) // Analog-to-Digital Converter

+#define AT91C_ID_AES    ((unsigned int) 18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES   ((unsigned int) 19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved ((unsigned int) 20) // Reserved

+#define AT91C_ID_21_Reserved ((unsigned int) 21) // Reserved

+#define AT91C_ID_22_Reserved ((unsigned int) 22) // Reserved

+#define AT91C_ID_23_Reserved ((unsigned int) 23) // Reserved

+#define AT91C_ID_24_Reserved ((unsigned int) 24) // Reserved

+#define AT91C_ID_25_Reserved ((unsigned int) 25) // Reserved

+#define AT91C_ID_26_Reserved ((unsigned int) 26) // Reserved

+#define AT91C_ID_27_Reserved ((unsigned int) 27) // Reserved

+#define AT91C_ID_28_Reserved ((unsigned int) 28) // Reserved

+#define AT91C_ID_29_Reserved ((unsigned int) 29) // Reserved

+#define AT91C_ID_IRQ0   ((unsigned int) 30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1   ((unsigned int) 31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_BASE_SYS       ((AT91PS_SYS) 	0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC       ((AT91PS_AIC) 	0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU  ((AT91PS_PDC) 	0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU      ((AT91PS_DBGU) 	0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA      ((AT91PS_PIO) 	0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB      ((AT91PS_PIO) 	0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR      ((AT91PS_CKGR) 	0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC       ((AT91PS_PMC) 	0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC      ((AT91PS_RSTC) 	0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC      ((AT91PS_RTTC) 	0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC      ((AT91PS_PITC) 	0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC      ((AT91PS_WDTC) 	0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG      ((AT91PS_VREG) 	0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC        ((AT91PS_MC) 	0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1  ((AT91PS_PDC) 	0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1      ((AT91PS_SPI) 	0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0  ((AT91PS_PDC) 	0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0      ((AT91PS_SPI) 	0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1   ((AT91PS_PDC) 	0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1       ((AT91PS_USART) 	0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0   ((AT91PS_PDC) 	0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0       ((AT91PS_USART) 	0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC   ((AT91PS_PDC) 	0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC       ((AT91PS_SSC) 	0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI       ((AT91PS_TWI) 	0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3  ((AT91PS_PWMC_CH) 	0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2  ((AT91PS_PWMC_CH) 	0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1  ((AT91PS_PWMC_CH) 	0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0  ((AT91PS_PWMC_CH) 	0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC      ((AT91PS_PWMC) 	0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP       ((AT91PS_UDP) 	0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0       ((AT91PS_TC) 	0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1       ((AT91PS_TC) 	0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2       ((AT91PS_TC) 	0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB       ((AT91PS_TCB) 	0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0   ((AT91PS_CAN_MB) 	0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1   ((AT91PS_CAN_MB) 	0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2   ((AT91PS_CAN_MB) 	0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3   ((AT91PS_CAN_MB) 	0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4   ((AT91PS_CAN_MB) 	0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5   ((AT91PS_CAN_MB) 	0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6   ((AT91PS_CAN_MB) 	0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7   ((AT91PS_CAN_MB) 	0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN       ((AT91PS_CAN) 	0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC      ((AT91PS_EMAC) 	0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC   ((AT91PS_PDC) 	0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC       ((AT91PS_ADC) 	0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES   ((AT91PS_PDC) 	0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES       ((AT91PS_AES) 	0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES  ((AT91PS_PDC) 	0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES      ((AT91PS_TDES) 	0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ISRAM	 ((char *) 	0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	 ((unsigned int) 0x00010000) // Internal SRAM size in byte (64 Kbyte)

+#define AT91C_IFLASH	 ((char *) 	0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	 ((unsigned int) 0x00040000) // Internal ROM size in byte (256 Kbyte)

+

+

+

+// - Hardware register definition

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR System Peripherals

+// - *****************************************************************************

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// - *****************************************************************************

+// - -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#if 0 /*_RB_*/

+AT91C_AIC_PRIOR           EQU (0x7 <<  0) ;- (AIC) Priority Level

+AT91C_AIC_PRIOR_LOWEST    EQU (0x0) ;- (AIC) Lowest priority level

+AT91C_AIC_PRIOR_HIGHEST   EQU (0x7) ;- (AIC) Highest priority level

+AT91C_AIC_SRCTYPE         EQU (0x3 <<  5) ;- (AIC) Interrupt Source Type

+AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL EQU (0x0 <<  5) ;- (AIC) Internal Sources Code Label High-level Sensitive

+AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL EQU (0x0 <<  5) ;- (AIC) External Sources Code Label Low-level Sensitive

+AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE EQU (0x1 <<  5) ;- (AIC) Internal Sources Code Label Positive Edge triggered

+AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE EQU (0x1 <<  5) ;- (AIC) External Sources Code Label Negative Edge triggered

+AT91C_AIC_SRCTYPE_HIGH_LEVEL EQU (0x2 <<  5) ;- (AIC) Internal Or External Sources Code Label High-level Sensitive

+AT91C_AIC_SRCTYPE_POSITIVE_EDGE EQU (0x3 <<  5) ;- (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// - -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+AT91C_AIC_NFIQ            EQU (0x1 <<  0) ;- (AIC) NFIQ Status

+AT91C_AIC_NIRQ            EQU (0x1 <<  1) ;- (AIC) NIRQ Status

+// - -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+AT91C_AIC_DCR_PROT        EQU (0x1 <<  0) ;- (AIC) Protection Mode

+AT91C_AIC_DCR_GMSK        EQU (0x1 <<  1) ;- (AIC) General Mask

+#endif

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// - *****************************************************************************

+// - -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+AT91C_PDC_RXTEN           EQU (0x1 <<  0) ;- (PDC) Receiver Transfer Enable

+AT91C_PDC_RXTDIS          EQU (0x1 <<  1) ;- (PDC) Receiver Transfer Disable

+AT91C_PDC_TXTEN           EQU (0x1 <<  8) ;- (PDC) Transmitter Transfer Enable

+AT91C_PDC_TXTDIS          EQU (0x1 <<  9) ;- (PDC) Transmitter Transfer Disable

+// - -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Debug Unit

+// - *****************************************************************************

+// - -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+AT91C_US_RSTRX            EQU (0x1 <<  2) ;- (DBGU) Reset Receiver

+AT91C_US_RSTTX            EQU (0x1 <<  3) ;- (DBGU) Reset Transmitter

+AT91C_US_RXEN             EQU (0x1 <<  4) ;- (DBGU) Receiver Enable

+AT91C_US_RXDIS            EQU (0x1 <<  5) ;- (DBGU) Receiver Disable

+AT91C_US_TXEN             EQU (0x1 <<  6) ;- (DBGU) Transmitter Enable

+AT91C_US_TXDIS            EQU (0x1 <<  7) ;- (DBGU) Transmitter Disable

+AT91C_US_RSTSTA           EQU (0x1 <<  8) ;- (DBGU) Reset Status Bits

+// - -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+AT91C_US_PAR              EQU (0x7 <<  9) ;- (DBGU) Parity type

+AT91C_US_PAR_EVEN         EQU (0x0 <<  9) ;- (DBGU) Even Parity

+AT91C_US_PAR_ODD          EQU (0x1 <<  9) ;- (DBGU) Odd Parity

+AT91C_US_PAR_SPACE        EQU (0x2 <<  9) ;- (DBGU) Parity forced to 0 (Space)

+AT91C_US_PAR_MARK         EQU (0x3 <<  9) ;- (DBGU) Parity forced to 1 (Mark)

+AT91C_US_PAR_NONE         EQU (0x4 <<  9) ;- (DBGU) No Parity

+AT91C_US_PAR_MULTI_DROP   EQU (0x6 <<  9) ;- (DBGU) Multi-drop mode

+AT91C_US_CHMODE           EQU (0x3 << 14) ;- (DBGU) Channel Mode

+AT91C_US_CHMODE_NORMAL    EQU (0x0 << 14) ;- (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+AT91C_US_CHMODE_AUTO      EQU (0x1 << 14) ;- (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+AT91C_US_CHMODE_LOCAL     EQU (0x2 << 14) ;- (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+AT91C_US_CHMODE_REMOTE    EQU (0x3 << 14) ;- (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// - -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+AT91C_US_RXRDY            EQU (0x1 <<  0) ;- (DBGU) RXRDY Interrupt

+AT91C_US_TXRDY            EQU (0x1 <<  1) ;- (DBGU) TXRDY Interrupt

+AT91C_US_ENDRX            EQU (0x1 <<  3) ;- (DBGU) End of Receive Transfer Interrupt

+AT91C_US_ENDTX            EQU (0x1 <<  4) ;- (DBGU) End of Transmit Interrupt

+AT91C_US_OVRE             EQU (0x1 <<  5) ;- (DBGU) Overrun Interrupt

+AT91C_US_FRAME            EQU (0x1 <<  6) ;- (DBGU) Framing Error Interrupt

+AT91C_US_PARE             EQU (0x1 <<  7) ;- (DBGU) Parity Error Interrupt

+AT91C_US_TXEMPTY          EQU (0x1 <<  9) ;- (DBGU) TXEMPTY Interrupt

+AT91C_US_TXBUFE           EQU (0x1 << 11) ;- (DBGU) TXBUFE Interrupt

+AT91C_US_RXBUFF           EQU (0x1 << 12) ;- (DBGU) RXBUFF Interrupt

+AT91C_US_COMM_TX          EQU (0x1 << 30) ;- (DBGU) COMM_TX Interrupt

+AT91C_US_COMM_RX          EQU (0x1 << 31) ;- (DBGU) COMM_RX Interrupt

+// - -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// - -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// - -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// - -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+AT91C_US_FORCE_NTRST      EQU (0x1 <<  0) ;- (DBGU) Force NTRST in JTAG

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// - *****************************************************************************

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// - *****************************************************************************

+// - -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+AT91C_CKGR_MOSCEN         EQU (0x1 <<  0) ;- (CKGR) Main Oscillator Enable

+AT91C_CKGR_OSCBYPASS      EQU (0x1 <<  1) ;- (CKGR) Main Oscillator Bypass

+AT91C_CKGR_OSCOUNT        EQU (0xFF <<  8) ;- (CKGR) Main Oscillator Start-up Time

+// - -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+AT91C_CKGR_MAINF          EQU (0xFFFF <<  0) ;- (CKGR) Main Clock Frequency

+AT91C_CKGR_MAINRDY        EQU (0x1 << 16) ;- (CKGR) Main Clock Ready

+// - -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+AT91C_CKGR_DIV            EQU (0xFF <<  0) ;- (CKGR) Divider Selected

+AT91C_CKGR_DIV_0          EQU (0x0) ;- (CKGR) Divider output is 0

+AT91C_CKGR_DIV_BYPASS     EQU (0x1) ;- (CKGR) Divider is bypassed

+AT91C_CKGR_PLLCOUNT       EQU (0x3F <<  8) ;- (CKGR) PLL Counter

+AT91C_CKGR_OUT            EQU (0x3 << 14) ;- (CKGR) PLL Output Frequency Range

+AT91C_CKGR_OUT_0          EQU (0x0 << 14) ;- (CKGR) Please refer to the PLL datasheet

+AT91C_CKGR_OUT_1          EQU (0x1 << 14) ;- (CKGR) Please refer to the PLL datasheet

+AT91C_CKGR_OUT_2          EQU (0x2 << 14) ;- (CKGR) Please refer to the PLL datasheet

+AT91C_CKGR_OUT_3          EQU (0x3 << 14) ;- (CKGR) Please refer to the PLL datasheet

+AT91C_CKGR_MUL            EQU (0x7FF << 16) ;- (CKGR) PLL Multiplier

+AT91C_CKGR_USBDIV         EQU (0x3 << 28) ;- (CKGR) Divider for USB Clocks

+AT91C_CKGR_USBDIV_0       EQU (0x0 << 28) ;- (CKGR) Divider output is PLL clock output

+AT91C_CKGR_USBDIV_1       EQU (0x1 << 28) ;- (CKGR) Divider output is PLL clock output divided by 2

+AT91C_CKGR_USBDIV_2       EQU (0x2 << 28) ;- (CKGR) Divider output is PLL clock output divided by 4

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Power Management Controler

+// - *****************************************************************************

+// - -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+AT91C_PMC_PCK             EQU (0x1 <<  0) ;- (PMC) Processor Clock

+AT91C_PMC_UDP             EQU (0x1 <<  7) ;- (PMC) USB Device Port Clock

+AT91C_PMC_PCK0            EQU (0x1 <<  8) ;- (PMC) Programmable Clock Output

+AT91C_PMC_PCK1            EQU (0x1 <<  9) ;- (PMC) Programmable Clock Output

+AT91C_PMC_PCK2            EQU (0x1 << 10) ;- (PMC) Programmable Clock Output

+AT91C_PMC_PCK3            EQU (0x1 << 11) ;- (PMC) Programmable Clock Output

+// - -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// - -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// - -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// - -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// - -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// - -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+AT91C_PMC_CSS             EQU (0x3 <<  0) ;- (PMC) Programmable Clock Selection

+AT91C_PMC_CSS_SLOW_CLK    EQU (0x0) ;- (PMC) Slow Clock is selected

+AT91C_PMC_CSS_MAIN_CLK    EQU (0x1) ;- (PMC) Main Clock is selected

+AT91C_PMC_CSS_PLL_CLK     EQU (0x3) ;- (PMC) Clock from PLL is selected

+AT91C_PMC_PRES            EQU (0x7 <<  2) ;- (PMC) Programmable Clock Prescaler

+AT91C_PMC_PRES_CLK        EQU (0x0 <<  2) ;- (PMC) Selected clock

+AT91C_PMC_PRES_CLK_2      EQU (0x1 <<  2) ;- (PMC) Selected clock divided by 2

+AT91C_PMC_PRES_CLK_4      EQU (0x2 <<  2) ;- (PMC) Selected clock divided by 4

+AT91C_PMC_PRES_CLK_8      EQU (0x3 <<  2) ;- (PMC) Selected clock divided by 8

+AT91C_PMC_PRES_CLK_16     EQU (0x4 <<  2) ;- (PMC) Selected clock divided by 16

+AT91C_PMC_PRES_CLK_32     EQU (0x5 <<  2) ;- (PMC) Selected clock divided by 32

+AT91C_PMC_PRES_CLK_64     EQU (0x6 <<  2) ;- (PMC) Selected clock divided by 64

+// - -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// - -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+AT91C_PMC_MOSCS           EQU (0x1 <<  0) ;- (PMC) MOSC Status/Enable/Disable/Mask

+AT91C_PMC_LOCK            EQU (0x1 <<  2) ;- (PMC) PLL Status/Enable/Disable/Mask

+AT91C_PMC_MCKRDY          EQU (0x1 <<  3) ;- (PMC) MCK_RDY Status/Enable/Disable/Mask

+AT91C_PMC_PCK0RDY         EQU (0x1 <<  8) ;- (PMC) PCK0_RDY Status/Enable/Disable/Mask

+AT91C_PMC_PCK1RDY         EQU (0x1 <<  9) ;- (PMC) PCK1_RDY Status/Enable/Disable/Mask

+AT91C_PMC_PCK2RDY         EQU (0x1 << 10) ;- (PMC) PCK2_RDY Status/Enable/Disable/Mask

+AT91C_PMC_PCK3RDY         EQU (0x1 << 11) ;- (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// - -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// - -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// - -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// - *****************************************************************************

+// - -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+AT91C_RSTC_PROCRST        EQU (0x1 <<  0) ;- (RSTC) Processor Reset

+AT91C_RSTC_PERRST         EQU (0x1 <<  2) ;- (RSTC) Peripheral Reset

+AT91C_RSTC_EXTRST         EQU (0x1 <<  3) ;- (RSTC) External Reset

+AT91C_RSTC_KEY            EQU (0xFF << 24) ;- (RSTC) Password

+// - -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+AT91C_RSTC_URSTS          EQU (0x1 <<  0) ;- (RSTC) User Reset Status

+AT91C_RSTC_BODSTS         EQU (0x1 <<  1) ;- (RSTC) Brownout Detection Status

+AT91C_RSTC_RSTTYP         EQU (0x7 <<  8) ;- (RSTC) Reset Type

+AT91C_RSTC_RSTTYP_POWERUP EQU (0x0 <<  8) ;- (RSTC) Power-up Reset. VDDCORE rising.

+AT91C_RSTC_RSTTYP_WAKEUP  EQU (0x1 <<  8) ;- (RSTC) WakeUp Reset. VDDCORE rising.

+AT91C_RSTC_RSTTYP_WATCHDOG EQU (0x2 <<  8) ;- (RSTC) Watchdog Reset. Watchdog overflow occured.

+AT91C_RSTC_RSTTYP_SOFTWARE EQU (0x3 <<  8) ;- (RSTC) Software Reset. Processor reset required by the software.

+AT91C_RSTC_RSTTYP_USER    EQU (0x4 <<  8) ;- (RSTC) User Reset. NRST pin detected low.

+AT91C_RSTC_RSTTYP_BROWNOUT EQU (0x5 <<  8) ;- (RSTC) Brownout Reset occured.

+AT91C_RSTC_NRSTL          EQU (0x1 << 16) ;- (RSTC) NRST pin level

+AT91C_RSTC_SRCMP          EQU (0x1 << 17) ;- (RSTC) Software Reset Command in Progress.

+// - -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+AT91C_RSTC_URSTEN         EQU (0x1 <<  0) ;- (RSTC) User Reset Enable

+AT91C_RSTC_URSTIEN        EQU (0x1 <<  4) ;- (RSTC) User Reset Interrupt Enable

+AT91C_RSTC_ERSTL          EQU (0xF <<  8) ;- (RSTC) User Reset Enable

+AT91C_RSTC_BODIEN         EQU (0x1 << 16) ;- (RSTC) Brownout Detection Interrupt Enable

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// - *****************************************************************************

+// - -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+AT91C_RTTC_RTPRES         EQU (0xFFFF <<  0) ;- (RTTC) Real-time Timer Prescaler Value

+AT91C_RTTC_ALMIEN         EQU (0x1 << 16) ;- (RTTC) Alarm Interrupt Enable

+AT91C_RTTC_RTTINCIEN      EQU (0x1 << 17) ;- (RTTC) Real Time Timer Increment Interrupt Enable

+AT91C_RTTC_RTTRST         EQU (0x1 << 18) ;- (RTTC) Real Time Timer Restart

+// - -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+AT91C_RTTC_ALMV           EQU (0x0 <<  0) ;- (RTTC) Alarm Value

+// - -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+AT91C_RTTC_CRTV           EQU (0x0 <<  0) ;- (RTTC) Current Real-time Value

+// - -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+AT91C_RTTC_ALMS           EQU (0x1 <<  0) ;- (RTTC) Real-time Alarm Status

+AT91C_RTTC_RTTINC         EQU (0x1 <<  1) ;- (RTTC) Real-time Timer Increment

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// - *****************************************************************************

+// - -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+AT91C_PITC_PIV            EQU (0xFFFFF <<  0) ;- (PITC) Periodic Interval Value

+AT91C_PITC_PITEN          EQU (0x1 << 24) ;- (PITC) Periodic Interval Timer Enabled

+AT91C_PITC_PITIEN         EQU (0x1 << 25) ;- (PITC) Periodic Interval Timer Interrupt Enable

+// - -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+AT91C_PITC_PITS           EQU (0x1 <<  0) ;- (PITC) Periodic Interval Timer Status

+// - -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+AT91C_PITC_CPIV           EQU (0xFFFFF <<  0) ;- (PITC) Current Periodic Interval Value

+AT91C_PITC_PICNT          EQU (0xFFF << 20) ;- (PITC) Periodic Interval Counter

+// - -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// - *****************************************************************************

+// - -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+AT91C_WDTC_WDRSTT         EQU (0x1 <<  0) ;- (WDTC) Watchdog Restart

+AT91C_WDTC_KEY            EQU (0xFF << 24) ;- (WDTC) Watchdog KEY Password

+// - -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+AT91C_WDTC_WDV            EQU (0xFFF <<  0) ;- (WDTC) Watchdog Timer Restart

+AT91C_WDTC_WDFIEN         EQU (0x1 << 12) ;- (WDTC) Watchdog Fault Interrupt Enable

+AT91C_WDTC_WDRSTEN        EQU (0x1 << 13) ;- (WDTC) Watchdog Reset Enable

+AT91C_WDTC_WDRPROC        EQU (0x1 << 14) ;- (WDTC) Watchdog Timer Restart

+AT91C_WDTC_WDDIS          EQU (0x1 << 15) ;- (WDTC) Watchdog Disable

+AT91C_WDTC_WDD            EQU (0xFFF << 16) ;- (WDTC) Watchdog Delta Value

+AT91C_WDTC_WDDBGHLT       EQU (0x1 << 28) ;- (WDTC) Watchdog Debug Halt

+AT91C_WDTC_WDIDLEHLT      EQU (0x1 << 29) ;- (WDTC) Watchdog Idle Halt

+// - -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+AT91C_WDTC_WDUNF          EQU (0x1 <<  0) ;- (WDTC) Watchdog Underflow

+AT91C_WDTC_WDERR          EQU (0x1 <<  1) ;- (WDTC) Watchdog Error

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// - *****************************************************************************

+// - -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+AT91C_VREG_PSTDBY         EQU (0x1 <<  0) ;- (VREG) Voltage Regulator Power Standby Mode

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// - *****************************************************************************

+// - -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+AT91C_MC_RCB              EQU (0x1 <<  0) ;- (MC) Remap Command Bit

+// - -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+AT91C_MC_UNDADD           EQU (0x1 <<  0) ;- (MC) Undefined Addess Abort Status

+AT91C_MC_MISADD           EQU (0x1 <<  1) ;- (MC) Misaligned Addess Abort Status

+AT91C_MC_ABTSZ            EQU (0x3 <<  8) ;- (MC) Abort Size Status

+AT91C_MC_ABTSZ_BYTE       EQU (0x0 <<  8) ;- (MC) Byte

+AT91C_MC_ABTSZ_HWORD      EQU (0x1 <<  8) ;- (MC) Half-word

+AT91C_MC_ABTSZ_WORD       EQU (0x2 <<  8) ;- (MC) Word

+AT91C_MC_ABTTYP           EQU (0x3 << 10) ;- (MC) Abort Type Status

+AT91C_MC_ABTTYP_DATAR     EQU (0x0 << 10) ;- (MC) Data Read

+AT91C_MC_ABTTYP_DATAW     EQU (0x1 << 10) ;- (MC) Data Write

+AT91C_MC_ABTTYP_FETCH     EQU (0x2 << 10) ;- (MC) Code Fetch

+AT91C_MC_MST0             EQU (0x1 << 16) ;- (MC) Master 0 Abort Source

+AT91C_MC_MST1             EQU (0x1 << 17) ;- (MC) Master 1 Abort Source

+AT91C_MC_SVMST0           EQU (0x1 << 24) ;- (MC) Saved Master 0 Abort Source

+AT91C_MC_SVMST1           EQU (0x1 << 25) ;- (MC) Saved Master 1 Abort Source

+// - -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+AT91C_MC_FRDY             EQU (0x1 <<  0) ;- (MC) Flash Ready

+AT91C_MC_LOCKE            EQU (0x1 <<  2) ;- (MC) Lock Error

+AT91C_MC_PROGE            EQU (0x1 <<  3) ;- (MC) Programming Error

+AT91C_MC_NEBP             EQU (0x1 <<  7) ;- (MC) No Erase Before Programming

+AT91C_MC_FWS              EQU (0x3 <<  8) ;- (MC) Flash Wait State

+AT91C_MC_FWS_0FWS         EQU (0x0 <<  8) ;- (MC) 1 cycle for Read, 2 for Write operations

+AT91C_MC_FWS_1FWS         EQU (0x1 <<  8) ;- (MC) 2 cycles for Read, 3 for Write operations

+AT91C_MC_FWS_2FWS         EQU (0x2 <<  8) ;- (MC) 3 cycles for Read, 4 for Write operations

+AT91C_MC_FWS_3FWS         EQU (0x3 <<  8) ;- (MC) 4 cycles for Read, 4 for Write operations

+AT91C_MC_FMCN             EQU (0xFF << 16) ;- (MC) Flash Microsecond Cycle Number

+// - -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+AT91C_MC_FCMD             EQU (0xF <<  0) ;- (MC) Flash Command

+AT91C_MC_FCMD_START_PROG  EQU (0x1) ;- (MC) Starts the programming of th epage specified by PAGEN.

+AT91C_MC_FCMD_LOCK        EQU (0x2) ;- (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+AT91C_MC_FCMD_PROG_AND_LOCK EQU (0x3) ;- (MC) The lock sequence automatically happens after the programming sequence is completed.

+AT91C_MC_FCMD_UNLOCK      EQU (0x4) ;- (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+AT91C_MC_FCMD_ERASE_ALL   EQU (0x8) ;- (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+AT91C_MC_FCMD_SET_GP_NVM  EQU (0xB) ;- (MC) Set General Purpose NVM bits.

+AT91C_MC_FCMD_CLR_GP_NVM  EQU (0xD) ;- (MC) Clear General Purpose NVM bits.

+AT91C_MC_FCMD_SET_SECURITY EQU (0xF) ;- (MC) Set Security Bit.

+AT91C_MC_PAGEN            EQU (0x3FF <<  8) ;- (MC) Page Number

+AT91C_MC_KEY              EQU (0xFF << 24) ;- (MC) Writing Protect Key

+// - -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+AT91C_MC_SECURITY         EQU (0x1 <<  4) ;- (MC) Security Bit Status

+AT91C_MC_GPNVM0           EQU (0x1 <<  8) ;- (MC) Sector 0 Lock Status

+AT91C_MC_GPNVM1           EQU (0x1 <<  9) ;- (MC) Sector 1 Lock Status

+AT91C_MC_GPNVM2           EQU (0x1 << 10) ;- (MC) Sector 2 Lock Status

+AT91C_MC_GPNVM3           EQU (0x1 << 11) ;- (MC) Sector 3 Lock Status

+AT91C_MC_GPNVM4           EQU (0x1 << 12) ;- (MC) Sector 4 Lock Status

+AT91C_MC_GPNVM5           EQU (0x1 << 13) ;- (MC) Sector 5 Lock Status

+AT91C_MC_GPNVM6           EQU (0x1 << 14) ;- (MC) Sector 6 Lock Status

+AT91C_MC_GPNVM7           EQU (0x1 << 15) ;- (MC) Sector 7 Lock Status

+AT91C_MC_LOCKS0           EQU (0x1 << 16) ;- (MC) Sector 0 Lock Status

+AT91C_MC_LOCKS1           EQU (0x1 << 17) ;- (MC) Sector 1 Lock Status

+AT91C_MC_LOCKS2           EQU (0x1 << 18) ;- (MC) Sector 2 Lock Status

+AT91C_MC_LOCKS3           EQU (0x1 << 19) ;- (MC) Sector 3 Lock Status

+AT91C_MC_LOCKS4           EQU (0x1 << 20) ;- (MC) Sector 4 Lock Status

+AT91C_MC_LOCKS5           EQU (0x1 << 21) ;- (MC) Sector 5 Lock Status

+AT91C_MC_LOCKS6           EQU (0x1 << 22) ;- (MC) Sector 6 Lock Status

+AT91C_MC_LOCKS7           EQU (0x1 << 23) ;- (MC) Sector 7 Lock Status

+AT91C_MC_LOCKS8           EQU (0x1 << 24) ;- (MC) Sector 8 Lock Status

+AT91C_MC_LOCKS9           EQU (0x1 << 25) ;- (MC) Sector 9 Lock Status

+AT91C_MC_LOCKS10          EQU (0x1 << 26) ;- (MC) Sector 10 Lock Status

+AT91C_MC_LOCKS11          EQU (0x1 << 27) ;- (MC) Sector 11 Lock Status

+AT91C_MC_LOCKS12          EQU (0x1 << 28) ;- (MC) Sector 12 Lock Status

+AT91C_MC_LOCKS13          EQU (0x1 << 29) ;- (MC) Sector 13 Lock Status

+AT91C_MC_LOCKS14          EQU (0x1 << 30) ;- (MC) Sector 14 Lock Status

+AT91C_MC_LOCKS15          EQU (0x1 << 31) ;- (MC) Sector 15 Lock Status

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// - *****************************************************************************

+// - -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+AT91C_SPI_SPIEN           EQU (0x1 <<  0) ;- (SPI) SPI Enable

+AT91C_SPI_SPIDIS          EQU (0x1 <<  1) ;- (SPI) SPI Disable

+AT91C_SPI_SWRST           EQU (0x1 <<  7) ;- (SPI) SPI Software reset

+AT91C_SPI_LASTXFER        EQU (0x1 << 24) ;- (SPI) SPI Last Transfer

+// - -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+AT91C_SPI_MSTR            EQU (0x1 <<  0) ;- (SPI) Master/Slave Mode

+AT91C_SPI_PS              EQU (0x1 <<  1) ;- (SPI) Peripheral Select

+AT91C_SPI_PS_FIXED        EQU (0x0 <<  1) ;- (SPI) Fixed Peripheral Select

+AT91C_SPI_PS_VARIABLE     EQU (0x1 <<  1) ;- (SPI) Variable Peripheral Select

+AT91C_SPI_PCSDEC          EQU (0x1 <<  2) ;- (SPI) Chip Select Decode

+AT91C_SPI_FDIV            EQU (0x1 <<  3) ;- (SPI) Clock Selection

+AT91C_SPI_MODFDIS         EQU (0x1 <<  4) ;- (SPI) Mode Fault Detection

+AT91C_SPI_LLB             EQU (0x1 <<  7) ;- (SPI) Clock Selection

+AT91C_SPI_PCS             EQU (0xF << 16) ;- (SPI) Peripheral Chip Select

+AT91C_SPI_DLYBCS          EQU (0xFF << 24) ;- (SPI) Delay Between Chip Selects

+// - -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+AT91C_SPI_RD              EQU (0xFFFF <<  0) ;- (SPI) Receive Data

+AT91C_SPI_RPCS            EQU (0xF << 16) ;- (SPI) Peripheral Chip Select Status

+// - -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+AT91C_SPI_TD              EQU (0xFFFF <<  0) ;- (SPI) Transmit Data

+AT91C_SPI_TPCS            EQU (0xF << 16) ;- (SPI) Peripheral Chip Select Status

+// - -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+AT91C_SPI_RDRF            EQU (0x1 <<  0) ;- (SPI) Receive Data Register Full

+AT91C_SPI_TDRE            EQU (0x1 <<  1) ;- (SPI) Transmit Data Register Empty

+AT91C_SPI_MODF            EQU (0x1 <<  2) ;- (SPI) Mode Fault Error

+AT91C_SPI_OVRES           EQU (0x1 <<  3) ;- (SPI) Overrun Error Status

+AT91C_SPI_ENDRX           EQU (0x1 <<  4) ;- (SPI) End of Receiver Transfer

+AT91C_SPI_ENDTX           EQU (0x1 <<  5) ;- (SPI) End of Receiver Transfer

+AT91C_SPI_RXBUFF          EQU (0x1 <<  6) ;- (SPI) RXBUFF Interrupt

+AT91C_SPI_TXBUFE          EQU (0x1 <<  7) ;- (SPI) TXBUFE Interrupt

+AT91C_SPI_NSSR            EQU (0x1 <<  8) ;- (SPI) NSSR Interrupt

+AT91C_SPI_TXEMPTY         EQU (0x1 <<  9) ;- (SPI) TXEMPTY Interrupt

+AT91C_SPI_SPIENS          EQU (0x1 << 16) ;- (SPI) Enable Status

+// - -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// - -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// - -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// - -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+AT91C_SPI_CPOL            EQU (0x1 <<  0) ;- (SPI) Clock Polarity

+AT91C_SPI_NCPHA           EQU (0x1 <<  1) ;- (SPI) Clock Phase

+AT91C_SPI_CSAAT           EQU (0x1 <<  3) ;- (SPI) Chip Select Active After Transfer

+AT91C_SPI_BITS            EQU (0xF <<  4) ;- (SPI) Bits Per Transfer

+AT91C_SPI_BITS_8          EQU (0x0 <<  4) ;- (SPI) 8 Bits Per transfer

+AT91C_SPI_BITS_9          EQU (0x1 <<  4) ;- (SPI) 9 Bits Per transfer

+AT91C_SPI_BITS_10         EQU (0x2 <<  4) ;- (SPI) 10 Bits Per transfer

+AT91C_SPI_BITS_11         EQU (0x3 <<  4) ;- (SPI) 11 Bits Per transfer

+AT91C_SPI_BITS_12         EQU (0x4 <<  4) ;- (SPI) 12 Bits Per transfer

+AT91C_SPI_BITS_13         EQU (0x5 <<  4) ;- (SPI) 13 Bits Per transfer

+AT91C_SPI_BITS_14         EQU (0x6 <<  4) ;- (SPI) 14 Bits Per transfer

+AT91C_SPI_BITS_15         EQU (0x7 <<  4) ;- (SPI) 15 Bits Per transfer

+AT91C_SPI_BITS_16         EQU (0x8 <<  4) ;- (SPI) 16 Bits Per transfer

+AT91C_SPI_SCBR            EQU (0xFF <<  8) ;- (SPI) Serial Clock Baud Rate

+AT91C_SPI_DLYBS           EQU (0xFF << 16) ;- (SPI) Delay Before SPCK

+AT91C_SPI_DLYBCT          EQU (0xFF << 24) ;- (SPI) Delay Between Consecutive Transfers

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Usart

+// - *****************************************************************************

+// - -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+AT91C_US_STTBRK           EQU (0x1 <<  9) ;- (USART) Start Break

+AT91C_US_STPBRK           EQU (0x1 << 10) ;- (USART) Stop Break

+AT91C_US_STTTO            EQU (0x1 << 11) ;- (USART) Start Time-out

+AT91C_US_SENDA            EQU (0x1 << 12) ;- (USART) Send Address

+AT91C_US_RSTIT            EQU (0x1 << 13) ;- (USART) Reset Iterations

+AT91C_US_RSTNACK          EQU (0x1 << 14) ;- (USART) Reset Non Acknowledge

+AT91C_US_RETTO            EQU (0x1 << 15) ;- (USART) Rearm Time-out

+AT91C_US_DTREN            EQU (0x1 << 16) ;- (USART) Data Terminal ready Enable

+AT91C_US_DTRDIS           EQU (0x1 << 17) ;- (USART) Data Terminal ready Disable

+AT91C_US_RTSEN            EQU (0x1 << 18) ;- (USART) Request to Send enable

+AT91C_US_RTSDIS           EQU (0x1 << 19) ;- (USART) Request to Send Disable

+// - -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+AT91C_US_USMODE           EQU (0xF <<  0) ;- (USART) Usart mode

+AT91C_US_USMODE_NORMAL    EQU (0x0) ;- (USART) Normal

+AT91C_US_USMODE_RS485     EQU (0x1) ;- (USART) RS485

+AT91C_US_USMODE_HWHSH     EQU (0x2) ;- (USART) Hardware Handshaking

+AT91C_US_USMODE_MODEM     EQU (0x3) ;- (USART) Modem

+AT91C_US_USMODE_ISO7816_0 EQU (0x4) ;- (USART) ISO7816 protocol: T = 0

+AT91C_US_USMODE_ISO7816_1 EQU (0x6) ;- (USART) ISO7816 protocol: T = 1

+AT91C_US_USMODE_IRDA      EQU (0x8) ;- (USART) IrDA

+AT91C_US_USMODE_SWHSH     EQU (0xC) ;- (USART) Software Handshaking

+AT91C_US_CLKS             EQU (0x3 <<  4) ;- (USART) Clock Selection (Baud Rate generator Input Clock

+AT91C_US_CLKS_CLOCK       EQU (0x0 <<  4) ;- (USART) Clock

+AT91C_US_CLKS_FDIV1       EQU (0x1 <<  4) ;- (USART) fdiv1

+AT91C_US_CLKS_SLOW        EQU (0x2 <<  4) ;- (USART) slow_clock (ARM)

+AT91C_US_CLKS_EXT         EQU (0x3 <<  4) ;- (USART) External (SCK)

+AT91C_US_CHRL             EQU (0x3 <<  6) ;- (USART) Clock Selection (Baud Rate generator Input Clock

+AT91C_US_CHRL_5_BITS      EQU (0x0 <<  6) ;- (USART) Character Length: 5 bits

+AT91C_US_CHRL_6_BITS      EQU (0x1 <<  6) ;- (USART) Character Length: 6 bits

+AT91C_US_CHRL_7_BITS      EQU (0x2 <<  6) ;- (USART) Character Length: 7 bits

+AT91C_US_CHRL_8_BITS      EQU (0x3 <<  6) ;- (USART) Character Length: 8 bits

+AT91C_US_SYNC             EQU (0x1 <<  8) ;- (USART) Synchronous Mode Select

+AT91C_US_NBSTOP           EQU (0x3 << 12) ;- (USART) Number of Stop bits

+AT91C_US_NBSTOP_1_BIT     EQU (0x0 << 12) ;- (USART) 1 stop bit

+AT91C_US_NBSTOP_15_BIT    EQU (0x1 << 12) ;- (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+AT91C_US_NBSTOP_2_BIT     EQU (0x2 << 12) ;- (USART) 2 stop bits

+AT91C_US_MSBF             EQU (0x1 << 16) ;- (USART) Bit Order

+AT91C_US_MODE9            EQU (0x1 << 17) ;- (USART) 9-bit Character length

+AT91C_US_CKLO             EQU (0x1 << 18) ;- (USART) Clock Output Select

+AT91C_US_OVER             EQU (0x1 << 19) ;- (USART) Over Sampling Mode

+AT91C_US_INACK            EQU (0x1 << 20) ;- (USART) Inhibit Non Acknowledge

+AT91C_US_DSNACK           EQU (0x1 << 21) ;- (USART) Disable Successive NACK

+AT91C_US_MAX_ITER         EQU (0x1 << 24) ;- (USART) Number of Repetitions

+AT91C_US_FILTER           EQU (0x1 << 28) ;- (USART) Receive Line Filter

+// - -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+AT91C_US_RXBRK            EQU (0x1 <<  2) ;- (USART) Break Received/End of Break

+AT91C_US_TIMEOUT          EQU (0x1 <<  8) ;- (USART) Receiver Time-out

+AT91C_US_ITERATION        EQU (0x1 << 10) ;- (USART) Max number of Repetitions Reached

+AT91C_US_NACK             EQU (0x1 << 13) ;- (USART) Non Acknowledge

+AT91C_US_RIIC             EQU (0x1 << 16) ;- (USART) Ring INdicator Input Change Flag

+AT91C_US_DSRIC            EQU (0x1 << 17) ;- (USART) Data Set Ready Input Change Flag

+AT91C_US_DCDIC            EQU (0x1 << 18) ;- (USART) Data Carrier Flag

+AT91C_US_CTSIC            EQU (0x1 << 19) ;- (USART) Clear To Send Input Change Flag

+// - -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// - -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// - -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+AT91C_US_RI               EQU (0x1 << 20) ;- (USART) Image of RI Input

+AT91C_US_DSR              EQU (0x1 << 21) ;- (USART) Image of DSR Input

+AT91C_US_DCD              EQU (0x1 << 22) ;- (USART) Image of DCD Input

+AT91C_US_CTS              EQU (0x1 << 23) ;- (USART) Image of CTS Input

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// - *****************************************************************************

+// - -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+AT91C_SSC_RXEN            EQU (0x1 <<  0) ;- (SSC) Receive Enable

+AT91C_SSC_RXDIS           EQU (0x1 <<  1) ;- (SSC) Receive Disable

+AT91C_SSC_TXEN            EQU (0x1 <<  8) ;- (SSC) Transmit Enable

+AT91C_SSC_TXDIS           EQU (0x1 <<  9) ;- (SSC) Transmit Disable

+AT91C_SSC_SWRST           EQU (0x1 << 15) ;- (SSC) Software Reset

+// - -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+AT91C_SSC_CKS             EQU (0x3 <<  0) ;- (SSC) Receive/Transmit Clock Selection

+AT91C_SSC_CKS_DIV         EQU (0x0) ;- (SSC) Divided Clock

+AT91C_SSC_CKS_TK          EQU (0x1) ;- (SSC) TK Clock signal

+AT91C_SSC_CKS_RK          EQU (0x2) ;- (SSC) RK pin

+AT91C_SSC_CKO             EQU (0x7 <<  2) ;- (SSC) Receive/Transmit Clock Output Mode Selection

+AT91C_SSC_CKO_NONE        EQU (0x0 <<  2) ;- (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+AT91C_SSC_CKO_CONTINOUS   EQU (0x1 <<  2) ;- (SSC) Continuous Receive/Transmit Clock RK pin: Output

+AT91C_SSC_CKO_DATA_TX     EQU (0x2 <<  2) ;- (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+AT91C_SSC_CKI             EQU (0x1 <<  5) ;- (SSC) Receive/Transmit Clock Inversion

+AT91C_SSC_START           EQU (0xF <<  8) ;- (SSC) Receive/Transmit Start Selection

+AT91C_SSC_START_CONTINOUS EQU (0x0 <<  8) ;- (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+AT91C_SSC_START_TX        EQU (0x1 <<  8) ;- (SSC) Transmit/Receive start

+AT91C_SSC_START_LOW_RF    EQU (0x2 <<  8) ;- (SSC) Detection of a low level on RF input

+AT91C_SSC_START_HIGH_RF   EQU (0x3 <<  8) ;- (SSC) Detection of a high level on RF input

+AT91C_SSC_START_FALL_RF   EQU (0x4 <<  8) ;- (SSC) Detection of a falling edge on RF input

+AT91C_SSC_START_RISE_RF   EQU (0x5 <<  8) ;- (SSC) Detection of a rising edge on RF input

+AT91C_SSC_START_LEVEL_RF  EQU (0x6 <<  8) ;- (SSC) Detection of any level change on RF input

+AT91C_SSC_START_EDGE_RF   EQU (0x7 <<  8) ;- (SSC) Detection of any edge on RF input

+AT91C_SSC_START_0         EQU (0x8 <<  8) ;- (SSC) Compare 0

+AT91C_SSC_STTDLY          EQU (0xFF << 16) ;- (SSC) Receive/Transmit Start Delay

+AT91C_SSC_PERIOD          EQU (0xFF << 24) ;- (SSC) Receive/Transmit Period Divider Selection

+// - -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+AT91C_SSC_DATLEN          EQU (0x1F <<  0) ;- (SSC) Data Length

+AT91C_SSC_LOOP            EQU (0x1 <<  5) ;- (SSC) Loop Mode

+AT91C_SSC_MSBF            EQU (0x1 <<  7) ;- (SSC) Most Significant Bit First

+AT91C_SSC_DATNB           EQU (0xF <<  8) ;- (SSC) Data Number per Frame

+AT91C_SSC_FSLEN           EQU (0xF << 16) ;- (SSC) Receive/Transmit Frame Sync length

+AT91C_SSC_FSOS            EQU (0x7 << 20) ;- (SSC) Receive/Transmit Frame Sync Output Selection

+AT91C_SSC_FSOS_NONE       EQU (0x0 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+AT91C_SSC_FSOS_NEGATIVE   EQU (0x1 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+AT91C_SSC_FSOS_POSITIVE   EQU (0x2 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+AT91C_SSC_FSOS_LOW        EQU (0x3 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+AT91C_SSC_FSOS_HIGH       EQU (0x4 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+AT91C_SSC_FSOS_TOGGLE     EQU (0x5 << 20) ;- (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+AT91C_SSC_FSEDGE          EQU (0x1 << 24) ;- (SSC) Frame Sync Edge Detection

+// - -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// - -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+AT91C_SSC_DATDEF          EQU (0x1 <<  5) ;- (SSC) Data Default Value

+AT91C_SSC_FSDEN           EQU (0x1 << 23) ;- (SSC) Frame Sync Data Enable

+// - -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+AT91C_SSC_TXRDY           EQU (0x1 <<  0) ;- (SSC) Transmit Ready

+AT91C_SSC_TXEMPTY         EQU (0x1 <<  1) ;- (SSC) Transmit Empty

+AT91C_SSC_ENDTX           EQU (0x1 <<  2) ;- (SSC) End Of Transmission

+AT91C_SSC_TXBUFE          EQU (0x1 <<  3) ;- (SSC) Transmit Buffer Empty

+AT91C_SSC_RXRDY           EQU (0x1 <<  4) ;- (SSC) Receive Ready

+AT91C_SSC_OVRUN           EQU (0x1 <<  5) ;- (SSC) Receive Overrun

+AT91C_SSC_ENDRX           EQU (0x1 <<  6) ;- (SSC) End of Reception

+AT91C_SSC_RXBUFF          EQU (0x1 <<  7) ;- (SSC) Receive Buffer Full

+AT91C_SSC_TXSYN           EQU (0x1 << 10) ;- (SSC) Transmit Sync

+AT91C_SSC_RXSYN           EQU (0x1 << 11) ;- (SSC) Receive Sync

+AT91C_SSC_TXENA           EQU (0x1 << 16) ;- (SSC) Transmit Enable

+AT91C_SSC_RXENA           EQU (0x1 << 17) ;- (SSC) Receive Enable

+// - -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// - -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// - -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// - *****************************************************************************

+// - -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+AT91C_TWI_START           EQU (0x1 <<  0) ;- (TWI) Send a START Condition

+AT91C_TWI_STOP            EQU (0x1 <<  1) ;- (TWI) Send a STOP Condition

+AT91C_TWI_MSEN            EQU (0x1 <<  2) ;- (TWI) TWI Master Transfer Enabled

+AT91C_TWI_MSDIS           EQU (0x1 <<  3) ;- (TWI) TWI Master Transfer Disabled

+AT91C_TWI_SWRST           EQU (0x1 <<  7) ;- (TWI) Software Reset

+// - -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+AT91C_TWI_IADRSZ          EQU (0x3 <<  8) ;- (TWI) Internal Device Address Size

+AT91C_TWI_IADRSZ_NO       EQU (0x0 <<  8) ;- (TWI) No internal device address

+AT91C_TWI_IADRSZ_1_BYTE   EQU (0x1 <<  8) ;- (TWI) One-byte internal device address

+AT91C_TWI_IADRSZ_2_BYTE   EQU (0x2 <<  8) ;- (TWI) Two-byte internal device address

+AT91C_TWI_IADRSZ_3_BYTE   EQU (0x3 <<  8) ;- (TWI) Three-byte internal device address

+AT91C_TWI_MREAD           EQU (0x1 << 12) ;- (TWI) Master Read Direction

+AT91C_TWI_DADR            EQU (0x7F << 16) ;- (TWI) Device Address

+// - -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+AT91C_TWI_CLDIV           EQU (0xFF <<  0) ;- (TWI) Clock Low Divider

+AT91C_TWI_CHDIV           EQU (0xFF <<  8) ;- (TWI) Clock High Divider

+AT91C_TWI_CKDIV           EQU (0x7 << 16) ;- (TWI) Clock Divider

+// - -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+AT91C_TWI_TXCOMP          EQU (0x1 <<  0) ;- (TWI) Transmission Completed

+AT91C_TWI_RXRDY           EQU (0x1 <<  1) ;- (TWI) Receive holding register ReaDY

+AT91C_TWI_TXRDY           EQU (0x1 <<  2) ;- (TWI) Transmit holding register ReaDY

+AT91C_TWI_OVRE            EQU (0x1 <<  6) ;- (TWI) Overrun Error

+AT91C_TWI_UNRE            EQU (0x1 <<  7) ;- (TWI) Underrun Error

+AT91C_TWI_NACK            EQU (0x1 <<  8) ;- (TWI) Not Acknowledged

+// - -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// - -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// - -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// - *****************************************************************************

+// - -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+AT91C_PWMC_CPRE           EQU (0xF <<  0) ;- (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+AT91C_PWMC_CPRE_MCK       EQU (0x0) ;- (PWMC_CH) 

+AT91C_PWMC_CPRE_MCKA      EQU (0xB) ;- (PWMC_CH) 

+AT91C_PWMC_CPRE_MCKB      EQU (0xC) ;- (PWMC_CH) 

+AT91C_PWMC_CALG           EQU (0x1 <<  8) ;- (PWMC_CH) Channel Alignment

+AT91C_PWMC_CPOL           EQU (0x1 <<  9) ;- (PWMC_CH) Channel Polarity

+AT91C_PWMC_CPD            EQU (0x1 << 10) ;- (PWMC_CH) Channel Update Period

+// - -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+AT91C_PWMC_CDTY           EQU (0x0 <<  0) ;- (PWMC_CH) Channel Duty Cycle

+// - -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+AT91C_PWMC_CPRD           EQU (0x0 <<  0) ;- (PWMC_CH) Channel Period

+// - -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+AT91C_PWMC_CCNT           EQU (0x0 <<  0) ;- (PWMC_CH) Channel Counter

+// - -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+AT91C_PWMC_CUPD           EQU (0x0 <<  0) ;- (PWMC_CH) Channel Update

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// - *****************************************************************************

+// - -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+AT91C_PWMC_DIVA           EQU (0xFF <<  0) ;- (PWMC) CLKA divide factor.

+AT91C_PWMC_PREA           EQU (0xF <<  8) ;- (PWMC) Divider Input Clock Prescaler A

+AT91C_PWMC_PREA_MCK       EQU (0x0 <<  8) ;- (PWMC) 

+AT91C_PWMC_DIVB           EQU (0xFF << 16) ;- (PWMC) CLKB divide factor.

+AT91C_PWMC_PREB           EQU (0xF << 24) ;- (PWMC) Divider Input Clock Prescaler B

+AT91C_PWMC_PREB_MCK       EQU (0x0 << 24) ;- (PWMC) 

+// - -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+AT91C_PWMC_CHID0          EQU (0x1 <<  0) ;- (PWMC) Channel ID 0

+AT91C_PWMC_CHID1          EQU (0x1 <<  1) ;- (PWMC) Channel ID 1

+AT91C_PWMC_CHID2          EQU (0x1 <<  2) ;- (PWMC) Channel ID 2

+AT91C_PWMC_CHID3          EQU (0x1 <<  3) ;- (PWMC) Channel ID 3

+// - -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// - -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// - -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// - -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// - -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// - -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR USB Device Interface

+// - *****************************************************************************

+// - -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+AT91C_UDP_FRM_NUM         EQU (0x7FF <<  0) ;- (UDP) Frame Number as Defined in the Packet Field Formats

+AT91C_UDP_FRM_ERR         EQU (0x1 << 16) ;- (UDP) Frame Error

+AT91C_UDP_FRM_OK          EQU (0x1 << 17) ;- (UDP) Frame OK

+// - -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+AT91C_UDP_FADDEN          EQU (0x1 <<  0) ;- (UDP) Function Address Enable

+AT91C_UDP_CONFG           EQU (0x1 <<  1) ;- (UDP) Configured

+AT91C_UDP_ESR             EQU (0x1 <<  2) ;- (UDP) Enable Send Resume

+AT91C_UDP_RSMINPR         EQU (0x1 <<  3) ;- (UDP) A Resume Has Been Sent to the Host

+AT91C_UDP_RMWUPE          EQU (0x1 <<  4) ;- (UDP) Remote Wake Up Enable

+// - -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+AT91C_UDP_FADD            EQU (0xFF <<  0) ;- (UDP) Function Address Value

+AT91C_UDP_FEN             EQU (0x1 <<  8) ;- (UDP) Function Enable

+// - -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+AT91C_UDP_EPINT0          EQU (0x1 <<  0) ;- (UDP) Endpoint 0 Interrupt

+AT91C_UDP_EPINT1          EQU (0x1 <<  1) ;- (UDP) Endpoint 0 Interrupt

+AT91C_UDP_EPINT2          EQU (0x1 <<  2) ;- (UDP) Endpoint 2 Interrupt

+AT91C_UDP_EPINT3          EQU (0x1 <<  3) ;- (UDP) Endpoint 3 Interrupt

+AT91C_UDP_EPINT4          EQU (0x1 <<  4) ;- (UDP) Endpoint 4 Interrupt

+AT91C_UDP_EPINT5          EQU (0x1 <<  5) ;- (UDP) Endpoint 5 Interrupt

+AT91C_UDP_RXSUSP          EQU (0x1 <<  8) ;- (UDP) USB Suspend Interrupt

+AT91C_UDP_RXRSM           EQU (0x1 <<  9) ;- (UDP) USB Resume Interrupt

+AT91C_UDP_EXTRSM          EQU (0x1 << 10) ;- (UDP) USB External Resume Interrupt

+AT91C_UDP_SOFINT          EQU (0x1 << 11) ;- (UDP) USB Start Of frame Interrupt

+AT91C_UDP_WAKEUP          EQU (0x1 << 13) ;- (UDP) USB Resume Interrupt

+// - -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// - -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// - -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+AT91C_UDP_ENDBUSRES       EQU (0x1 << 12) ;- (UDP) USB End Of Bus Reset Interrupt

+// - -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// - -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+AT91C_UDP_EP0             EQU (0x1 <<  0) ;- (UDP) Reset Endpoint 0

+AT91C_UDP_EP1             EQU (0x1 <<  1) ;- (UDP) Reset Endpoint 1

+AT91C_UDP_EP2             EQU (0x1 <<  2) ;- (UDP) Reset Endpoint 2

+AT91C_UDP_EP3             EQU (0x1 <<  3) ;- (UDP) Reset Endpoint 3

+AT91C_UDP_EP4             EQU (0x1 <<  4) ;- (UDP) Reset Endpoint 4

+AT91C_UDP_EP5             EQU (0x1 <<  5) ;- (UDP) Reset Endpoint 5

+// - -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+AT91C_UDP_TXCOMP          EQU (0x1 <<  0) ;- (UDP) Generates an IN packet with data previously written in the DPR

+AT91C_UDP_RX_DATA_BK0     EQU (0x1 <<  1) ;- (UDP) Receive Data Bank 0

+AT91C_UDP_RXSETUP         EQU (0x1 <<  2) ;- (UDP) Sends STALL to the Host (Control endpoints)

+AT91C_UDP_ISOERROR        EQU (0x1 <<  3) ;- (UDP) Isochronous error (Isochronous endpoints)

+AT91C_UDP_TXPKTRDY        EQU (0x1 <<  4) ;- (UDP) Transmit Packet Ready

+AT91C_UDP_FORCESTALL      EQU (0x1 <<  5) ;- (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+AT91C_UDP_RX_DATA_BK1     EQU (0x1 <<  6) ;- (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+AT91C_UDP_DIR             EQU (0x1 <<  7) ;- (UDP) Transfer Direction

+AT91C_UDP_EPTYPE          EQU (0x7 <<  8) ;- (UDP) Endpoint type

+AT91C_UDP_EPTYPE_CTRL     EQU (0x0 <<  8) ;- (UDP) Control

+AT91C_UDP_EPTYPE_ISO_OUT  EQU (0x1 <<  8) ;- (UDP) Isochronous OUT

+AT91C_UDP_EPTYPE_BULK_OUT EQU (0x2 <<  8) ;- (UDP) Bulk OUT

+AT91C_UDP_EPTYPE_INT_OUT  EQU (0x3 <<  8) ;- (UDP) Interrupt OUT

+AT91C_UDP_EPTYPE_ISO_IN   EQU (0x5 <<  8) ;- (UDP) Isochronous IN

+AT91C_UDP_EPTYPE_BULK_IN  EQU (0x6 <<  8) ;- (UDP) Bulk IN

+AT91C_UDP_EPTYPE_INT_IN   EQU (0x7 <<  8) ;- (UDP) Interrupt IN

+AT91C_UDP_DTGLE           EQU (0x1 << 11) ;- (UDP) Data Toggle

+AT91C_UDP_EPEDS           EQU (0x1 << 15) ;- (UDP) Endpoint Enable Disable

+AT91C_UDP_RXBYTECNT       EQU (0x7FF << 16) ;- (UDP) Number Of Bytes Available in the FIFO

+// - -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+AT91C_UDP_TXVDIS          EQU (0x1 <<  8) ;- (UDP) 

+AT91C_UDP_PUON            EQU (0x1 <<  9) ;- (UDP) Pull-up ON

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// - *****************************************************************************

+// - -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+AT91C_TC_CLKEN            EQU (0x1 <<  0) ;- (TC) Counter Clock Enable Command

+AT91C_TC_CLKDIS           EQU (0x1 <<  1) ;- (TC) Counter Clock Disable Command

+AT91C_TC_SWTRG            EQU (0x1 <<  2) ;- (TC) Software Trigger Command

+// - -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+AT91C_TC_CLKS             EQU (0x7 <<  0) ;- (TC) Clock Selection

+AT91C_TC_CLKS_TIMER_DIV1_CLOCK EQU (0x0) ;- (TC) Clock selected: TIMER_DIV1_CLOCK

+AT91C_TC_CLKS_TIMER_DIV2_CLOCK EQU (0x1) ;- (TC) Clock selected: TIMER_DIV2_CLOCK

+AT91C_TC_CLKS_TIMER_DIV3_CLOCK EQU (0x2) ;- (TC) Clock selected: TIMER_DIV3_CLOCK

+AT91C_TC_CLKS_TIMER_DIV4_CLOCK EQU (0x3) ;- (TC) Clock selected: TIMER_DIV4_CLOCK

+AT91C_TC_CLKS_TIMER_DIV5_CLOCK EQU (0x4) ;- (TC) Clock selected: TIMER_DIV5_CLOCK

+AT91C_TC_CLKS_XC0         EQU (0x5) ;- (TC) Clock selected: XC0

+AT91C_TC_CLKS_XC1         EQU (0x6) ;- (TC) Clock selected: XC1

+AT91C_TC_CLKS_XC2         EQU (0x7) ;- (TC) Clock selected: XC2

+AT91C_TC_CLKI             EQU (0x1 <<  3) ;- (TC) Clock Invert

+AT91C_TC_BURST            EQU (0x3 <<  4) ;- (TC) Burst Signal Selection

+AT91C_TC_BURST_NONE       EQU (0x0 <<  4) ;- (TC) The clock is not gated by an external signal

+AT91C_TC_BURST_XC0        EQU (0x1 <<  4) ;- (TC) XC0 is ANDed with the selected clock

+AT91C_TC_BURST_XC1        EQU (0x2 <<  4) ;- (TC) XC1 is ANDed with the selected clock

+AT91C_TC_BURST_XC2        EQU (0x3 <<  4) ;- (TC) XC2 is ANDed with the selected clock

+AT91C_TC_CPCSTOP          EQU (0x1 <<  6) ;- (TC) Counter Clock Stopped with RC Compare

+AT91C_TC_LDBSTOP          EQU (0x1 <<  6) ;- (TC) Counter Clock Stopped with RB Loading

+AT91C_TC_CPCDIS           EQU (0x1 <<  7) ;- (TC) Counter Clock Disable with RC Compare

+AT91C_TC_LDBDIS           EQU (0x1 <<  7) ;- (TC) Counter Clock Disabled with RB Loading

+AT91C_TC_ETRGEDG          EQU (0x3 <<  8) ;- (TC) External Trigger Edge Selection

+AT91C_TC_ETRGEDG_NONE     EQU (0x0 <<  8) ;- (TC) Edge: None

+AT91C_TC_ETRGEDG_RISING   EQU (0x1 <<  8) ;- (TC) Edge: rising edge

+AT91C_TC_ETRGEDG_FALLING  EQU (0x2 <<  8) ;- (TC) Edge: falling edge

+AT91C_TC_ETRGEDG_BOTH     EQU (0x3 <<  8) ;- (TC) Edge: each edge

+AT91C_TC_EEVTEDG          EQU (0x3 <<  8) ;- (TC) External Event Edge Selection

+AT91C_TC_EEVTEDG_NONE     EQU (0x0 <<  8) ;- (TC) Edge: None

+AT91C_TC_EEVTEDG_RISING   EQU (0x1 <<  8) ;- (TC) Edge: rising edge

+AT91C_TC_EEVTEDG_FALLING  EQU (0x2 <<  8) ;- (TC) Edge: falling edge

+AT91C_TC_EEVTEDG_BOTH     EQU (0x3 <<  8) ;- (TC) Edge: each edge

+AT91C_TC_EEVT             EQU (0x3 << 10) ;- (TC) External Event  Selection

+AT91C_TC_EEVT_TIOB        EQU (0x0 << 10) ;- (TC) Signal selected as external event: TIOB TIOB direction: input

+AT91C_TC_EEVT_XC0         EQU (0x1 << 10) ;- (TC) Signal selected as external event: XC0 TIOB direction: output

+AT91C_TC_EEVT_XC1         EQU (0x2 << 10) ;- (TC) Signal selected as external event: XC1 TIOB direction: output

+AT91C_TC_EEVT_XC2         EQU (0x3 << 10) ;- (TC) Signal selected as external event: XC2 TIOB direction: output

+AT91C_TC_ABETRG           EQU (0x1 << 10) ;- (TC) TIOA or TIOB External Trigger Selection

+AT91C_TC_ENETRG           EQU (0x1 << 12) ;- (TC) External Event Trigger enable

+AT91C_TC_WAVESEL          EQU (0x3 << 13) ;- (TC) Waveform  Selection

+AT91C_TC_WAVESEL_UP       EQU (0x0 << 13) ;- (TC) UP mode without atomatic trigger on RC Compare

+AT91C_TC_WAVESEL_UPDOWN   EQU (0x1 << 13) ;- (TC) UPDOWN mode without automatic trigger on RC Compare

+AT91C_TC_WAVESEL_UP_AUTO  EQU (0x2 << 13) ;- (TC) UP mode with automatic trigger on RC Compare

+AT91C_TC_WAVESEL_UPDOWN_AUTO EQU (0x3 << 13) ;- (TC) UPDOWN mode with automatic trigger on RC Compare

+AT91C_TC_CPCTRG           EQU (0x1 << 14) ;- (TC) RC Compare Trigger Enable

+AT91C_TC_WAVE             EQU (0x1 << 15) ;- (TC) 

+AT91C_TC_ACPA             EQU (0x3 << 16) ;- (TC) RA Compare Effect on TIOA

+AT91C_TC_ACPA_NONE        EQU (0x0 << 16) ;- (TC) Effect: none

+AT91C_TC_ACPA_SET         EQU (0x1 << 16) ;- (TC) Effect: set

+AT91C_TC_ACPA_CLEAR       EQU (0x2 << 16) ;- (TC) Effect: clear

+AT91C_TC_ACPA_TOGGLE      EQU (0x3 << 16) ;- (TC) Effect: toggle

+AT91C_TC_LDRA             EQU (0x3 << 16) ;- (TC) RA Loading Selection

+AT91C_TC_LDRA_NONE        EQU (0x0 << 16) ;- (TC) Edge: None

+AT91C_TC_LDRA_RISING      EQU (0x1 << 16) ;- (TC) Edge: rising edge of TIOA

+AT91C_TC_LDRA_FALLING     EQU (0x2 << 16) ;- (TC) Edge: falling edge of TIOA

+AT91C_TC_LDRA_BOTH        EQU (0x3 << 16) ;- (TC) Edge: each edge of TIOA

+AT91C_TC_ACPC             EQU (0x3 << 18) ;- (TC) RC Compare Effect on TIOA

+AT91C_TC_ACPC_NONE        EQU (0x0 << 18) ;- (TC) Effect: none

+AT91C_TC_ACPC_SET         EQU (0x1 << 18) ;- (TC) Effect: set

+AT91C_TC_ACPC_CLEAR       EQU (0x2 << 18) ;- (TC) Effect: clear

+AT91C_TC_ACPC_TOGGLE      EQU (0x3 << 18) ;- (TC) Effect: toggle

+AT91C_TC_LDRB             EQU (0x3 << 18) ;- (TC) RB Loading Selection

+AT91C_TC_LDRB_NONE        EQU (0x0 << 18) ;- (TC) Edge: None

+AT91C_TC_LDRB_RISING      EQU (0x1 << 18) ;- (TC) Edge: rising edge of TIOA

+AT91C_TC_LDRB_FALLING     EQU (0x2 << 18) ;- (TC) Edge: falling edge of TIOA

+AT91C_TC_LDRB_BOTH        EQU (0x3 << 18) ;- (TC) Edge: each edge of TIOA

+AT91C_TC_AEEVT            EQU (0x3 << 20) ;- (TC) External Event Effect on TIOA

+AT91C_TC_AEEVT_NONE       EQU (0x0 << 20) ;- (TC) Effect: none

+AT91C_TC_AEEVT_SET        EQU (0x1 << 20) ;- (TC) Effect: set

+AT91C_TC_AEEVT_CLEAR      EQU (0x2 << 20) ;- (TC) Effect: clear

+AT91C_TC_AEEVT_TOGGLE     EQU (0x3 << 20) ;- (TC) Effect: toggle

+AT91C_TC_ASWTRG           EQU (0x3 << 22) ;- (TC) Software Trigger Effect on TIOA

+AT91C_TC_ASWTRG_NONE      EQU (0x0 << 22) ;- (TC) Effect: none

+AT91C_TC_ASWTRG_SET       EQU (0x1 << 22) ;- (TC) Effect: set

+AT91C_TC_ASWTRG_CLEAR     EQU (0x2 << 22) ;- (TC) Effect: clear

+AT91C_TC_ASWTRG_TOGGLE    EQU (0x3 << 22) ;- (TC) Effect: toggle

+AT91C_TC_BCPB             EQU (0x3 << 24) ;- (TC) RB Compare Effect on TIOB

+AT91C_TC_BCPB_NONE        EQU (0x0 << 24) ;- (TC) Effect: none

+AT91C_TC_BCPB_SET         EQU (0x1 << 24) ;- (TC) Effect: set

+AT91C_TC_BCPB_CLEAR       EQU (0x2 << 24) ;- (TC) Effect: clear

+AT91C_TC_BCPB_TOGGLE      EQU (0x3 << 24) ;- (TC) Effect: toggle

+AT91C_TC_BCPC             EQU (0x3 << 26) ;- (TC) RC Compare Effect on TIOB

+AT91C_TC_BCPC_NONE        EQU (0x0 << 26) ;- (TC) Effect: none

+AT91C_TC_BCPC_SET         EQU (0x1 << 26) ;- (TC) Effect: set

+AT91C_TC_BCPC_CLEAR       EQU (0x2 << 26) ;- (TC) Effect: clear

+AT91C_TC_BCPC_TOGGLE      EQU (0x3 << 26) ;- (TC) Effect: toggle

+AT91C_TC_BEEVT            EQU (0x3 << 28) ;- (TC) External Event Effect on TIOB

+AT91C_TC_BEEVT_NONE       EQU (0x0 << 28) ;- (TC) Effect: none

+AT91C_TC_BEEVT_SET        EQU (0x1 << 28) ;- (TC) Effect: set

+AT91C_TC_BEEVT_CLEAR      EQU (0x2 << 28) ;- (TC) Effect: clear

+AT91C_TC_BEEVT_TOGGLE     EQU (0x3 << 28) ;- (TC) Effect: toggle

+AT91C_TC_BSWTRG           EQU (0x3 << 30) ;- (TC) Software Trigger Effect on TIOB

+AT91C_TC_BSWTRG_NONE      EQU (0x0 << 30) ;- (TC) Effect: none

+AT91C_TC_BSWTRG_SET       EQU (0x1 << 30) ;- (TC) Effect: set

+AT91C_TC_BSWTRG_CLEAR     EQU (0x2 << 30) ;- (TC) Effect: clear

+AT91C_TC_BSWTRG_TOGGLE    EQU (0x3 << 30) ;- (TC) Effect: toggle

+// - -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+AT91C_TC_COVFS            EQU (0x1 <<  0) ;- (TC) Counter Overflow

+AT91C_TC_LOVRS            EQU (0x1 <<  1) ;- (TC) Load Overrun

+AT91C_TC_CPAS             EQU (0x1 <<  2) ;- (TC) RA Compare

+AT91C_TC_CPBS             EQU (0x1 <<  3) ;- (TC) RB Compare

+AT91C_TC_CPCS             EQU (0x1 <<  4) ;- (TC) RC Compare

+AT91C_TC_LDRAS            EQU (0x1 <<  5) ;- (TC) RA Loading

+AT91C_TC_LDRBS            EQU (0x1 <<  6) ;- (TC) RB Loading

+AT91C_TC_ETRGS            EQU (0x1 <<  7) ;- (TC) External Trigger

+AT91C_TC_CLKSTA           EQU (0x1 << 16) ;- (TC) Clock Enabling

+AT91C_TC_MTIOA            EQU (0x1 << 17) ;- (TC) TIOA Mirror

+AT91C_TC_MTIOB            EQU (0x1 << 18) ;- (TC) TIOA Mirror

+// - -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// - -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// - -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// - *****************************************************************************

+// - -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+AT91C_TCB_SYNC            EQU (0x1 <<  0) ;- (TCB) Synchro Command

+// - -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+AT91C_TCB_TC0XC0S         EQU (0x3 <<  0) ;- (TCB) External Clock Signal 0 Selection

+AT91C_TCB_TC0XC0S_TCLK0   EQU (0x0) ;- (TCB) TCLK0 connected to XC0

+AT91C_TCB_TC0XC0S_NONE    EQU (0x1) ;- (TCB) None signal connected to XC0

+AT91C_TCB_TC0XC0S_TIOA1   EQU (0x2) ;- (TCB) TIOA1 connected to XC0

+AT91C_TCB_TC0XC0S_TIOA2   EQU (0x3) ;- (TCB) TIOA2 connected to XC0

+AT91C_TCB_TC1XC1S         EQU (0x3 <<  2) ;- (TCB) External Clock Signal 1 Selection

+AT91C_TCB_TC1XC1S_TCLK1   EQU (0x0 <<  2) ;- (TCB) TCLK1 connected to XC1

+AT91C_TCB_TC1XC1S_NONE    EQU (0x1 <<  2) ;- (TCB) None signal connected to XC1

+AT91C_TCB_TC1XC1S_TIOA0   EQU (0x2 <<  2) ;- (TCB) TIOA0 connected to XC1

+AT91C_TCB_TC1XC1S_TIOA2   EQU (0x3 <<  2) ;- (TCB) TIOA2 connected to XC1

+AT91C_TCB_TC2XC2S         EQU (0x3 <<  4) ;- (TCB) External Clock Signal 2 Selection

+AT91C_TCB_TC2XC2S_TCLK2   EQU (0x0 <<  4) ;- (TCB) TCLK2 connected to XC2

+AT91C_TCB_TC2XC2S_NONE    EQU (0x1 <<  4) ;- (TCB) None signal connected to XC2

+AT91C_TCB_TC2XC2S_TIOA0   EQU (0x2 <<  4) ;- (TCB) TIOA0 connected to XC2

+AT91C_TCB_TC2XC2S_TIOA1   EQU (0x3 <<  4) ;- (TCB) TIOA2 connected to XC2

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// - *****************************************************************************

+// - -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+AT91C_CAN_MTIMEMARK       EQU (0xFFFF <<  0) ;- (CAN_MB) Mailbox Timemark

+AT91C_CAN_PRIOR           EQU (0xF << 16) ;- (CAN_MB) Mailbox Priority

+AT91C_CAN_MOT             EQU (0x7 << 24) ;- (CAN_MB) Mailbox Object Type

+AT91C_CAN_MOT_DIS         EQU (0x0 << 24) ;- (CAN_MB) 

+AT91C_CAN_MOT_RX          EQU (0x1 << 24) ;- (CAN_MB) 

+AT91C_CAN_MOT_RXOVERWRITE EQU (0x2 << 24) ;- (CAN_MB) 

+AT91C_CAN_MOT_TX          EQU (0x3 << 24) ;- (CAN_MB) 

+AT91C_CAN_MOT_CONSUMER    EQU (0x4 << 24) ;- (CAN_MB) 

+AT91C_CAN_MOT_PRODUCER    EQU (0x5 << 24) ;- (CAN_MB) 

+// - -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+AT91C_CAN_MIDvB           EQU (0x3FFFF <<  0) ;- (CAN_MB) Complementary bits for identifier in extended mode

+AT91C_CAN_MIDvA           EQU (0x7FF << 18) ;- (CAN_MB) Identifier for standard frame mode

+AT91C_CAN_MIDE            EQU (0x1 << 29) ;- (CAN_MB) Identifier Version

+// - -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// - -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// - -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+AT91C_CAN_MTIMESTAMP      EQU (0xFFFF <<  0) ;- (CAN_MB) Timer Value

+AT91C_CAN_MDLC            EQU (0xF << 16) ;- (CAN_MB) Mailbox Data Length Code

+AT91C_CAN_MRTR            EQU (0x1 << 20) ;- (CAN_MB) Mailbox Remote Transmission Request

+AT91C_CAN_MABT            EQU (0x1 << 22) ;- (CAN_MB) Mailbox Message Abort

+AT91C_CAN_MRDY            EQU (0x1 << 23) ;- (CAN_MB) Mailbox Ready

+AT91C_CAN_MMI             EQU (0x1 << 24) ;- (CAN_MB) Mailbox Message Ignored

+// - -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// - -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// - -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+AT91C_CAN_MACR            EQU (0x1 << 22) ;- (CAN_MB) Abort Request for Mailbox

+AT91C_CAN_MTCR            EQU (0x1 << 23) ;- (CAN_MB) Mailbox Transfer Command

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// - *****************************************************************************

+// - -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+AT91C_CAN_CANEN           EQU (0x1 <<  0) ;- (CAN) CAN Controller Enable

+AT91C_CAN_LPM             EQU (0x1 <<  1) ;- (CAN) Disable/Enable Low Power Mode

+AT91C_CAN_ABM             EQU (0x1 <<  2) ;- (CAN) Disable/Enable Autobaud/Listen Mode

+AT91C_CAN_OVL             EQU (0x1 <<  3) ;- (CAN) Disable/Enable Overload Frame

+AT91C_CAN_TEOF            EQU (0x1 <<  4) ;- (CAN) Time Stamp messages at each end of Frame

+AT91C_CAN_TTM             EQU (0x1 <<  5) ;- (CAN) Disable/Enable Time Trigger Mode

+AT91C_CAN_TIMFRZ          EQU (0x1 <<  6) ;- (CAN) Enable Timer Freeze

+AT91C_CAN_DRPT            EQU (0x1 <<  7) ;- (CAN) Disable Repeat

+// - -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+AT91C_CAN_MB0             EQU (0x1 <<  0) ;- (CAN) Mailbox 0 Flag

+AT91C_CAN_MB1             EQU (0x1 <<  1) ;- (CAN) Mailbox 1 Flag

+AT91C_CAN_MB2             EQU (0x1 <<  2) ;- (CAN) Mailbox 2 Flag

+AT91C_CAN_MB3             EQU (0x1 <<  3) ;- (CAN) Mailbox 3 Flag

+AT91C_CAN_MB4             EQU (0x1 <<  4) ;- (CAN) Mailbox 4 Flag

+AT91C_CAN_MB5             EQU (0x1 <<  5) ;- (CAN) Mailbox 5 Flag

+AT91C_CAN_MB6             EQU (0x1 <<  6) ;- (CAN) Mailbox 6 Flag

+AT91C_CAN_MB7             EQU (0x1 <<  7) ;- (CAN) Mailbox 7 Flag

+AT91C_CAN_MB8             EQU (0x1 <<  8) ;- (CAN) Mailbox 8 Flag

+AT91C_CAN_MB9             EQU (0x1 <<  9) ;- (CAN) Mailbox 9 Flag

+AT91C_CAN_MB10            EQU (0x1 << 10) ;- (CAN) Mailbox 10 Flag

+AT91C_CAN_MB11            EQU (0x1 << 11) ;- (CAN) Mailbox 11 Flag

+AT91C_CAN_MB12            EQU (0x1 << 12) ;- (CAN) Mailbox 12 Flag

+AT91C_CAN_MB13            EQU (0x1 << 13) ;- (CAN) Mailbox 13 Flag

+AT91C_CAN_MB14            EQU (0x1 << 14) ;- (CAN) Mailbox 14 Flag

+AT91C_CAN_MB15            EQU (0x1 << 15) ;- (CAN) Mailbox 15 Flag

+AT91C_CAN_ERRA            EQU (0x1 << 16) ;- (CAN) Error Active Mode Flag

+AT91C_CAN_WARN            EQU (0x1 << 17) ;- (CAN) Warning Limit Flag

+AT91C_CAN_ERRP            EQU (0x1 << 18) ;- (CAN) Error Passive Mode Flag

+AT91C_CAN_BOFF            EQU (0x1 << 19) ;- (CAN) Bus Off Mode Flag

+AT91C_CAN_SLEEP           EQU (0x1 << 20) ;- (CAN) Sleep Flag

+AT91C_CAN_WAKEUP          EQU (0x1 << 21) ;- (CAN) Wakeup Flag

+AT91C_CAN_TOVF            EQU (0x1 << 22) ;- (CAN) Timer Overflow Flag

+AT91C_CAN_TSTP            EQU (0x1 << 23) ;- (CAN) Timestamp Flag

+AT91C_CAN_CERR            EQU (0x1 << 24) ;- (CAN) CRC Error

+AT91C_CAN_SERR            EQU (0x1 << 25) ;- (CAN) Stuffing Error

+AT91C_CAN_AERR            EQU (0x1 << 26) ;- (CAN) Acknowledgment Error

+AT91C_CAN_FERR            EQU (0x1 << 27) ;- (CAN) Form Error

+AT91C_CAN_BERR            EQU (0x1 << 28) ;- (CAN) Bit Error

+// - -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// - -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// - -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+AT91C_CAN_RBSY            EQU (0x1 << 29) ;- (CAN) Receiver Busy

+AT91C_CAN_TBSY            EQU (0x1 << 30) ;- (CAN) Transmitter Busy

+AT91C_CAN_OVLY            EQU (0x1 << 31) ;- (CAN) Overload Busy

+// - -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+AT91C_CAN_PHASE2          EQU (0x7 <<  0) ;- (CAN) Phase 2 segment

+AT91C_CAN_PHASE1          EQU (0x7 <<  4) ;- (CAN) Phase 1 segment

+AT91C_CAN_PROPAG          EQU (0x7 <<  8) ;- (CAN) Programmation time segment

+AT91C_CAN_SYNC            EQU (0x3 << 12) ;- (CAN) Re-synchronization jump width segment

+AT91C_CAN_BRP             EQU (0x7F << 16) ;- (CAN) Baudrate Prescaler

+AT91C_CAN_SMP             EQU (0x1 << 24) ;- (CAN) Sampling mode

+// - -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+AT91C_CAN_TIMER           EQU (0xFFFF <<  0) ;- (CAN) Timer field

+// - -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// - -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+AT91C_CAN_REC             EQU (0xFF <<  0) ;- (CAN) Receive Error Counter

+AT91C_CAN_TEC             EQU (0xFF << 16) ;- (CAN) Transmit Error Counter

+// - -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+AT91C_CAN_TIMRST          EQU (0x1 << 31) ;- (CAN) Timer Reset Field

+// - -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// - *****************************************************************************

+// - -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+AT91C_EMAC_LB             EQU (0x1 <<  0) ;- (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+AT91C_EMAC_LLB            EQU (0x1 <<  1) ;- (EMAC) Loopback local. 

+AT91C_EMAC_RE             EQU (0x1 <<  2) ;- (EMAC) Receive enable. 

+AT91C_EMAC_TE             EQU (0x1 <<  3) ;- (EMAC) Transmit enable. 

+AT91C_EMAC_MPE            EQU (0x1 <<  4) ;- (EMAC) Management port enable. 

+AT91C_EMAC_CLRSTAT        EQU (0x1 <<  5) ;- (EMAC) Clear statistics registers. 

+AT91C_EMAC_INCSTAT        EQU (0x1 <<  6) ;- (EMAC) Increment statistics registers. 

+AT91C_EMAC_WESTAT         EQU (0x1 <<  7) ;- (EMAC) Write enable for statistics registers. 

+AT91C_EMAC_BP             EQU (0x1 <<  8) ;- (EMAC) Back pressure. 

+AT91C_EMAC_TSTART         EQU (0x1 <<  9) ;- (EMAC) Start Transmission. 

+AT91C_EMAC_THALT          EQU (0x1 << 10) ;- (EMAC) Transmission Halt. 

+AT91C_EMAC_TPFR           EQU (0x1 << 11) ;- (EMAC) Transmit pause frame 

+AT91C_EMAC_TZQ            EQU (0x1 << 12) ;- (EMAC) Transmit zero quantum pause frame

+// - -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+AT91C_EMAC_SPD            EQU (0x1 <<  0) ;- (EMAC) Speed. 

+AT91C_EMAC_FD             EQU (0x1 <<  1) ;- (EMAC) Full duplex. 

+AT91C_EMAC_JFRAME         EQU (0x1 <<  3) ;- (EMAC) Jumbo Frames. 

+AT91C_EMAC_CAF            EQU (0x1 <<  4) ;- (EMAC) Copy all frames. 

+AT91C_EMAC_NBC            EQU (0x1 <<  5) ;- (EMAC) No broadcast. 

+AT91C_EMAC_MTI            EQU (0x1 <<  6) ;- (EMAC) Multicast hash event enable

+AT91C_EMAC_UNI            EQU (0x1 <<  7) ;- (EMAC) Unicast hash enable. 

+AT91C_EMAC_BIG            EQU (0x1 <<  8) ;- (EMAC) Receive 1522 bytes. 

+AT91C_EMAC_EAE            EQU (0x1 <<  9) ;- (EMAC) External address match enable. 

+AT91C_EMAC_CLK            EQU (0x3 << 10) ;- (EMAC) 

+AT91C_EMAC_CLK_HCLK_8     EQU (0x0 << 10) ;- (EMAC) HCLK divided by 8

+AT91C_EMAC_CLK_HCLK_16    EQU (0x1 << 10) ;- (EMAC) HCLK divided by 16

+AT91C_EMAC_CLK_HCLK_32    EQU (0x2 << 10) ;- (EMAC) HCLK divided by 32

+AT91C_EMAC_CLK_HCLK_64    EQU (0x3 << 10) ;- (EMAC) HCLK divided by 64

+AT91C_EMAC_RTY            EQU (0x1 << 12) ;- (EMAC) 

+AT91C_EMAC_PAE            EQU (0x1 << 13) ;- (EMAC) 

+AT91C_EMAC_RBOF           EQU (0x3 << 14) ;- (EMAC) 

+AT91C_EMAC_RBOF_OFFSET_0  EQU (0x0 << 14) ;- (EMAC) no offset from start of receive buffer

+AT91C_EMAC_RBOF_OFFSET_1  EQU (0x1 << 14) ;- (EMAC) one byte offset from start of receive buffer

+AT91C_EMAC_RBOF_OFFSET_2  EQU (0x2 << 14) ;- (EMAC) two bytes offset from start of receive buffer

+AT91C_EMAC_RBOF_OFFSET_3  EQU (0x3 << 14) ;- (EMAC) three bytes offset from start of receive buffer

+AT91C_EMAC_RLCE           EQU (0x1 << 16) ;- (EMAC) Receive Length field Checking Enable

+AT91C_EMAC_DRFCS          EQU (0x1 << 17) ;- (EMAC) Discard Receive FCS

+AT91C_EMAC_EFRHD          EQU (0x1 << 18) ;- (EMAC) 

+AT91C_EMAC_IRXFCS         EQU (0x1 << 19) ;- (EMAC) Ignore RX FCS

+// - -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+AT91C_EMAC_LINKR          EQU (0x1 <<  0) ;- (EMAC) 

+AT91C_EMAC_MDIO           EQU (0x1 <<  1) ;- (EMAC) 

+AT91C_EMAC_IDLE           EQU (0x1 <<  2) ;- (EMAC) 

+// - -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+AT91C_EMAC_UBR            EQU (0x1 <<  0) ;- (EMAC) 

+AT91C_EMAC_COL            EQU (0x1 <<  1) ;- (EMAC) 

+AT91C_EMAC_RLES           EQU (0x1 <<  2) ;- (EMAC) 

+AT91C_EMAC_TGO            EQU (0x1 <<  3) ;- (EMAC) Transmit Go

+AT91C_EMAC_BEX            EQU (0x1 <<  4) ;- (EMAC) Buffers exhausted mid frame

+AT91C_EMAC_COMP           EQU (0x1 <<  5) ;- (EMAC) 

+AT91C_EMAC_UND            EQU (0x1 <<  6) ;- (EMAC) 

+// - -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+AT91C_EMAC_BNA            EQU (0x1 <<  0) ;- (EMAC) 

+AT91C_EMAC_REC            EQU (0x1 <<  1) ;- (EMAC) 

+AT91C_EMAC_OVR            EQU (0x1 <<  2) ;- (EMAC) 

+// - -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+AT91C_EMAC_MFD            EQU (0x1 <<  0) ;- (EMAC) 

+AT91C_EMAC_RCOMP          EQU (0x1 <<  1) ;- (EMAC) 

+AT91C_EMAC_RXUBR          EQU (0x1 <<  2) ;- (EMAC) 

+AT91C_EMAC_TXUBR          EQU (0x1 <<  3) ;- (EMAC) 

+AT91C_EMAC_TUNDR          EQU (0x1 <<  4) ;- (EMAC) 

+AT91C_EMAC_RLEX           EQU (0x1 <<  5) ;- (EMAC) 

+AT91C_EMAC_TXERR          EQU (0x1 <<  6) ;- (EMAC) 

+AT91C_EMAC_TCOMP          EQU (0x1 <<  7) ;- (EMAC) 

+AT91C_EMAC_LINK           EQU (0x1 <<  9) ;- (EMAC) 

+AT91C_EMAC_ROVR           EQU (0x1 << 10) ;- (EMAC) 

+AT91C_EMAC_HRESP          EQU (0x1 << 11) ;- (EMAC) 

+AT91C_EMAC_PFRE           EQU (0x1 << 12) ;- (EMAC) 

+AT91C_EMAC_PTZ            EQU (0x1 << 13) ;- (EMAC) 

+// - -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// - -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// - -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// - -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+AT91C_EMAC_DATA           EQU (0xFFFF <<  0) ;- (EMAC) 

+AT91C_EMAC_CODE           EQU (0x3 << 16) ;- (EMAC) 

+AT91C_EMAC_REGA           EQU (0x1F << 18) ;- (EMAC) 

+AT91C_EMAC_PHYA           EQU (0x1F << 23) ;- (EMAC) 

+AT91C_EMAC_RW             EQU (0x3 << 28) ;- (EMAC) 

+AT91C_EMAC_SOF            EQU (0x3 << 30) ;- (EMAC) 

+// - -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+AT91C_EMAC_RMII           EQU (0x1 <<  0) ;- (EMAC) Reduce MII

+// - -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+AT91C_EMAC_IP             EQU (0xFFFF <<  0) ;- (EMAC) ARP request IP address

+AT91C_EMAC_MAG            EQU (0x1 << 16) ;- (EMAC) Magic packet event enable

+AT91C_EMAC_ARP            EQU (0x1 << 17) ;- (EMAC) ARP request event enable

+AT91C_EMAC_SA1            EQU (0x1 << 18) ;- (EMAC) Specific address register 1 event enable

+// - -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+AT91C_EMAC_REVREF         EQU (0xFFFF <<  0) ;- (EMAC) 

+AT91C_EMAC_PARTREF        EQU (0xFFFF << 16) ;- (EMAC) 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// - *****************************************************************************

+// - -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+AT91C_ADC_SWRST           EQU (0x1 <<  0) ;- (ADC) Software Reset

+AT91C_ADC_START           EQU (0x1 <<  1) ;- (ADC) Start Conversion

+// - -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+AT91C_ADC_TRGEN           EQU (0x1 <<  0) ;- (ADC) Trigger Enable

+AT91C_ADC_TRGEN_DIS       EQU (0x0) ;- (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+AT91C_ADC_TRGEN_EN        EQU (0x1) ;- (ADC) Hardware trigger selected by TRGSEL field is enabled.

+AT91C_ADC_TRGSEL          EQU (0x7 <<  1) ;- (ADC) Trigger Selection

+AT91C_ADC_TRGSEL_TIOA0    EQU (0x0 <<  1) ;- (ADC) Selected TRGSEL = TIAO0

+AT91C_ADC_TRGSEL_TIOA1    EQU (0x1 <<  1) ;- (ADC) Selected TRGSEL = TIAO1

+AT91C_ADC_TRGSEL_TIOA2    EQU (0x2 <<  1) ;- (ADC) Selected TRGSEL = TIAO2

+AT91C_ADC_TRGSEL_TIOA3    EQU (0x3 <<  1) ;- (ADC) Selected TRGSEL = TIAO3

+AT91C_ADC_TRGSEL_TIOA4    EQU (0x4 <<  1) ;- (ADC) Selected TRGSEL = TIAO4

+AT91C_ADC_TRGSEL_TIOA5    EQU (0x5 <<  1) ;- (ADC) Selected TRGSEL = TIAO5

+AT91C_ADC_TRGSEL_EXT      EQU (0x6 <<  1) ;- (ADC) Selected TRGSEL = External Trigger

+AT91C_ADC_LOWRES          EQU (0x1 <<  4) ;- (ADC) Resolution.

+AT91C_ADC_LOWRES_10_BIT   EQU (0x0 <<  4) ;- (ADC) 10-bit resolution

+AT91C_ADC_LOWRES_8_BIT    EQU (0x1 <<  4) ;- (ADC) 8-bit resolution

+AT91C_ADC_SLEEP           EQU (0x1 <<  5) ;- (ADC) Sleep Mode

+AT91C_ADC_SLEEP_NORMAL_MODE EQU (0x0 <<  5) ;- (ADC) Normal Mode

+AT91C_ADC_SLEEP_MODE      EQU (0x1 <<  5) ;- (ADC) Sleep Mode

+AT91C_ADC_PRESCAL         EQU (0x3F <<  8) ;- (ADC) Prescaler rate selection

+AT91C_ADC_STARTUP         EQU (0x1F << 16) ;- (ADC) Startup Time

+AT91C_ADC_SHTIM           EQU (0xF << 24) ;- (ADC) Sample & Hold Time

+// - -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+AT91C_ADC_CH0             EQU (0x1 <<  0) ;- (ADC) Channel 0

+AT91C_ADC_CH1             EQU (0x1 <<  1) ;- (ADC) Channel 1

+AT91C_ADC_CH2             EQU (0x1 <<  2) ;- (ADC) Channel 2

+AT91C_ADC_CH3             EQU (0x1 <<  3) ;- (ADC) Channel 3

+AT91C_ADC_CH4             EQU (0x1 <<  4) ;- (ADC) Channel 4

+AT91C_ADC_CH5             EQU (0x1 <<  5) ;- (ADC) Channel 5

+AT91C_ADC_CH6             EQU (0x1 <<  6) ;- (ADC) Channel 6

+AT91C_ADC_CH7             EQU (0x1 <<  7) ;- (ADC) Channel 7

+// - -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// - -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// - -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+AT91C_ADC_EOC0            EQU (0x1 <<  0) ;- (ADC) End of Conversion

+AT91C_ADC_EOC1            EQU (0x1 <<  1) ;- (ADC) End of Conversion

+AT91C_ADC_EOC2            EQU (0x1 <<  2) ;- (ADC) End of Conversion

+AT91C_ADC_EOC3            EQU (0x1 <<  3) ;- (ADC) End of Conversion

+AT91C_ADC_EOC4            EQU (0x1 <<  4) ;- (ADC) End of Conversion

+AT91C_ADC_EOC5            EQU (0x1 <<  5) ;- (ADC) End of Conversion

+AT91C_ADC_EOC6            EQU (0x1 <<  6) ;- (ADC) End of Conversion

+AT91C_ADC_EOC7            EQU (0x1 <<  7) ;- (ADC) End of Conversion

+AT91C_ADC_OVRE0           EQU (0x1 <<  8) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE1           EQU (0x1 <<  9) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE2           EQU (0x1 << 10) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE3           EQU (0x1 << 11) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE4           EQU (0x1 << 12) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE5           EQU (0x1 << 13) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE6           EQU (0x1 << 14) ;- (ADC) Overrun Error

+AT91C_ADC_OVRE7           EQU (0x1 << 15) ;- (ADC) Overrun Error

+AT91C_ADC_DRDY            EQU (0x1 << 16) ;- (ADC) Data Ready

+AT91C_ADC_GOVRE           EQU (0x1 << 17) ;- (ADC) General Overrun

+AT91C_ADC_ENDRX           EQU (0x1 << 18) ;- (ADC) End of Receiver Transfer

+AT91C_ADC_RXBUFF          EQU (0x1 << 19) ;- (ADC) RXBUFF Interrupt

+// - -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+AT91C_ADC_LDATA           EQU (0x3FF <<  0) ;- (ADC) Last Data Converted

+// - -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// - -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// - -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// - -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+AT91C_ADC_DATA            EQU (0x3FF <<  0) ;- (ADC) Converted Data

+// - -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// - -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// - -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// - -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// - -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// - -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// - -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// - *****************************************************************************

+// - -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+AT91C_AES_START           EQU (0x1 <<  0) ;- (AES) Starts Processing

+AT91C_AES_SWRST           EQU (0x1 <<  8) ;- (AES) Software Reset

+AT91C_AES_LOADSEED        EQU (0x1 << 16) ;- (AES) Random Number Generator Seed Loading

+// - -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+AT91C_AES_CIPHER          EQU (0x1 <<  0) ;- (AES) Processing Mode

+AT91C_AES_PROCDLY         EQU (0xF <<  4) ;- (AES) Processing Delay

+AT91C_AES_SMOD            EQU (0x3 <<  8) ;- (AES) Start Mode

+AT91C_AES_SMOD_MANUAL     EQU (0x0 <<  8) ;- (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+AT91C_AES_SMOD_AUTO       EQU (0x1 <<  8) ;- (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+AT91C_AES_SMOD_PDC        EQU (0x2 <<  8) ;- (AES) PDC Mode (cf datasheet).

+AT91C_AES_OPMOD           EQU (0x7 << 12) ;- (AES) Operation Mode

+AT91C_AES_OPMOD_ECB       EQU (0x0 << 12) ;- (AES) ECB Electronic CodeBook mode.

+AT91C_AES_OPMOD_CBC       EQU (0x1 << 12) ;- (AES) CBC Cipher Block Chaining mode.

+AT91C_AES_OPMOD_OFB       EQU (0x2 << 12) ;- (AES) OFB Output Feedback mode.

+AT91C_AES_OPMOD_CFB       EQU (0x3 << 12) ;- (AES) CFB Cipher Feedback mode.

+AT91C_AES_OPMOD_CTR       EQU (0x4 << 12) ;- (AES) CTR Counter mode.

+AT91C_AES_LOD             EQU (0x1 << 15) ;- (AES) Last Output Data Mode

+AT91C_AES_CFBS            EQU (0x7 << 16) ;- (AES) Cipher Feedback Data Size

+AT91C_AES_CFBS_128_BIT    EQU (0x0 << 16) ;- (AES) 128-bit.

+AT91C_AES_CFBS_64_BIT     EQU (0x1 << 16) ;- (AES) 64-bit.

+AT91C_AES_CFBS_32_BIT     EQU (0x2 << 16) ;- (AES) 32-bit.

+AT91C_AES_CFBS_16_BIT     EQU (0x3 << 16) ;- (AES) 16-bit.

+AT91C_AES_CFBS_8_BIT      EQU (0x4 << 16) ;- (AES) 8-bit.

+AT91C_AES_CKEY            EQU (0xF << 20) ;- (AES) Countermeasure Key

+AT91C_AES_CTYPE           EQU (0x1F << 24) ;- (AES) Countermeasure Type

+AT91C_AES_CTYPE_TYPE1_EN  EQU (0x1 << 24) ;- (AES) Countermeasure type 1 is enabled.

+AT91C_AES_CTYPE_TYPE2_EN  EQU (0x2 << 24) ;- (AES) Countermeasure type 2 is enabled.

+AT91C_AES_CTYPE_TYPE3_EN  EQU (0x4 << 24) ;- (AES) Countermeasure type 3 is enabled.

+AT91C_AES_CTYPE_TYPE4_EN  EQU (0x8 << 24) ;- (AES) Countermeasure type 4 is enabled.

+AT91C_AES_CTYPE_TYPE5_EN  EQU (0x10 << 24) ;- (AES) Countermeasure type 5 is enabled.

+// - -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+AT91C_AES_DATRDY          EQU (0x1 <<  0) ;- (AES) DATRDY

+AT91C_AES_ENDRX           EQU (0x1 <<  1) ;- (AES) PDC Read Buffer End

+AT91C_AES_ENDTX           EQU (0x1 <<  2) ;- (AES) PDC Write Buffer End

+AT91C_AES_RXBUFF          EQU (0x1 <<  3) ;- (AES) PDC Read Buffer Full

+AT91C_AES_TXBUFE          EQU (0x1 <<  4) ;- (AES) PDC Write Buffer Empty

+AT91C_AES_URAD            EQU (0x1 <<  8) ;- (AES) Unspecified Register Access Detection

+// - -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// - -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// - -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+AT91C_AES_URAT            EQU (0x7 << 12) ;- (AES) Unspecified Register Access Type Status

+AT91C_AES_URAT_IN_DAT_WRITE_DATPROC EQU (0x0 << 12) ;- (AES) Input data register written during the data processing in PDC mode.

+AT91C_AES_URAT_OUT_DAT_READ_DATPROC EQU (0x1 << 12) ;- (AES) Output data register read during the data processing.

+AT91C_AES_URAT_MODEREG_WRITE_DATPROC EQU (0x2 << 12) ;- (AES) Mode register written during the data processing.

+AT91C_AES_URAT_OUT_DAT_READ_SUBKEY EQU (0x3 << 12) ;- (AES) Output data register read during the sub-keys generation.

+AT91C_AES_URAT_MODEREG_WRITE_SUBKEY EQU (0x4 << 12) ;- (AES) Mode register written during the sub-keys generation.

+AT91C_AES_URAT_WO_REG_READ EQU (0x5 << 12) ;- (AES) Write-only register read access.

+

+// - *****************************************************************************

+// -              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// - *****************************************************************************

+// - -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+AT91C_TDES_START          EQU (0x1 <<  0) ;- (TDES) Starts Processing

+AT91C_TDES_SWRST          EQU (0x1 <<  8) ;- (TDES) Software Reset

+// - -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+AT91C_TDES_CIPHER         EQU (0x1 <<  0) ;- (TDES) Processing Mode

+AT91C_TDES_TDESMOD        EQU (0x1 <<  1) ;- (TDES) Single or Triple DES Mode

+AT91C_TDES_KEYMOD         EQU (0x1 <<  4) ;- (TDES) Key Mode

+AT91C_TDES_SMOD           EQU (0x3 <<  8) ;- (TDES) Start Mode

+AT91C_TDES_SMOD_MANUAL    EQU (0x0 <<  8) ;- (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+AT91C_TDES_SMOD_AUTO      EQU (0x1 <<  8) ;- (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+AT91C_TDES_SMOD_PDC       EQU (0x2 <<  8) ;- (TDES) PDC Mode (cf datasheet).

+AT91C_TDES_OPMOD          EQU (0x3 << 12) ;- (TDES) Operation Mode

+AT91C_TDES_OPMOD_ECB      EQU (0x0 << 12) ;- (TDES) ECB Electronic CodeBook mode.

+AT91C_TDES_OPMOD_CBC      EQU (0x1 << 12) ;- (TDES) CBC Cipher Block Chaining mode.

+AT91C_TDES_OPMOD_OFB      EQU (0x2 << 12) ;- (TDES) OFB Output Feedback mode.

+AT91C_TDES_OPMOD_CFB      EQU (0x3 << 12) ;- (TDES) CFB Cipher Feedback mode.

+AT91C_TDES_LOD            EQU (0x1 << 15) ;- (TDES) Last Output Data Mode

+AT91C_TDES_CFBS           EQU (0x3 << 16) ;- (TDES) Cipher Feedback Data Size

+AT91C_TDES_CFBS_64_BIT    EQU (0x0 << 16) ;- (TDES) 64-bit.

+AT91C_TDES_CFBS_32_BIT    EQU (0x1 << 16) ;- (TDES) 32-bit.

+AT91C_TDES_CFBS_16_BIT    EQU (0x2 << 16) ;- (TDES) 16-bit.

+AT91C_TDES_CFBS_8_BIT     EQU (0x3 << 16) ;- (TDES) 8-bit.

+// - -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+AT91C_TDES_DATRDY         EQU (0x1 <<  0) ;- (TDES) DATRDY

+AT91C_TDES_ENDRX          EQU (0x1 <<  1) ;- (TDES) PDC Read Buffer End

+AT91C_TDES_ENDTX          EQU (0x1 <<  2) ;- (TDES) PDC Write Buffer End

+AT91C_TDES_RXBUFF         EQU (0x1 <<  3) ;- (TDES) PDC Read Buffer Full

+AT91C_TDES_TXBUFE         EQU (0x1 <<  4) ;- (TDES) PDC Write Buffer Empty

+AT91C_TDES_URAD           EQU (0x1 <<  8) ;- (TDES) Unspecified Register Access Detection

+// - -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// - -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// - -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+AT91C_TDES_URAT           EQU (0x3 << 12) ;- (TDES) Unspecified Register Access Type Status

+AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC EQU (0x0 << 12) ;- (TDES) Input data register written during the data processing in PDC mode.

+AT91C_TDES_URAT_OUT_DAT_READ_DATPROC EQU (0x1 << 12) ;- (TDES) Output data register read during the data processing.

+AT91C_TDES_URAT_MODEREG_WRITE_DATPROC EQU (0x2 << 12) ;- (TDES) Mode register written during the data processing.

+AT91C_TDES_URAT_WO_REG_READ EQU (0x3 << 12) ;- (TDES) Write-only register read access.

+

+// - *****************************************************************************

+// -               REGISTER ADDRESS DEFINITION FOR AT91SAM7X256

+// - *****************************************************************************

+// - ========== Register definition for SYS peripheral ========== 

+// - ========== Register definition for AIC peripheral ========== 

+AT91C_AIC_IVR             EQU (0xFFFFF100) ;- (AIC) IRQ Vector Register

+AT91C_AIC_SMR             EQU (0xFFFFF000) ;- (AIC) Source Mode Register

+AT91C_AIC_FVR             EQU (0xFFFFF104) ;- (AIC) FIQ Vector Register

+AT91C_AIC_DCR             EQU (0xFFFFF138) ;- (AIC) Debug Control Register (Protect)

+AT91C_AIC_EOICR           EQU (0xFFFFF130) ;- (AIC) End of Interrupt Command Register

+AT91C_AIC_SVR             EQU (0xFFFFF080) ;- (AIC) Source Vector Register

+AT91C_AIC_FFSR            EQU (0xFFFFF148) ;- (AIC) Fast Forcing Status Register

+AT91C_AIC_ICCR            EQU (0xFFFFF128) ;- (AIC) Interrupt Clear Command Register

+AT91C_AIC_ISR             EQU (0xFFFFF108) ;- (AIC) Interrupt Status Register

+AT91C_AIC_IMR             EQU (0xFFFFF110) ;- (AIC) Interrupt Mask Register

+AT91C_AIC_IPR             EQU (0xFFFFF10C) ;- (AIC) Interrupt Pending Register

+AT91C_AIC_FFER            EQU (0xFFFFF140) ;- (AIC) Fast Forcing Enable Register

+AT91C_AIC_IECR            EQU (0xFFFFF120) ;- (AIC) Interrupt Enable Command Register

+AT91C_AIC_ISCR            EQU (0xFFFFF12C) ;- (AIC) Interrupt Set Command Register

+AT91C_AIC_FFDR            EQU (0xFFFFF144) ;- (AIC) Fast Forcing Disable Register

+AT91C_AIC_CISR            EQU (0xFFFFF114) ;- (AIC) Core Interrupt Status Register

+AT91C_AIC_IDCR            EQU (0xFFFFF124) ;- (AIC) Interrupt Disable Command Register

+AT91C_AIC_SPU             EQU (0xFFFFF134) ;- (AIC) Spurious Vector Register

+// - ========== Register definition for PDC_DBGU peripheral ========== 

+AT91C_DBGU_TCR            EQU (0xFFFFF30C) ;- (PDC_DBGU) Transmit Counter Register

+AT91C_DBGU_RNPR           EQU (0xFFFFF310) ;- (PDC_DBGU) Receive Next Pointer Register

+AT91C_DBGU_TNPR           EQU (0xFFFFF318) ;- (PDC_DBGU) Transmit Next Pointer Register

+AT91C_DBGU_TPR            EQU (0xFFFFF308) ;- (PDC_DBGU) Transmit Pointer Register

+AT91C_DBGU_RPR            EQU (0xFFFFF300) ;- (PDC_DBGU) Receive Pointer Register

+AT91C_DBGU_RCR            EQU (0xFFFFF304) ;- (PDC_DBGU) Receive Counter Register

+AT91C_DBGU_RNCR           EQU (0xFFFFF314) ;- (PDC_DBGU) Receive Next Counter Register

+AT91C_DBGU_PTCR           EQU (0xFFFFF320) ;- (PDC_DBGU) PDC Transfer Control Register

+AT91C_DBGU_PTSR           EQU (0xFFFFF324) ;- (PDC_DBGU) PDC Transfer Status Register

+AT91C_DBGU_TNCR           EQU (0xFFFFF31C) ;- (PDC_DBGU) Transmit Next Counter Register

+// - ========== Register definition for DBGU peripheral ========== 

+AT91C_DBGU_EXID           EQU (0xFFFFF244) ;- (DBGU) Chip ID Extension Register

+AT91C_DBGU_BRGR           EQU (0xFFFFF220) ;- (DBGU) Baud Rate Generator Register

+AT91C_DBGU_IDR            EQU (0xFFFFF20C) ;- (DBGU) Interrupt Disable Register

+AT91C_DBGU_CSR            EQU (0xFFFFF214) ;- (DBGU) Channel Status Register

+AT91C_DBGU_CIDR           EQU (0xFFFFF240) ;- (DBGU) Chip ID Register

+AT91C_DBGU_MR             EQU (0xFFFFF204) ;- (DBGU) Mode Register

+AT91C_DBGU_IMR            EQU (0xFFFFF210) ;- (DBGU) Interrupt Mask Register

+AT91C_DBGU_CR             EQU (0xFFFFF200) ;- (DBGU) Control Register

+AT91C_DBGU_FNTR           EQU (0xFFFFF248) ;- (DBGU) Force NTRST Register

+AT91C_DBGU_THR            EQU (0xFFFFF21C) ;- (DBGU) Transmitter Holding Register

+AT91C_DBGU_RHR            EQU (0xFFFFF218) ;- (DBGU) Receiver Holding Register

+AT91C_DBGU_IER            EQU (0xFFFFF208) ;- (DBGU) Interrupt Enable Register

+// - ========== Register definition for PIOA peripheral ========== 

+AT91C_PIOA_ODR            EQU (0xFFFFF414) ;- (PIOA) Output Disable Registerr

+AT91C_PIOA_SODR           EQU (0xFFFFF430) ;- (PIOA) Set Output Data Register

+AT91C_PIOA_ISR            EQU (0xFFFFF44C) ;- (PIOA) Interrupt Status Register

+AT91C_PIOA_ABSR           EQU (0xFFFFF478) ;- (PIOA) AB Select Status Register

+AT91C_PIOA_IER            EQU (0xFFFFF440) ;- (PIOA) Interrupt Enable Register

+AT91C_PIOA_PPUDR          EQU (0xFFFFF460) ;- (PIOA) Pull-up Disable Register

+AT91C_PIOA_IMR            EQU (0xFFFFF448) ;- (PIOA) Interrupt Mask Register

+AT91C_PIOA_PER            EQU (0xFFFFF400) ;- (PIOA) PIO Enable Register

+AT91C_PIOA_IFDR           EQU (0xFFFFF424) ;- (PIOA) Input Filter Disable Register

+AT91C_PIOA_OWDR           EQU (0xFFFFF4A4) ;- (PIOA) Output Write Disable Register

+AT91C_PIOA_MDSR           EQU (0xFFFFF458) ;- (PIOA) Multi-driver Status Register

+AT91C_PIOA_IDR            EQU (0xFFFFF444) ;- (PIOA) Interrupt Disable Register

+AT91C_PIOA_ODSR           EQU (0xFFFFF438) ;- (PIOA) Output Data Status Register

+AT91C_PIOA_PPUSR          EQU (0xFFFFF468) ;- (PIOA) Pull-up Status Register

+AT91C_PIOA_OWSR           EQU (0xFFFFF4A8) ;- (PIOA) Output Write Status Register

+AT91C_PIOA_BSR            EQU (0xFFFFF474) ;- (PIOA) Select B Register

+AT91C_PIOA_OWER           EQU (0xFFFFF4A0) ;- (PIOA) Output Write Enable Register

+AT91C_PIOA_IFER           EQU (0xFFFFF420) ;- (PIOA) Input Filter Enable Register

+AT91C_PIOA_PDSR           EQU (0xFFFFF43C) ;- (PIOA) Pin Data Status Register

+AT91C_PIOA_PPUER          EQU (0xFFFFF464) ;- (PIOA) Pull-up Enable Register

+AT91C_PIOA_OSR            EQU (0xFFFFF418) ;- (PIOA) Output Status Register

+AT91C_PIOA_ASR            EQU (0xFFFFF470) ;- (PIOA) Select A Register

+AT91C_PIOA_MDDR           EQU (0xFFFFF454) ;- (PIOA) Multi-driver Disable Register

+AT91C_PIOA_CODR           EQU (0xFFFFF434) ;- (PIOA) Clear Output Data Register

+AT91C_PIOA_MDER           EQU (0xFFFFF450) ;- (PIOA) Multi-driver Enable Register

+AT91C_PIOA_PDR            EQU (0xFFFFF404) ;- (PIOA) PIO Disable Register

+AT91C_PIOA_IFSR           EQU (0xFFFFF428) ;- (PIOA) Input Filter Status Register

+AT91C_PIOA_OER            EQU (0xFFFFF410) ;- (PIOA) Output Enable Register

+AT91C_PIOA_PSR            EQU (0xFFFFF408) ;- (PIOA) PIO Status Register

+// - ========== Register definition for PIOB peripheral ========== 

+AT91C_PIOB_OWDR           EQU (0xFFFFF6A4) ;- (PIOB) Output Write Disable Register

+AT91C_PIOB_MDER           EQU (0xFFFFF650) ;- (PIOB) Multi-driver Enable Register

+AT91C_PIOB_PPUSR          EQU (0xFFFFF668) ;- (PIOB) Pull-up Status Register

+AT91C_PIOB_IMR            EQU (0xFFFFF648) ;- (PIOB) Interrupt Mask Register

+AT91C_PIOB_ASR            EQU (0xFFFFF670) ;- (PIOB) Select A Register

+AT91C_PIOB_PPUDR          EQU (0xFFFFF660) ;- (PIOB) Pull-up Disable Register

+AT91C_PIOB_PSR            EQU (0xFFFFF608) ;- (PIOB) PIO Status Register

+AT91C_PIOB_IER            EQU (0xFFFFF640) ;- (PIOB) Interrupt Enable Register

+AT91C_PIOB_CODR           EQU (0xFFFFF634) ;- (PIOB) Clear Output Data Register

+AT91C_PIOB_OWER           EQU (0xFFFFF6A0) ;- (PIOB) Output Write Enable Register

+AT91C_PIOB_ABSR           EQU (0xFFFFF678) ;- (PIOB) AB Select Status Register

+AT91C_PIOB_IFDR           EQU (0xFFFFF624) ;- (PIOB) Input Filter Disable Register

+AT91C_PIOB_PDSR           EQU (0xFFFFF63C) ;- (PIOB) Pin Data Status Register

+AT91C_PIOB_IDR            EQU (0xFFFFF644) ;- (PIOB) Interrupt Disable Register

+AT91C_PIOB_OWSR           EQU (0xFFFFF6A8) ;- (PIOB) Output Write Status Register

+AT91C_PIOB_PDR            EQU (0xFFFFF604) ;- (PIOB) PIO Disable Register

+AT91C_PIOB_ODR            EQU (0xFFFFF614) ;- (PIOB) Output Disable Registerr

+AT91C_PIOB_IFSR           EQU (0xFFFFF628) ;- (PIOB) Input Filter Status Register

+AT91C_PIOB_PPUER          EQU (0xFFFFF664) ;- (PIOB) Pull-up Enable Register

+AT91C_PIOB_SODR           EQU (0xFFFFF630) ;- (PIOB) Set Output Data Register

+AT91C_PIOB_ISR            EQU (0xFFFFF64C) ;- (PIOB) Interrupt Status Register

+AT91C_PIOB_ODSR           EQU (0xFFFFF638) ;- (PIOB) Output Data Status Register

+AT91C_PIOB_OSR            EQU (0xFFFFF618) ;- (PIOB) Output Status Register

+AT91C_PIOB_MDSR           EQU (0xFFFFF658) ;- (PIOB) Multi-driver Status Register

+AT91C_PIOB_IFER           EQU (0xFFFFF620) ;- (PIOB) Input Filter Enable Register

+AT91C_PIOB_BSR            EQU (0xFFFFF674) ;- (PIOB) Select B Register

+AT91C_PIOB_MDDR           EQU (0xFFFFF654) ;- (PIOB) Multi-driver Disable Register

+AT91C_PIOB_OER            EQU (0xFFFFF610) ;- (PIOB) Output Enable Register

+AT91C_PIOB_PER            EQU (0xFFFFF600) ;- (PIOB) PIO Enable Register

+// - ========== Register definition for CKGR peripheral ========== 

+AT91C_CKGR_MOR            EQU (0xFFFFFC20) ;- (CKGR) Main Oscillator Register

+AT91C_CKGR_PLLR           EQU (0xFFFFFC2C) ;- (CKGR) PLL Register

+AT91C_CKGR_MCFR           EQU (0xFFFFFC24) ;- (CKGR) Main Clock  Frequency Register

+// - ========== Register definition for PMC peripheral ========== 

+AT91C_PMC_IDR             EQU (0xFFFFFC64) ;- (PMC) Interrupt Disable Register

+AT91C_PMC_MOR             EQU (0xFFFFFC20) ;- (PMC) Main Oscillator Register

+AT91C_PMC_PLLR            EQU (0xFFFFFC2C) ;- (PMC) PLL Register

+AT91C_PMC_PCER            EQU (0xFFFFFC10) ;- (PMC) Peripheral Clock Enable Register

+AT91C_PMC_PCKR            EQU (0xFFFFFC40) ;- (PMC) Programmable Clock Register

+AT91C_PMC_MCKR            EQU (0xFFFFFC30) ;- (PMC) Master Clock Register

+AT91C_PMC_SCDR            EQU (0xFFFFFC04) ;- (PMC) System Clock Disable Register

+AT91C_PMC_PCDR            EQU (0xFFFFFC14) ;- (PMC) Peripheral Clock Disable Register

+AT91C_PMC_SCSR            EQU (0xFFFFFC08) ;- (PMC) System Clock Status Register

+AT91C_PMC_PCSR            EQU (0xFFFFFC18) ;- (PMC) Peripheral Clock Status Register

+AT91C_PMC_MCFR            EQU (0xFFFFFC24) ;- (PMC) Main Clock  Frequency Register

+AT91C_PMC_SCER            EQU (0xFFFFFC00) ;- (PMC) System Clock Enable Register

+AT91C_PMC_IMR             EQU (0xFFFFFC6C) ;- (PMC) Interrupt Mask Register

+AT91C_PMC_IER             EQU (0xFFFFFC60) ;- (PMC) Interrupt Enable Register

+AT91C_PMC_SR              EQU (0xFFFFFC68) ;- (PMC) Status Register

+// - ========== Register definition for RSTC peripheral ========== 

+AT91C_RSTC_RCR            EQU (0xFFFFFD00) ;- (RSTC) Reset Control Register

+AT91C_RSTC_RMR            EQU (0xFFFFFD08) ;- (RSTC) Reset Mode Register

+AT91C_RSTC_RSR            EQU (0xFFFFFD04) ;- (RSTC) Reset Status Register

+// - ========== Register definition for RTTC peripheral ========== 

+AT91C_RTTC_RTSR           EQU (0xFFFFFD2C) ;- (RTTC) Real-time Status Register

+AT91C_RTTC_RTMR           EQU (0xFFFFFD20) ;- (RTTC) Real-time Mode Register

+AT91C_RTTC_RTVR           EQU (0xFFFFFD28) ;- (RTTC) Real-time Value Register

+AT91C_RTTC_RTAR           EQU (0xFFFFFD24) ;- (RTTC) Real-time Alarm Register

+// - ========== Register definition for PITC peripheral ========== 

+AT91C_PITC_PIVR           EQU (0xFFFFFD38) ;- (PITC) Period Interval Value Register

+AT91C_PITC_PISR           EQU (0xFFFFFD34) ;- (PITC) Period Interval Status Register

+AT91C_PITC_PIIR           EQU (0xFFFFFD3C) ;- (PITC) Period Interval Image Register

+AT91C_PITC_PIMR           EQU (0xFFFFFD30) ;- (PITC) Period Interval Mode Register

+// - ========== Register definition for WDTC peripheral ========== 

+AT91C_WDTC_WDCR           EQU (0xFFFFFD40) ;- (WDTC) Watchdog Control Register

+AT91C_WDTC_WDSR           EQU (0xFFFFFD48) ;- (WDTC) Watchdog Status Register

+AT91C_WDTC_WDMR           EQU (0xFFFFFD44) ;- (WDTC) Watchdog Mode Register

+// - ========== Register definition for VREG peripheral ========== 

+AT91C_VREG_MR             EQU (0xFFFFFD60) ;- (VREG) Voltage Regulator Mode Register

+// - ========== Register definition for MC peripheral ========== 

+AT91C_MC_ASR              EQU (0xFFFFFF04) ;- (MC) MC Abort Status Register

+AT91C_MC_RCR              EQU (0xFFFFFF00) ;- (MC) MC Remap Control Register

+AT91C_MC_FCR              EQU (0xFFFFFF64) ;- (MC) MC Flash Command Register

+AT91C_MC_AASR             EQU (0xFFFFFF08) ;- (MC) MC Abort Address Status Register

+AT91C_MC_FSR              EQU (0xFFFFFF68) ;- (MC) MC Flash Status Register

+AT91C_MC_FMR              EQU (0xFFFFFF60) ;- (MC) MC Flash Mode Register

+// - ========== Register definition for PDC_SPI1 peripheral ========== 

+AT91C_SPI1_PTCR           EQU (0xFFFE4120) ;- (PDC_SPI1) PDC Transfer Control Register

+AT91C_SPI1_RPR            EQU (0xFFFE4100) ;- (PDC_SPI1) Receive Pointer Register

+AT91C_SPI1_TNCR           EQU (0xFFFE411C) ;- (PDC_SPI1) Transmit Next Counter Register

+AT91C_SPI1_TPR            EQU (0xFFFE4108) ;- (PDC_SPI1) Transmit Pointer Register

+AT91C_SPI1_TNPR           EQU (0xFFFE4118) ;- (PDC_SPI1) Transmit Next Pointer Register

+AT91C_SPI1_TCR            EQU (0xFFFE410C) ;- (PDC_SPI1) Transmit Counter Register

+AT91C_SPI1_RCR            EQU (0xFFFE4104) ;- (PDC_SPI1) Receive Counter Register

+AT91C_SPI1_RNPR           EQU (0xFFFE4110) ;- (PDC_SPI1) Receive Next Pointer Register

+AT91C_SPI1_RNCR           EQU (0xFFFE4114) ;- (PDC_SPI1) Receive Next Counter Register

+AT91C_SPI1_PTSR           EQU (0xFFFE4124) ;- (PDC_SPI1) PDC Transfer Status Register

+// - ========== Register definition for SPI1 peripheral ========== 

+AT91C_SPI1_IMR            EQU (0xFFFE401C) ;- (SPI1) Interrupt Mask Register

+AT91C_SPI1_IER            EQU (0xFFFE4014) ;- (SPI1) Interrupt Enable Register

+AT91C_SPI1_MR             EQU (0xFFFE4004) ;- (SPI1) Mode Register

+AT91C_SPI1_RDR            EQU (0xFFFE4008) ;- (SPI1) Receive Data Register

+AT91C_SPI1_IDR            EQU (0xFFFE4018) ;- (SPI1) Interrupt Disable Register

+AT91C_SPI1_SR             EQU (0xFFFE4010) ;- (SPI1) Status Register

+AT91C_SPI1_TDR            EQU (0xFFFE400C) ;- (SPI1) Transmit Data Register

+AT91C_SPI1_CR             EQU (0xFFFE4000) ;- (SPI1) Control Register

+AT91C_SPI1_CSR            EQU (0xFFFE4030) ;- (SPI1) Chip Select Register

+// - ========== Register definition for PDC_SPI0 peripheral ========== 

+AT91C_SPI0_PTCR           EQU (0xFFFE0120) ;- (PDC_SPI0) PDC Transfer Control Register

+AT91C_SPI0_TPR            EQU (0xFFFE0108) ;- (PDC_SPI0) Transmit Pointer Register

+AT91C_SPI0_TCR            EQU (0xFFFE010C) ;- (PDC_SPI0) Transmit Counter Register

+AT91C_SPI0_RCR            EQU (0xFFFE0104) ;- (PDC_SPI0) Receive Counter Register

+AT91C_SPI0_PTSR           EQU (0xFFFE0124) ;- (PDC_SPI0) PDC Transfer Status Register

+AT91C_SPI0_RNPR           EQU (0xFFFE0110) ;- (PDC_SPI0) Receive Next Pointer Register

+AT91C_SPI0_RPR            EQU (0xFFFE0100) ;- (PDC_SPI0) Receive Pointer Register

+AT91C_SPI0_TNCR           EQU (0xFFFE011C) ;- (PDC_SPI0) Transmit Next Counter Register

+AT91C_SPI0_RNCR           EQU (0xFFFE0114) ;- (PDC_SPI0) Receive Next Counter Register

+AT91C_SPI0_TNPR           EQU (0xFFFE0118) ;- (PDC_SPI0) Transmit Next Pointer Register

+// - ========== Register definition for SPI0 peripheral ========== 

+AT91C_SPI0_IER            EQU (0xFFFE0014) ;- (SPI0) Interrupt Enable Register

+AT91C_SPI0_SR             EQU (0xFFFE0010) ;- (SPI0) Status Register

+AT91C_SPI0_IDR            EQU (0xFFFE0018) ;- (SPI0) Interrupt Disable Register

+AT91C_SPI0_CR             EQU (0xFFFE0000) ;- (SPI0) Control Register

+AT91C_SPI0_MR             EQU (0xFFFE0004) ;- (SPI0) Mode Register

+AT91C_SPI0_IMR            EQU (0xFFFE001C) ;- (SPI0) Interrupt Mask Register

+AT91C_SPI0_TDR            EQU (0xFFFE000C) ;- (SPI0) Transmit Data Register

+AT91C_SPI0_RDR            EQU (0xFFFE0008) ;- (SPI0) Receive Data Register

+AT91C_SPI0_CSR            EQU (0xFFFE0030) ;- (SPI0) Chip Select Register

+// - ========== Register definition for PDC_US1 peripheral ========== 

+AT91C_US1_RNCR            EQU (0xFFFC4114) ;- (PDC_US1) Receive Next Counter Register

+AT91C_US1_PTCR            EQU (0xFFFC4120) ;- (PDC_US1) PDC Transfer Control Register

+AT91C_US1_TCR             EQU (0xFFFC410C) ;- (PDC_US1) Transmit Counter Register

+AT91C_US1_PTSR            EQU (0xFFFC4124) ;- (PDC_US1) PDC Transfer Status Register

+AT91C_US1_TNPR            EQU (0xFFFC4118) ;- (PDC_US1) Transmit Next Pointer Register

+AT91C_US1_RCR             EQU (0xFFFC4104) ;- (PDC_US1) Receive Counter Register

+AT91C_US1_RNPR            EQU (0xFFFC4110) ;- (PDC_US1) Receive Next Pointer Register

+AT91C_US1_RPR             EQU (0xFFFC4100) ;- (PDC_US1) Receive Pointer Register

+AT91C_US1_TNCR            EQU (0xFFFC411C) ;- (PDC_US1) Transmit Next Counter Register

+AT91C_US1_TPR             EQU (0xFFFC4108) ;- (PDC_US1) Transmit Pointer Register

+// - ========== Register definition for US1 peripheral ========== 

+AT91C_US1_IF              EQU (0xFFFC404C) ;- (US1) IRDA_FILTER Register

+AT91C_US1_NER             EQU (0xFFFC4044) ;- (US1) Nb Errors Register

+AT91C_US1_RTOR            EQU (0xFFFC4024) ;- (US1) Receiver Time-out Register

+AT91C_US1_CSR             EQU (0xFFFC4014) ;- (US1) Channel Status Register

+AT91C_US1_IDR             EQU (0xFFFC400C) ;- (US1) Interrupt Disable Register

+AT91C_US1_IER             EQU (0xFFFC4008) ;- (US1) Interrupt Enable Register

+AT91C_US1_THR             EQU (0xFFFC401C) ;- (US1) Transmitter Holding Register

+AT91C_US1_TTGR            EQU (0xFFFC4028) ;- (US1) Transmitter Time-guard Register

+AT91C_US1_RHR             EQU (0xFFFC4018) ;- (US1) Receiver Holding Register

+AT91C_US1_BRGR            EQU (0xFFFC4020) ;- (US1) Baud Rate Generator Register

+AT91C_US1_IMR             EQU (0xFFFC4010) ;- (US1) Interrupt Mask Register

+AT91C_US1_FIDI            EQU (0xFFFC4040) ;- (US1) FI_DI_Ratio Register

+AT91C_US1_CR              EQU (0xFFFC4000) ;- (US1) Control Register

+AT91C_US1_MR              EQU (0xFFFC4004) ;- (US1) Mode Register

+// - ========== Register definition for PDC_US0 peripheral ========== 

+AT91C_US0_TNPR            EQU (0xFFFC0118) ;- (PDC_US0) Transmit Next Pointer Register

+AT91C_US0_RNPR            EQU (0xFFFC0110) ;- (PDC_US0) Receive Next Pointer Register

+AT91C_US0_TCR             EQU (0xFFFC010C) ;- (PDC_US0) Transmit Counter Register

+AT91C_US0_PTCR            EQU (0xFFFC0120) ;- (PDC_US0) PDC Transfer Control Register

+AT91C_US0_PTSR            EQU (0xFFFC0124) ;- (PDC_US0) PDC Transfer Status Register

+AT91C_US0_TNCR            EQU (0xFFFC011C) ;- (PDC_US0) Transmit Next Counter Register

+AT91C_US0_TPR             EQU (0xFFFC0108) ;- (PDC_US0) Transmit Pointer Register

+AT91C_US0_RCR             EQU (0xFFFC0104) ;- (PDC_US0) Receive Counter Register

+AT91C_US0_RPR             EQU (0xFFFC0100) ;- (PDC_US0) Receive Pointer Register

+AT91C_US0_RNCR            EQU (0xFFFC0114) ;- (PDC_US0) Receive Next Counter Register

+// - ========== Register definition for US0 peripheral ========== 

+AT91C_US0_BRGR            EQU (0xFFFC0020) ;- (US0) Baud Rate Generator Register

+AT91C_US0_NER             EQU (0xFFFC0044) ;- (US0) Nb Errors Register

+AT91C_US0_CR              EQU (0xFFFC0000) ;- (US0) Control Register

+AT91C_US0_IMR             EQU (0xFFFC0010) ;- (US0) Interrupt Mask Register

+AT91C_US0_FIDI            EQU (0xFFFC0040) ;- (US0) FI_DI_Ratio Register

+AT91C_US0_TTGR            EQU (0xFFFC0028) ;- (US0) Transmitter Time-guard Register

+AT91C_US0_MR              EQU (0xFFFC0004) ;- (US0) Mode Register

+AT91C_US0_RTOR            EQU (0xFFFC0024) ;- (US0) Receiver Time-out Register

+AT91C_US0_CSR             EQU (0xFFFC0014) ;- (US0) Channel Status Register

+AT91C_US0_RHR             EQU (0xFFFC0018) ;- (US0) Receiver Holding Register

+AT91C_US0_IDR             EQU (0xFFFC000C) ;- (US0) Interrupt Disable Register

+AT91C_US0_THR             EQU (0xFFFC001C) ;- (US0) Transmitter Holding Register

+AT91C_US0_IF              EQU (0xFFFC004C) ;- (US0) IRDA_FILTER Register

+AT91C_US0_IER             EQU (0xFFFC0008) ;- (US0) Interrupt Enable Register

+// - ========== Register definition for PDC_SSC peripheral ========== 

+AT91C_SSC_TNCR            EQU (0xFFFD411C) ;- (PDC_SSC) Transmit Next Counter Register

+AT91C_SSC_RPR             EQU (0xFFFD4100) ;- (PDC_SSC) Receive Pointer Register

+AT91C_SSC_RNCR            EQU (0xFFFD4114) ;- (PDC_SSC) Receive Next Counter Register

+AT91C_SSC_TPR             EQU (0xFFFD4108) ;- (PDC_SSC) Transmit Pointer Register

+AT91C_SSC_PTCR            EQU (0xFFFD4120) ;- (PDC_SSC) PDC Transfer Control Register

+AT91C_SSC_TCR             EQU (0xFFFD410C) ;- (PDC_SSC) Transmit Counter Register

+AT91C_SSC_RCR             EQU (0xFFFD4104) ;- (PDC_SSC) Receive Counter Register

+AT91C_SSC_RNPR            EQU (0xFFFD4110) ;- (PDC_SSC) Receive Next Pointer Register

+AT91C_SSC_TNPR            EQU (0xFFFD4118) ;- (PDC_SSC) Transmit Next Pointer Register

+AT91C_SSC_PTSR            EQU (0xFFFD4124) ;- (PDC_SSC) PDC Transfer Status Register

+// - ========== Register definition for SSC peripheral ========== 

+AT91C_SSC_RHR             EQU (0xFFFD4020) ;- (SSC) Receive Holding Register

+AT91C_SSC_RSHR            EQU (0xFFFD4030) ;- (SSC) Receive Sync Holding Register

+AT91C_SSC_TFMR            EQU (0xFFFD401C) ;- (SSC) Transmit Frame Mode Register

+AT91C_SSC_IDR             EQU (0xFFFD4048) ;- (SSC) Interrupt Disable Register

+AT91C_SSC_THR             EQU (0xFFFD4024) ;- (SSC) Transmit Holding Register

+AT91C_SSC_RCMR            EQU (0xFFFD4010) ;- (SSC) Receive Clock ModeRegister

+AT91C_SSC_IER             EQU (0xFFFD4044) ;- (SSC) Interrupt Enable Register

+AT91C_SSC_TSHR            EQU (0xFFFD4034) ;- (SSC) Transmit Sync Holding Register

+AT91C_SSC_SR              EQU (0xFFFD4040) ;- (SSC) Status Register

+AT91C_SSC_CMR             EQU (0xFFFD4004) ;- (SSC) Clock Mode Register

+AT91C_SSC_TCMR            EQU (0xFFFD4018) ;- (SSC) Transmit Clock Mode Register

+AT91C_SSC_CR              EQU (0xFFFD4000) ;- (SSC) Control Register

+AT91C_SSC_IMR             EQU (0xFFFD404C) ;- (SSC) Interrupt Mask Register

+AT91C_SSC_RFMR            EQU (0xFFFD4014) ;- (SSC) Receive Frame Mode Register

+// - ========== Register definition for TWI peripheral ========== 

+AT91C_TWI_IER             EQU (0xFFFB8024) ;- (TWI) Interrupt Enable Register

+AT91C_TWI_CR              EQU (0xFFFB8000) ;- (TWI) Control Register

+AT91C_TWI_SR              EQU (0xFFFB8020) ;- (TWI) Status Register

+AT91C_TWI_IMR             EQU (0xFFFB802C) ;- (TWI) Interrupt Mask Register

+AT91C_TWI_THR             EQU (0xFFFB8034) ;- (TWI) Transmit Holding Register

+AT91C_TWI_IDR             EQU (0xFFFB8028) ;- (TWI) Interrupt Disable Register

+AT91C_TWI_IADR            EQU (0xFFFB800C) ;- (TWI) Internal Address Register

+AT91C_TWI_MMR             EQU (0xFFFB8004) ;- (TWI) Master Mode Register

+AT91C_TWI_CWGR            EQU (0xFFFB8010) ;- (TWI) Clock Waveform Generator Register

+AT91C_TWI_RHR             EQU (0xFFFB8030) ;- (TWI) Receive Holding Register

+// - ========== Register definition for PWMC_CH3 peripheral ========== 

+AT91C_PWMC_CH3_CUPDR      EQU (0xFFFCC270) ;- (PWMC_CH3) Channel Update Register

+AT91C_PWMC_CH3_Reserved   EQU (0xFFFCC274) ;- (PWMC_CH3) Reserved

+AT91C_PWMC_CH3_CPRDR      EQU (0xFFFCC268) ;- (PWMC_CH3) Channel Period Register

+AT91C_PWMC_CH3_CDTYR      EQU (0xFFFCC264) ;- (PWMC_CH3) Channel Duty Cycle Register

+AT91C_PWMC_CH3_CCNTR      EQU (0xFFFCC26C) ;- (PWMC_CH3) Channel Counter Register

+AT91C_PWMC_CH3_CMR        EQU (0xFFFCC260) ;- (PWMC_CH3) Channel Mode Register

+// - ========== Register definition for PWMC_CH2 peripheral ========== 

+AT91C_PWMC_CH2_Reserved   EQU (0xFFFCC254) ;- (PWMC_CH2) Reserved

+AT91C_PWMC_CH2_CMR        EQU (0xFFFCC240) ;- (PWMC_CH2) Channel Mode Register

+AT91C_PWMC_CH2_CCNTR      EQU (0xFFFCC24C) ;- (PWMC_CH2) Channel Counter Register

+AT91C_PWMC_CH2_CPRDR      EQU (0xFFFCC248) ;- (PWMC_CH2) Channel Period Register

+AT91C_PWMC_CH2_CUPDR      EQU (0xFFFCC250) ;- (PWMC_CH2) Channel Update Register

+AT91C_PWMC_CH2_CDTYR      EQU (0xFFFCC244) ;- (PWMC_CH2) Channel Duty Cycle Register

+// - ========== Register definition for PWMC_CH1 peripheral ========== 

+AT91C_PWMC_CH1_Reserved   EQU (0xFFFCC234) ;- (PWMC_CH1) Reserved

+AT91C_PWMC_CH1_CUPDR      EQU (0xFFFCC230) ;- (PWMC_CH1) Channel Update Register

+AT91C_PWMC_CH1_CPRDR      EQU (0xFFFCC228) ;- (PWMC_CH1) Channel Period Register

+AT91C_PWMC_CH1_CCNTR      EQU (0xFFFCC22C) ;- (PWMC_CH1) Channel Counter Register

+AT91C_PWMC_CH1_CDTYR      EQU (0xFFFCC224) ;- (PWMC_CH1) Channel Duty Cycle Register

+AT91C_PWMC_CH1_CMR        EQU (0xFFFCC220) ;- (PWMC_CH1) Channel Mode Register

+// - ========== Register definition for PWMC_CH0 peripheral ========== 

+AT91C_PWMC_CH0_Reserved   EQU (0xFFFCC214) ;- (PWMC_CH0) Reserved

+AT91C_PWMC_CH0_CPRDR      EQU (0xFFFCC208) ;- (PWMC_CH0) Channel Period Register

+AT91C_PWMC_CH0_CDTYR      EQU (0xFFFCC204) ;- (PWMC_CH0) Channel Duty Cycle Register

+AT91C_PWMC_CH0_CMR        EQU (0xFFFCC200) ;- (PWMC_CH0) Channel Mode Register

+AT91C_PWMC_CH0_CUPDR      EQU (0xFFFCC210) ;- (PWMC_CH0) Channel Update Register

+AT91C_PWMC_CH0_CCNTR      EQU (0xFFFCC20C) ;- (PWMC_CH0) Channel Counter Register

+// - ========== Register definition for PWMC peripheral ========== 

+AT91C_PWMC_IDR            EQU (0xFFFCC014) ;- (PWMC) PWMC Interrupt Disable Register

+AT91C_PWMC_DIS            EQU (0xFFFCC008) ;- (PWMC) PWMC Disable Register

+AT91C_PWMC_IER            EQU (0xFFFCC010) ;- (PWMC) PWMC Interrupt Enable Register

+AT91C_PWMC_VR             EQU (0xFFFCC0FC) ;- (PWMC) PWMC Version Register

+AT91C_PWMC_ISR            EQU (0xFFFCC01C) ;- (PWMC) PWMC Interrupt Status Register

+AT91C_PWMC_SR             EQU (0xFFFCC00C) ;- (PWMC) PWMC Status Register

+AT91C_PWMC_IMR            EQU (0xFFFCC018) ;- (PWMC) PWMC Interrupt Mask Register

+AT91C_PWMC_MR             EQU (0xFFFCC000) ;- (PWMC) PWMC Mode Register

+AT91C_PWMC_ENA            EQU (0xFFFCC004) ;- (PWMC) PWMC Enable Register

+// - ========== Register definition for UDP peripheral ========== 

+AT91C_UDP_IMR             EQU (0xFFFB0018) ;- (UDP) Interrupt Mask Register

+AT91C_UDP_FADDR           EQU (0xFFFB0008) ;- (UDP) Function Address Register

+AT91C_UDP_NUM             EQU (0xFFFB0000) ;- (UDP) Frame Number Register

+AT91C_UDP_FDR             EQU (0xFFFB0050) ;- (UDP) Endpoint FIFO Data Register

+AT91C_UDP_ISR             EQU (0xFFFB001C) ;- (UDP) Interrupt Status Register

+AT91C_UDP_CSR             EQU (0xFFFB0030) ;- (UDP) Endpoint Control and Status Register

+AT91C_UDP_IDR             EQU (0xFFFB0014) ;- (UDP) Interrupt Disable Register

+AT91C_UDP_ICR             EQU (0xFFFB0020) ;- (UDP) Interrupt Clear Register

+AT91C_UDP_RSTEP           EQU (0xFFFB0028) ;- (UDP) Reset Endpoint Register

+AT91C_UDP_TXVC            EQU (0xFFFB0074) ;- (UDP) Transceiver Control Register

+AT91C_UDP_GLBSTATE        EQU (0xFFFB0004) ;- (UDP) Global State Register

+AT91C_UDP_IER             EQU (0xFFFB0010) ;- (UDP) Interrupt Enable Register

+// - ========== Register definition for TC0 peripheral ========== 

+AT91C_TC0_SR              EQU (0xFFFA0020) ;- (TC0) Status Register

+AT91C_TC0_RC              EQU (0xFFFA001C) ;- (TC0) Register C

+AT91C_TC0_RB              EQU (0xFFFA0018) ;- (TC0) Register B

+AT91C_TC0_CCR             EQU (0xFFFA0000) ;- (TC0) Channel Control Register

+AT91C_TC0_CMR             EQU (0xFFFA0004) ;- (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+AT91C_TC0_IER             EQU (0xFFFA0024) ;- (TC0) Interrupt Enable Register

+AT91C_TC0_RA              EQU (0xFFFA0014) ;- (TC0) Register A

+AT91C_TC0_IDR             EQU (0xFFFA0028) ;- (TC0) Interrupt Disable Register

+AT91C_TC0_CV              EQU (0xFFFA0010) ;- (TC0) Counter Value

+AT91C_TC0_IMR             EQU (0xFFFA002C) ;- (TC0) Interrupt Mask Register

+// - ========== Register definition for TC1 peripheral ========== 

+AT91C_TC1_RB              EQU (0xFFFA0058) ;- (TC1) Register B

+AT91C_TC1_CCR             EQU (0xFFFA0040) ;- (TC1) Channel Control Register

+AT91C_TC1_IER             EQU (0xFFFA0064) ;- (TC1) Interrupt Enable Register

+AT91C_TC1_IDR             EQU (0xFFFA0068) ;- (TC1) Interrupt Disable Register

+AT91C_TC1_SR              EQU (0xFFFA0060) ;- (TC1) Status Register

+AT91C_TC1_CMR             EQU (0xFFFA0044) ;- (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+AT91C_TC1_RA              EQU (0xFFFA0054) ;- (TC1) Register A

+AT91C_TC1_RC              EQU (0xFFFA005C) ;- (TC1) Register C

+AT91C_TC1_IMR             EQU (0xFFFA006C) ;- (TC1) Interrupt Mask Register

+AT91C_TC1_CV              EQU (0xFFFA0050) ;- (TC1) Counter Value

+// - ========== Register definition for TC2 peripheral ========== 

+AT91C_TC2_CMR             EQU (0xFFFA0084) ;- (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+AT91C_TC2_CCR             EQU (0xFFFA0080) ;- (TC2) Channel Control Register

+AT91C_TC2_CV              EQU (0xFFFA0090) ;- (TC2) Counter Value

+AT91C_TC2_RA              EQU (0xFFFA0094) ;- (TC2) Register A

+AT91C_TC2_RB              EQU (0xFFFA0098) ;- (TC2) Register B

+AT91C_TC2_IDR             EQU (0xFFFA00A8) ;- (TC2) Interrupt Disable Register

+AT91C_TC2_IMR             EQU (0xFFFA00AC) ;- (TC2) Interrupt Mask Register

+AT91C_TC2_RC              EQU (0xFFFA009C) ;- (TC2) Register C

+AT91C_TC2_IER             EQU (0xFFFA00A4) ;- (TC2) Interrupt Enable Register

+AT91C_TC2_SR              EQU (0xFFFA00A0) ;- (TC2) Status Register

+// - ========== Register definition for TCB peripheral ========== 

+AT91C_TCB_BMR             EQU (0xFFFA00C4) ;- (TCB) TC Block Mode Register

+AT91C_TCB_BCR             EQU (0xFFFA00C0) ;- (TCB) TC Block Control Register

+// - ========== Register definition for CAN_MB0 peripheral ========== 

+AT91C_CAN_MB0_MDL         EQU (0xFFFD0214) ;- (CAN_MB0) MailBox Data Low Register

+AT91C_CAN_MB0_MAM         EQU (0xFFFD0204) ;- (CAN_MB0) MailBox Acceptance Mask Register

+AT91C_CAN_MB0_MCR         EQU (0xFFFD021C) ;- (CAN_MB0) MailBox Control Register

+AT91C_CAN_MB0_MID         EQU (0xFFFD0208) ;- (CAN_MB0) MailBox ID Register

+AT91C_CAN_MB0_MSR         EQU (0xFFFD0210) ;- (CAN_MB0) MailBox Status Register

+AT91C_CAN_MB0_MFID        EQU (0xFFFD020C) ;- (CAN_MB0) MailBox Family ID Register

+AT91C_CAN_MB0_MDH         EQU (0xFFFD0218) ;- (CAN_MB0) MailBox Data High Register

+AT91C_CAN_MB0_MMR         EQU (0xFFFD0200) ;- (CAN_MB0) MailBox Mode Register

+// - ========== Register definition for CAN_MB1 peripheral ========== 

+AT91C_CAN_MB1_MDL         EQU (0xFFFD0234) ;- (CAN_MB1) MailBox Data Low Register

+AT91C_CAN_MB1_MID         EQU (0xFFFD0228) ;- (CAN_MB1) MailBox ID Register

+AT91C_CAN_MB1_MMR         EQU (0xFFFD0220) ;- (CAN_MB1) MailBox Mode Register

+AT91C_CAN_MB1_MSR         EQU (0xFFFD0230) ;- (CAN_MB1) MailBox Status Register

+AT91C_CAN_MB1_MAM         EQU (0xFFFD0224) ;- (CAN_MB1) MailBox Acceptance Mask Register

+AT91C_CAN_MB1_MDH         EQU (0xFFFD0238) ;- (CAN_MB1) MailBox Data High Register

+AT91C_CAN_MB1_MCR         EQU (0xFFFD023C) ;- (CAN_MB1) MailBox Control Register

+AT91C_CAN_MB1_MFID        EQU (0xFFFD022C) ;- (CAN_MB1) MailBox Family ID Register

+// - ========== Register definition for CAN_MB2 peripheral ========== 

+AT91C_CAN_MB2_MCR         EQU (0xFFFD025C) ;- (CAN_MB2) MailBox Control Register

+AT91C_CAN_MB2_MDH         EQU (0xFFFD0258) ;- (CAN_MB2) MailBox Data High Register

+AT91C_CAN_MB2_MID         EQU (0xFFFD0248) ;- (CAN_MB2) MailBox ID Register

+AT91C_CAN_MB2_MDL         EQU (0xFFFD0254) ;- (CAN_MB2) MailBox Data Low Register

+AT91C_CAN_MB2_MMR         EQU (0xFFFD0240) ;- (CAN_MB2) MailBox Mode Register

+AT91C_CAN_MB2_MAM         EQU (0xFFFD0244) ;- (CAN_MB2) MailBox Acceptance Mask Register

+AT91C_CAN_MB2_MFID        EQU (0xFFFD024C) ;- (CAN_MB2) MailBox Family ID Register

+AT91C_CAN_MB2_MSR         EQU (0xFFFD0250) ;- (CAN_MB2) MailBox Status Register

+// - ========== Register definition for CAN_MB3 peripheral ========== 

+AT91C_CAN_MB3_MFID        EQU (0xFFFD026C) ;- (CAN_MB3) MailBox Family ID Register

+AT91C_CAN_MB3_MAM         EQU (0xFFFD0264) ;- (CAN_MB3) MailBox Acceptance Mask Register

+AT91C_CAN_MB3_MID         EQU (0xFFFD0268) ;- (CAN_MB3) MailBox ID Register

+AT91C_CAN_MB3_MCR         EQU (0xFFFD027C) ;- (CAN_MB3) MailBox Control Register

+AT91C_CAN_MB3_MMR         EQU (0xFFFD0260) ;- (CAN_MB3) MailBox Mode Register

+AT91C_CAN_MB3_MSR         EQU (0xFFFD0270) ;- (CAN_MB3) MailBox Status Register

+AT91C_CAN_MB3_MDL         EQU (0xFFFD0274) ;- (CAN_MB3) MailBox Data Low Register

+AT91C_CAN_MB3_MDH         EQU (0xFFFD0278) ;- (CAN_MB3) MailBox Data High Register

+// - ========== Register definition for CAN_MB4 peripheral ========== 

+AT91C_CAN_MB4_MID         EQU (0xFFFD0288) ;- (CAN_MB4) MailBox ID Register

+AT91C_CAN_MB4_MMR         EQU (0xFFFD0280) ;- (CAN_MB4) MailBox Mode Register

+AT91C_CAN_MB4_MDH         EQU (0xFFFD0298) ;- (CAN_MB4) MailBox Data High Register

+AT91C_CAN_MB4_MFID        EQU (0xFFFD028C) ;- (CAN_MB4) MailBox Family ID Register

+AT91C_CAN_MB4_MSR         EQU (0xFFFD0290) ;- (CAN_MB4) MailBox Status Register

+AT91C_CAN_MB4_MCR         EQU (0xFFFD029C) ;- (CAN_MB4) MailBox Control Register

+AT91C_CAN_MB4_MDL         EQU (0xFFFD0294) ;- (CAN_MB4) MailBox Data Low Register

+AT91C_CAN_MB4_MAM         EQU (0xFFFD0284) ;- (CAN_MB4) MailBox Acceptance Mask Register

+// - ========== Register definition for CAN_MB5 peripheral ========== 

+AT91C_CAN_MB5_MSR         EQU (0xFFFD02B0) ;- (CAN_MB5) MailBox Status Register

+AT91C_CAN_MB5_MCR         EQU (0xFFFD02BC) ;- (CAN_MB5) MailBox Control Register

+AT91C_CAN_MB5_MFID        EQU (0xFFFD02AC) ;- (CAN_MB5) MailBox Family ID Register

+AT91C_CAN_MB5_MDH         EQU (0xFFFD02B8) ;- (CAN_MB5) MailBox Data High Register

+AT91C_CAN_MB5_MID         EQU (0xFFFD02A8) ;- (CAN_MB5) MailBox ID Register

+AT91C_CAN_MB5_MMR         EQU (0xFFFD02A0) ;- (CAN_MB5) MailBox Mode Register

+AT91C_CAN_MB5_MDL         EQU (0xFFFD02B4) ;- (CAN_MB5) MailBox Data Low Register

+AT91C_CAN_MB5_MAM         EQU (0xFFFD02A4) ;- (CAN_MB5) MailBox Acceptance Mask Register

+// - ========== Register definition for CAN_MB6 peripheral ========== 

+AT91C_CAN_MB6_MFID        EQU (0xFFFD02CC) ;- (CAN_MB6) MailBox Family ID Register

+AT91C_CAN_MB6_MID         EQU (0xFFFD02C8) ;- (CAN_MB6) MailBox ID Register

+AT91C_CAN_MB6_MAM         EQU (0xFFFD02C4) ;- (CAN_MB6) MailBox Acceptance Mask Register

+AT91C_CAN_MB6_MSR         EQU (0xFFFD02D0) ;- (CAN_MB6) MailBox Status Register

+AT91C_CAN_MB6_MDL         EQU (0xFFFD02D4) ;- (CAN_MB6) MailBox Data Low Register

+AT91C_CAN_MB6_MCR         EQU (0xFFFD02DC) ;- (CAN_MB6) MailBox Control Register

+AT91C_CAN_MB6_MDH         EQU (0xFFFD02D8) ;- (CAN_MB6) MailBox Data High Register

+AT91C_CAN_MB6_MMR         EQU (0xFFFD02C0) ;- (CAN_MB6) MailBox Mode Register

+// - ========== Register definition for CAN_MB7 peripheral ========== 

+AT91C_CAN_MB7_MCR         EQU (0xFFFD02FC) ;- (CAN_MB7) MailBox Control Register

+AT91C_CAN_MB7_MDH         EQU (0xFFFD02F8) ;- (CAN_MB7) MailBox Data High Register

+AT91C_CAN_MB7_MFID        EQU (0xFFFD02EC) ;- (CAN_MB7) MailBox Family ID Register

+AT91C_CAN_MB7_MDL         EQU (0xFFFD02F4) ;- (CAN_MB7) MailBox Data Low Register

+AT91C_CAN_MB7_MID         EQU (0xFFFD02E8) ;- (CAN_MB7) MailBox ID Register

+AT91C_CAN_MB7_MMR         EQU (0xFFFD02E0) ;- (CAN_MB7) MailBox Mode Register

+AT91C_CAN_MB7_MAM         EQU (0xFFFD02E4) ;- (CAN_MB7) MailBox Acceptance Mask Register

+AT91C_CAN_MB7_MSR         EQU (0xFFFD02F0) ;- (CAN_MB7) MailBox Status Register

+// - ========== Register definition for CAN peripheral ========== 

+AT91C_CAN_TCR             EQU (0xFFFD0024) ;- (CAN) Transfer Command Register

+AT91C_CAN_IMR             EQU (0xFFFD000C) ;- (CAN) Interrupt Mask Register

+AT91C_CAN_IER             EQU (0xFFFD0004) ;- (CAN) Interrupt Enable Register

+AT91C_CAN_ECR             EQU (0xFFFD0020) ;- (CAN) Error Counter Register

+AT91C_CAN_TIMESTP         EQU (0xFFFD001C) ;- (CAN) Time Stamp Register

+AT91C_CAN_MR              EQU (0xFFFD0000) ;- (CAN) Mode Register

+AT91C_CAN_IDR             EQU (0xFFFD0008) ;- (CAN) Interrupt Disable Register

+AT91C_CAN_ACR             EQU (0xFFFD0028) ;- (CAN) Abort Command Register

+AT91C_CAN_TIM             EQU (0xFFFD0018) ;- (CAN) Timer Register

+AT91C_CAN_SR              EQU (0xFFFD0010) ;- (CAN) Status Register

+AT91C_CAN_BR              EQU (0xFFFD0014) ;- (CAN) Baudrate Register

+AT91C_CAN_VR              EQU (0xFFFD00FC) ;- (CAN) Version Register

+// - ========== Register definition for EMAC peripheral ========== 

+AT91C_EMAC_ISR            EQU (0xFFFDC024) ;- (EMAC) Interrupt Status Register

+AT91C_EMAC_SA4H           EQU (0xFFFDC0B4) ;- (EMAC) Specific Address 4 Top, Last 2 bytes

+AT91C_EMAC_SA1L           EQU (0xFFFDC098) ;- (EMAC) Specific Address 1 Bottom, First 4 bytes

+AT91C_EMAC_ELE            EQU (0xFFFDC078) ;- (EMAC) Excessive Length Errors Register

+AT91C_EMAC_LCOL           EQU (0xFFFDC05C) ;- (EMAC) Late Collision Register

+AT91C_EMAC_RLE            EQU (0xFFFDC088) ;- (EMAC) Receive Length Field Mismatch Register

+AT91C_EMAC_WOL            EQU (0xFFFDC0C4) ;- (EMAC) Wake On LAN Register

+AT91C_EMAC_DTF            EQU (0xFFFDC058) ;- (EMAC) Deferred Transmission Frame Register

+AT91C_EMAC_TUND           EQU (0xFFFDC064) ;- (EMAC) Transmit Underrun Error Register

+AT91C_EMAC_NCR            EQU (0xFFFDC000) ;- (EMAC) Network Control Register

+AT91C_EMAC_SA4L           EQU (0xFFFDC0B0) ;- (EMAC) Specific Address 4 Bottom, First 4 bytes

+AT91C_EMAC_RSR            EQU (0xFFFDC020) ;- (EMAC) Receive Status Register

+AT91C_EMAC_SA3L           EQU (0xFFFDC0A8) ;- (EMAC) Specific Address 3 Bottom, First 4 bytes

+AT91C_EMAC_TSR            EQU (0xFFFDC014) ;- (EMAC) Transmit Status Register

+AT91C_EMAC_IDR            EQU (0xFFFDC02C) ;- (EMAC) Interrupt Disable Register

+AT91C_EMAC_RSE            EQU (0xFFFDC074) ;- (EMAC) Receive Symbol Errors Register

+AT91C_EMAC_ECOL           EQU (0xFFFDC060) ;- (EMAC) Excessive Collision Register

+AT91C_EMAC_TID            EQU (0xFFFDC0B8) ;- (EMAC) Type ID Checking Register

+AT91C_EMAC_HRB            EQU (0xFFFDC090) ;- (EMAC) Hash Address Bottom[31:0]

+AT91C_EMAC_TBQP           EQU (0xFFFDC01C) ;- (EMAC) Transmit Buffer Queue Pointer

+AT91C_EMAC_USRIO          EQU (0xFFFDC0C0) ;- (EMAC) USER Input/Output Register

+AT91C_EMAC_PTR            EQU (0xFFFDC038) ;- (EMAC) Pause Time Register

+AT91C_EMAC_SA2H           EQU (0xFFFDC0A4) ;- (EMAC) Specific Address 2 Top, Last 2 bytes

+AT91C_EMAC_ROV            EQU (0xFFFDC070) ;- (EMAC) Receive Overrun Errors Register

+AT91C_EMAC_ALE            EQU (0xFFFDC054) ;- (EMAC) Alignment Error Register

+AT91C_EMAC_RJA            EQU (0xFFFDC07C) ;- (EMAC) Receive Jabbers Register

+AT91C_EMAC_RBQP           EQU (0xFFFDC018) ;- (EMAC) Receive Buffer Queue Pointer

+AT91C_EMAC_TPF            EQU (0xFFFDC08C) ;- (EMAC) Transmitted Pause Frames Register

+AT91C_EMAC_NCFGR          EQU (0xFFFDC004) ;- (EMAC) Network Configuration Register

+AT91C_EMAC_HRT            EQU (0xFFFDC094) ;- (EMAC) Hash Address Top[63:32]

+AT91C_EMAC_USF            EQU (0xFFFDC080) ;- (EMAC) Undersize Frames Register

+AT91C_EMAC_FCSE           EQU (0xFFFDC050) ;- (EMAC) Frame Check Sequence Error Register

+AT91C_EMAC_TPQ            EQU (0xFFFDC0BC) ;- (EMAC) Transmit Pause Quantum Register

+AT91C_EMAC_MAN            EQU (0xFFFDC034) ;- (EMAC) PHY Maintenance Register

+AT91C_EMAC_FTO            EQU (0xFFFDC040) ;- (EMAC) Frames Transmitted OK Register

+AT91C_EMAC_REV            EQU (0xFFFDC0FC) ;- (EMAC) Revision Register

+AT91C_EMAC_IMR            EQU (0xFFFDC030) ;- (EMAC) Interrupt Mask Register

+AT91C_EMAC_SCF            EQU (0xFFFDC044) ;- (EMAC) Single Collision Frame Register

+AT91C_EMAC_PFR            EQU (0xFFFDC03C) ;- (EMAC) Pause Frames received Register

+AT91C_EMAC_MCF            EQU (0xFFFDC048) ;- (EMAC) Multiple Collision Frame Register

+AT91C_EMAC_NSR            EQU (0xFFFDC008) ;- (EMAC) Network Status Register

+AT91C_EMAC_SA2L           EQU (0xFFFDC0A0) ;- (EMAC) Specific Address 2 Bottom, First 4 bytes

+AT91C_EMAC_FRO            EQU (0xFFFDC04C) ;- (EMAC) Frames Received OK Register

+AT91C_EMAC_IER            EQU (0xFFFDC028) ;- (EMAC) Interrupt Enable Register

+AT91C_EMAC_SA1H           EQU (0xFFFDC09C) ;- (EMAC) Specific Address 1 Top, Last 2 bytes

+AT91C_EMAC_CSE            EQU (0xFFFDC068) ;- (EMAC) Carrier Sense Error Register

+AT91C_EMAC_SA3H           EQU (0xFFFDC0AC) ;- (EMAC) Specific Address 3 Top, Last 2 bytes

+AT91C_EMAC_RRE            EQU (0xFFFDC06C) ;- (EMAC) Receive Ressource Error Register

+AT91C_EMAC_STE            EQU (0xFFFDC084) ;- (EMAC) SQE Test Error Register

+// - ========== Register definition for PDC_ADC peripheral ========== 

+AT91C_ADC_PTSR            EQU (0xFFFD8124) ;- (PDC_ADC) PDC Transfer Status Register

+AT91C_ADC_PTCR            EQU (0xFFFD8120) ;- (PDC_ADC) PDC Transfer Control Register

+AT91C_ADC_TNPR            EQU (0xFFFD8118) ;- (PDC_ADC) Transmit Next Pointer Register

+AT91C_ADC_TNCR            EQU (0xFFFD811C) ;- (PDC_ADC) Transmit Next Counter Register

+AT91C_ADC_RNPR            EQU (0xFFFD8110) ;- (PDC_ADC) Receive Next Pointer Register

+AT91C_ADC_RNCR            EQU (0xFFFD8114) ;- (PDC_ADC) Receive Next Counter Register

+AT91C_ADC_RPR             EQU (0xFFFD8100) ;- (PDC_ADC) Receive Pointer Register

+AT91C_ADC_TCR             EQU (0xFFFD810C) ;- (PDC_ADC) Transmit Counter Register

+AT91C_ADC_TPR             EQU (0xFFFD8108) ;- (PDC_ADC) Transmit Pointer Register

+AT91C_ADC_RCR             EQU (0xFFFD8104) ;- (PDC_ADC) Receive Counter Register

+// - ========== Register definition for ADC peripheral ========== 

+AT91C_ADC_CDR2            EQU (0xFFFD8038) ;- (ADC) ADC Channel Data Register 2

+AT91C_ADC_CDR3            EQU (0xFFFD803C) ;- (ADC) ADC Channel Data Register 3

+AT91C_ADC_CDR0            EQU (0xFFFD8030) ;- (ADC) ADC Channel Data Register 0

+AT91C_ADC_CDR5            EQU (0xFFFD8044) ;- (ADC) ADC Channel Data Register 5

+AT91C_ADC_CHDR            EQU (0xFFFD8014) ;- (ADC) ADC Channel Disable Register

+AT91C_ADC_SR              EQU (0xFFFD801C) ;- (ADC) ADC Status Register

+AT91C_ADC_CDR4            EQU (0xFFFD8040) ;- (ADC) ADC Channel Data Register 4

+AT91C_ADC_CDR1            EQU (0xFFFD8034) ;- (ADC) ADC Channel Data Register 1

+AT91C_ADC_LCDR            EQU (0xFFFD8020) ;- (ADC) ADC Last Converted Data Register

+AT91C_ADC_IDR             EQU (0xFFFD8028) ;- (ADC) ADC Interrupt Disable Register

+AT91C_ADC_CR              EQU (0xFFFD8000) ;- (ADC) ADC Control Register

+AT91C_ADC_CDR7            EQU (0xFFFD804C) ;- (ADC) ADC Channel Data Register 7

+AT91C_ADC_CDR6            EQU (0xFFFD8048) ;- (ADC) ADC Channel Data Register 6

+AT91C_ADC_IER             EQU (0xFFFD8024) ;- (ADC) ADC Interrupt Enable Register

+AT91C_ADC_CHER            EQU (0xFFFD8010) ;- (ADC) ADC Channel Enable Register

+AT91C_ADC_CHSR            EQU (0xFFFD8018) ;- (ADC) ADC Channel Status Register

+AT91C_ADC_MR              EQU (0xFFFD8004) ;- (ADC) ADC Mode Register

+AT91C_ADC_IMR             EQU (0xFFFD802C) ;- (ADC) ADC Interrupt Mask Register

+// - ========== Register definition for PDC_AES peripheral ========== 

+AT91C_AES_TPR             EQU (0xFFFA4108) ;- (PDC_AES) Transmit Pointer Register

+AT91C_AES_PTCR            EQU (0xFFFA4120) ;- (PDC_AES) PDC Transfer Control Register

+AT91C_AES_RNPR            EQU (0xFFFA4110) ;- (PDC_AES) Receive Next Pointer Register

+AT91C_AES_TNCR            EQU (0xFFFA411C) ;- (PDC_AES) Transmit Next Counter Register

+AT91C_AES_TCR             EQU (0xFFFA410C) ;- (PDC_AES) Transmit Counter Register

+AT91C_AES_RCR             EQU (0xFFFA4104) ;- (PDC_AES) Receive Counter Register

+AT91C_AES_RNCR            EQU (0xFFFA4114) ;- (PDC_AES) Receive Next Counter Register

+AT91C_AES_TNPR            EQU (0xFFFA4118) ;- (PDC_AES) Transmit Next Pointer Register

+AT91C_AES_RPR             EQU (0xFFFA4100) ;- (PDC_AES) Receive Pointer Register

+AT91C_AES_PTSR            EQU (0xFFFA4124) ;- (PDC_AES) PDC Transfer Status Register

+// - ========== Register definition for AES peripheral ========== 

+AT91C_AES_IVxR            EQU (0xFFFA4060) ;- (AES) Initialization Vector x Register

+AT91C_AES_MR              EQU (0xFFFA4004) ;- (AES) Mode Register

+AT91C_AES_VR              EQU (0xFFFA40FC) ;- (AES) AES Version Register

+AT91C_AES_ODATAxR         EQU (0xFFFA4050) ;- (AES) Output Data x Register

+AT91C_AES_IDATAxR         EQU (0xFFFA4040) ;- (AES) Input Data x Register

+AT91C_AES_CR              EQU (0xFFFA4000) ;- (AES) Control Register

+AT91C_AES_IDR             EQU (0xFFFA4014) ;- (AES) Interrupt Disable Register

+AT91C_AES_IMR             EQU (0xFFFA4018) ;- (AES) Interrupt Mask Register

+AT91C_AES_IER             EQU (0xFFFA4010) ;- (AES) Interrupt Enable Register

+AT91C_AES_KEYWxR          EQU (0xFFFA4020) ;- (AES) Key Word x Register

+AT91C_AES_ISR             EQU (0xFFFA401C) ;- (AES) Interrupt Status Register

+// - ========== Register definition for PDC_TDES peripheral ========== 

+AT91C_TDES_RNCR           EQU (0xFFFA8114) ;- (PDC_TDES) Receive Next Counter Register

+AT91C_TDES_TCR            EQU (0xFFFA810C) ;- (PDC_TDES) Transmit Counter Register

+AT91C_TDES_RCR            EQU (0xFFFA8104) ;- (PDC_TDES) Receive Counter Register

+AT91C_TDES_TNPR           EQU (0xFFFA8118) ;- (PDC_TDES) Transmit Next Pointer Register

+AT91C_TDES_RNPR           EQU (0xFFFA8110) ;- (PDC_TDES) Receive Next Pointer Register

+AT91C_TDES_RPR            EQU (0xFFFA8100) ;- (PDC_TDES) Receive Pointer Register

+AT91C_TDES_TNCR           EQU (0xFFFA811C) ;- (PDC_TDES) Transmit Next Counter Register

+AT91C_TDES_TPR            EQU (0xFFFA8108) ;- (PDC_TDES) Transmit Pointer Register

+AT91C_TDES_PTSR           EQU (0xFFFA8124) ;- (PDC_TDES) PDC Transfer Status Register

+AT91C_TDES_PTCR           EQU (0xFFFA8120) ;- (PDC_TDES) PDC Transfer Control Register

+// - ========== Register definition for TDES peripheral ========== 

+AT91C_TDES_KEY2WxR        EQU (0xFFFA8028) ;- (TDES) Key 2 Word x Register

+AT91C_TDES_KEY3WxR        EQU (0xFFFA8030) ;- (TDES) Key 3 Word x Register

+AT91C_TDES_IDR            EQU (0xFFFA8014) ;- (TDES) Interrupt Disable Register

+AT91C_TDES_VR             EQU (0xFFFA80FC) ;- (TDES) TDES Version Register

+AT91C_TDES_IVxR           EQU (0xFFFA8060) ;- (TDES) Initialization Vector x Register

+AT91C_TDES_ODATAxR        EQU (0xFFFA8050) ;- (TDES) Output Data x Register

+AT91C_TDES_IMR            EQU (0xFFFA8018) ;- (TDES) Interrupt Mask Register

+AT91C_TDES_MR             EQU (0xFFFA8004) ;- (TDES) Mode Register

+AT91C_TDES_CR             EQU (0xFFFA8000) ;- (TDES) Control Register

+AT91C_TDES_IER            EQU (0xFFFA8010) ;- (TDES) Interrupt Enable Register

+AT91C_TDES_ISR            EQU (0xFFFA801C) ;- (TDES) Interrupt Status Register

+AT91C_TDES_IDATAxR        EQU (0xFFFA8040) ;- (TDES) Input Data x Register

+AT91C_TDES_KEY1WxR        EQU (0xFFFA8020) ;- (TDES) Key 1 Word x Register

+

+// - *****************************************************************************

+// -               PIO DEFINITIONS FOR AT91SAM7X256

+// - *****************************************************************************

+AT91C_PIO_PA0             EQU (1 <<  0) ;- Pin Controlled by PA0

+AT91C_PA0_RXD0            EQU (AT91C_PIO_PA0) ;-  USART 0 Receive Data

+AT91C_PIO_PA1             EQU (1 <<  1) ;- Pin Controlled by PA1

+AT91C_PA1_TXD0            EQU (AT91C_PIO_PA1) ;-  USART 0 Transmit Data

+AT91C_PIO_PA10            EQU (1 << 10) ;- Pin Controlled by PA10

+AT91C_PA10_TWD            EQU (AT91C_PIO_PA10) ;-  TWI Two-wire Serial Data

+AT91C_PIO_PA11            EQU (1 << 11) ;- Pin Controlled by PA11

+AT91C_PA11_TWCK           EQU (AT91C_PIO_PA11) ;-  TWI Two-wire Serial Clock

+AT91C_PIO_PA12            EQU (1 << 12) ;- Pin Controlled by PA12

+AT91C_PA12_NPCS00         EQU (AT91C_PIO_PA12) ;-  SPI 0 Peripheral Chip Select 0

+AT91C_PIO_PA13            EQU (1 << 13) ;- Pin Controlled by PA13

+AT91C_PA13_NPCS01         EQU (AT91C_PIO_PA13) ;-  SPI 0 Peripheral Chip Select 1

+AT91C_PA13_PCK1           EQU (AT91C_PIO_PA13) ;-  PMC Programmable Clock Output 1

+AT91C_PIO_PA14            EQU (1 << 14) ;- Pin Controlled by PA14

+AT91C_PA14_NPCS02         EQU (AT91C_PIO_PA14) ;-  SPI 0 Peripheral Chip Select 2

+AT91C_PA14_IRQ1           EQU (AT91C_PIO_PA14) ;-  External Interrupt 1

+AT91C_PIO_PA15            EQU (1 << 15) ;- Pin Controlled by PA15

+AT91C_PA15_NPCS03         EQU (AT91C_PIO_PA15) ;-  SPI 0 Peripheral Chip Select 3

+AT91C_PA15_TCLK2          EQU (AT91C_PIO_PA15) ;-  Timer Counter 2 external clock input

+AT91C_PIO_PA16            EQU (1 << 16) ;- Pin Controlled by PA16

+AT91C_PA16_MISO0          EQU (AT91C_PIO_PA16) ;-  SPI 0 Master In Slave

+AT91C_PIO_PA17            EQU (1 << 17) ;- Pin Controlled by PA17

+AT91C_PA17_MOSI0          EQU (AT91C_PIO_PA17) ;-  SPI 0 Master Out Slave

+AT91C_PIO_PA18            EQU (1 << 18) ;- Pin Controlled by PA18

+AT91C_PA18_SPCK0          EQU (AT91C_PIO_PA18) ;-  SPI 0 Serial Clock

+AT91C_PIO_PA19            EQU (1 << 19) ;- Pin Controlled by PA19

+AT91C_PA19_CANRX          EQU (AT91C_PIO_PA19) ;-  CAN Receive

+AT91C_PIO_PA2             EQU (1 <<  2) ;- Pin Controlled by PA2

+AT91C_PA2_SCK0            EQU (AT91C_PIO_PA2) ;-  USART 0 Serial Clock

+AT91C_PA2_NPCS11          EQU (AT91C_PIO_PA2) ;-  SPI 1 Peripheral Chip Select 1

+AT91C_PIO_PA20            EQU (1 << 20) ;- Pin Controlled by PA20

+AT91C_PA20_CANTX          EQU (AT91C_PIO_PA20) ;-  CAN Transmit

+AT91C_PIO_PA21            EQU (1 << 21) ;- Pin Controlled by PA21

+AT91C_PA21_TF             EQU (AT91C_PIO_PA21) ;-  SSC Transmit Frame Sync

+AT91C_PA21_NPCS10         EQU (AT91C_PIO_PA21) ;-  SPI 1 Peripheral Chip Select 0

+AT91C_PIO_PA22            EQU (1 << 22) ;- Pin Controlled by PA22

+AT91C_PA22_TK             EQU (AT91C_PIO_PA22) ;-  SSC Transmit Clock

+AT91C_PA22_SPCK1          EQU (AT91C_PIO_PA22) ;-  SPI 1 Serial Clock

+AT91C_PIO_PA23            EQU (1 << 23) ;- Pin Controlled by PA23

+AT91C_PA23_TD             EQU (AT91C_PIO_PA23) ;-  SSC Transmit data

+AT91C_PA23_MOSI1          EQU (AT91C_PIO_PA23) ;-  SPI 1 Master Out Slave

+AT91C_PIO_PA24            EQU (1 << 24) ;- Pin Controlled by PA24

+AT91C_PA24_RD             EQU (AT91C_PIO_PA24) ;-  SSC Receive Data

+AT91C_PA24_MISO1          EQU (AT91C_PIO_PA24) ;-  SPI 1 Master In Slave

+AT91C_PIO_PA25            EQU (1 << 25) ;- Pin Controlled by PA25

+AT91C_PA25_RK             EQU (AT91C_PIO_PA25) ;-  SSC Receive Clock

+AT91C_PA25_NPCS11         EQU (AT91C_PIO_PA25) ;-  SPI 1 Peripheral Chip Select 1

+AT91C_PIO_PA26            EQU (1 << 26) ;- Pin Controlled by PA26

+AT91C_PA26_RF             EQU (AT91C_PIO_PA26) ;-  SSC Receive Frame Sync

+AT91C_PA26_NPCS12         EQU (AT91C_PIO_PA26) ;-  SPI 1 Peripheral Chip Select 2

+AT91C_PIO_PA27            EQU (1 << 27) ;- Pin Controlled by PA27

+AT91C_PA27_DRXD           EQU (AT91C_PIO_PA27) ;-  DBGU Debug Receive Data

+AT91C_PA27_PCK3           EQU (AT91C_PIO_PA27) ;-  PMC Programmable Clock Output 3

+AT91C_PIO_PA28            EQU (1 << 28) ;- Pin Controlled by PA28

+AT91C_PA28_DTXD           EQU (AT91C_PIO_PA28) ;-  DBGU Debug Transmit Data

+AT91C_PIO_PA29            EQU (1 << 29) ;- Pin Controlled by PA29

+AT91C_PA29_FIQ            EQU (AT91C_PIO_PA29) ;-  AIC Fast Interrupt Input

+AT91C_PA29_NPCS13         EQU (AT91C_PIO_PA29) ;-  SPI 1 Peripheral Chip Select 3

+AT91C_PIO_PA3             EQU (1 <<  3) ;- Pin Controlled by PA3

+AT91C_PA3_RTS0            EQU (AT91C_PIO_PA3) ;-  USART 0 Ready To Send

+AT91C_PA3_NPCS12          EQU (AT91C_PIO_PA3) ;-  SPI 1 Peripheral Chip Select 2

+AT91C_PIO_PA30            EQU (1 << 30) ;- Pin Controlled by PA30

+AT91C_PA30_IRQ0           EQU (AT91C_PIO_PA30) ;-  External Interrupt 0

+AT91C_PA30_PCK2           EQU (AT91C_PIO_PA30) ;-  PMC Programmable Clock Output 2

+AT91C_PIO_PA4             EQU (1 <<  4) ;- Pin Controlled by PA4

+AT91C_PA4_CTS0            EQU (AT91C_PIO_PA4) ;-  USART 0 Clear To Send

+AT91C_PA4_NPCS13          EQU (AT91C_PIO_PA4) ;-  SPI 1 Peripheral Chip Select 3

+AT91C_PIO_PA5             EQU (1 <<  5) ;- Pin Controlled by PA5

+AT91C_PA5_RXD1            EQU (AT91C_PIO_PA5) ;-  USART 1 Receive Data

+AT91C_PIO_PA6             EQU (1 <<  6) ;- Pin Controlled by PA6

+AT91C_PA6_TXD1            EQU (AT91C_PIO_PA6) ;-  USART 1 Transmit Data

+AT91C_PIO_PA7             EQU (1 <<  7) ;- Pin Controlled by PA7

+AT91C_PA7_SCK1            EQU (AT91C_PIO_PA7) ;-  USART 1 Serial Clock

+AT91C_PA7_NPCS01          EQU (AT91C_PIO_PA7) ;-  SPI 0 Peripheral Chip Select 1

+AT91C_PIO_PA8             EQU (1 <<  8) ;- Pin Controlled by PA8

+AT91C_PA8_RTS1            EQU (AT91C_PIO_PA8) ;-  USART 1 Ready To Send

+AT91C_PA8_NPCS02          EQU (AT91C_PIO_PA8) ;-  SPI 0 Peripheral Chip Select 2

+AT91C_PIO_PA9             EQU (1 <<  9) ;- Pin Controlled by PA9

+AT91C_PA9_CTS1            EQU (AT91C_PIO_PA9) ;-  USART 1 Clear To Send

+AT91C_PA9_NPCS03          EQU (AT91C_PIO_PA9) ;-  SPI 0 Peripheral Chip Select 3

+AT91C_PIO_PB0             EQU (1 <<  0) ;- Pin Controlled by PB0

+AT91C_PB0_ETXCK_EREFCK    EQU (AT91C_PIO_PB0) ;-  Ethernet MAC Transmit Clock/Reference Clock

+AT91C_PB0_PCK0            EQU (AT91C_PIO_PB0) ;-  PMC Programmable Clock Output 0

+AT91C_PIO_PB1             EQU (1 <<  1) ;- Pin Controlled by PB1

+AT91C_PB1_ETXEN           EQU (AT91C_PIO_PB1) ;-  Ethernet MAC Transmit Enable

+AT91C_PIO_PB10            EQU (1 << 10) ;- Pin Controlled by PB10

+AT91C_PB10_ETX2           EQU (AT91C_PIO_PB10) ;-  Ethernet MAC Transmit Data 2

+AT91C_PB10_NPCS11         EQU (AT91C_PIO_PB10) ;-  SPI 1 Peripheral Chip Select 1

+AT91C_PIO_PB11            EQU (1 << 11) ;- Pin Controlled by PB11

+AT91C_PB11_ETX3           EQU (AT91C_PIO_PB11) ;-  Ethernet MAC Transmit Data 3

+AT91C_PB11_NPCS12         EQU (AT91C_PIO_PB11) ;-  SPI 1 Peripheral Chip Select 2

+AT91C_PIO_PB12            EQU (1 << 12) ;- Pin Controlled by PB12

+AT91C_PB12_ETXER          EQU (AT91C_PIO_PB12) ;-  Ethernet MAC Transmikt Coding Error

+AT91C_PB12_TCLK0          EQU (AT91C_PIO_PB12) ;-  Timer Counter 0 external clock input

+AT91C_PIO_PB13            EQU (1 << 13) ;- Pin Controlled by PB13

+AT91C_PB13_ERX2           EQU (AT91C_PIO_PB13) ;-  Ethernet MAC Receive Data 2

+AT91C_PB13_NPCS01         EQU (AT91C_PIO_PB13) ;-  SPI 0 Peripheral Chip Select 1

+AT91C_PIO_PB14            EQU (1 << 14) ;- Pin Controlled by PB14

+AT91C_PB14_ERX3           EQU (AT91C_PIO_PB14) ;-  Ethernet MAC Receive Data 3

+AT91C_PB14_NPCS02         EQU (AT91C_PIO_PB14) ;-  SPI 0 Peripheral Chip Select 2

+AT91C_PIO_PB15            EQU (1 << 15) ;- Pin Controlled by PB15

+AT91C_PB15_ERXDV          EQU (AT91C_PIO_PB15) ;-  Ethernet MAC Receive Data Valid

+AT91C_PIO_PB16            EQU (1 << 16) ;- Pin Controlled by PB16

+AT91C_PB16_ECOL           EQU (AT91C_PIO_PB16) ;-  Ethernet MAC Collision Detected

+AT91C_PB16_NPCS13         EQU (AT91C_PIO_PB16) ;-  SPI 1 Peripheral Chip Select 3

+AT91C_PIO_PB17            EQU (1 << 17) ;- Pin Controlled by PB17

+AT91C_PB17_ERXCK          EQU (AT91C_PIO_PB17) ;-  Ethernet MAC Receive Clock

+AT91C_PB17_NPCS03         EQU (AT91C_PIO_PB17) ;-  SPI 0 Peripheral Chip Select 3

+AT91C_PIO_PB18            EQU (1 << 18) ;- Pin Controlled by PB18

+AT91C_PB18_EF100          EQU (AT91C_PIO_PB18) ;-  Ethernet MAC Force 100 Mbits/sec

+AT91C_PB18_ADTRG          EQU (AT91C_PIO_PB18) ;-  ADC External Trigger

+AT91C_PIO_PB19            EQU (1 << 19) ;- Pin Controlled by PB19

+AT91C_PB19_PWM0           EQU (AT91C_PIO_PB19) ;-  PWM Channel 0

+AT91C_PB19_TCLK1          EQU (AT91C_PIO_PB19) ;-  Timer Counter 1 external clock input

+AT91C_PIO_PB2             EQU (1 <<  2) ;- Pin Controlled by PB2

+AT91C_PB2_ETX0            EQU (AT91C_PIO_PB2) ;-  Ethernet MAC Transmit Data 0

+AT91C_PIO_PB20            EQU (1 << 20) ;- Pin Controlled by PB20

+AT91C_PB20_PWM1           EQU (AT91C_PIO_PB20) ;-  PWM Channel 1

+AT91C_PB20_PCK0           EQU (AT91C_PIO_PB20) ;-  PMC Programmable Clock Output 0

+AT91C_PIO_PB21            EQU (1 << 21) ;- Pin Controlled by PB21

+AT91C_PB21_PWM2           EQU (AT91C_PIO_PB21) ;-  PWM Channel 2

+AT91C_PB21_PCK1           EQU (AT91C_PIO_PB21) ;-  PMC Programmable Clock Output 1

+AT91C_PIO_PB22            EQU (1 << 22) ;- Pin Controlled by PB22

+AT91C_PB22_PWM3           EQU (AT91C_PIO_PB22) ;-  PWM Channel 3

+AT91C_PB22_PCK2           EQU (AT91C_PIO_PB22) ;-  PMC Programmable Clock Output 2

+AT91C_PIO_PB23            EQU (1 << 23) ;- Pin Controlled by PB23

+AT91C_PB23_TIOA0          EQU (AT91C_PIO_PB23) ;-  Timer Counter 0 Multipurpose Timer I/O Pin A

+AT91C_PB23_DCD1           EQU (AT91C_PIO_PB23) ;-  USART 1 Data Carrier Detect

+AT91C_PIO_PB24            EQU (1 << 24) ;- Pin Controlled by PB24

+AT91C_PB24_TIOB0          EQU (AT91C_PIO_PB24) ;-  Timer Counter 0 Multipurpose Timer I/O Pin B

+AT91C_PB24_DSR1           EQU (AT91C_PIO_PB24) ;-  USART 1 Data Set ready

+AT91C_PIO_PB25            EQU (1 << 25) ;- Pin Controlled by PB25

+AT91C_PB25_TIOA1          EQU (AT91C_PIO_PB25) ;-  Timer Counter 1 Multipurpose Timer I/O Pin A

+AT91C_PB25_DTR1           EQU (AT91C_PIO_PB25) ;-  USART 1 Data Terminal ready

+AT91C_PIO_PB26            EQU (1 << 26) ;- Pin Controlled by PB26

+AT91C_PB26_TIOB1          EQU (AT91C_PIO_PB26) ;-  Timer Counter 1 Multipurpose Timer I/O Pin B

+AT91C_PB26_RI1            EQU (AT91C_PIO_PB26) ;-  USART 1 Ring Indicator

+AT91C_PIO_PB27            EQU (1 << 27) ;- Pin Controlled by PB27

+AT91C_PB27_TIOA2          EQU (AT91C_PIO_PB27) ;-  Timer Counter 2 Multipurpose Timer I/O Pin A

+AT91C_PB27_PWM0           EQU (AT91C_PIO_PB27) ;-  PWM Channel 0

+AT91C_PIO_PB28            EQU (1 << 28) ;- Pin Controlled by PB28

+AT91C_PB28_TIOB2          EQU (AT91C_PIO_PB28) ;-  Timer Counter 2 Multipurpose Timer I/O Pin B

+AT91C_PB28_PWM1           EQU (AT91C_PIO_PB28) ;-  PWM Channel 1

+AT91C_PIO_PB29            EQU (1 << 29) ;- Pin Controlled by PB29

+AT91C_PB29_PCK1           EQU (AT91C_PIO_PB29) ;-  PMC Programmable Clock Output 1

+AT91C_PB29_PWM2           EQU (AT91C_PIO_PB29) ;-  PWM Channel 2

+AT91C_PIO_PB3             EQU (1 <<  3) ;- Pin Controlled by PB3

+AT91C_PB3_ETX1            EQU (AT91C_PIO_PB3) ;-  Ethernet MAC Transmit Data 1

+AT91C_PIO_PB30            EQU (1 << 30) ;- Pin Controlled by PB30

+AT91C_PB30_PCK2           EQU (AT91C_PIO_PB30) ;-  PMC Programmable Clock Output 2

+AT91C_PB30_PWM3           EQU (AT91C_PIO_PB30) ;-  PWM Channel 3

+AT91C_PIO_PB4             EQU (1 <<  4) ;- Pin Controlled by PB4

+AT91C_PB4_ECRS_ECRSDV     EQU (AT91C_PIO_PB4) ;-  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+AT91C_PIO_PB5             EQU (1 <<  5) ;- Pin Controlled by PB5

+AT91C_PB5_ERX0            EQU (AT91C_PIO_PB5) ;-  Ethernet MAC Receive Data 0

+AT91C_PIO_PB6             EQU (1 <<  6) ;- Pin Controlled by PB6

+AT91C_PB6_ERX1            EQU (AT91C_PIO_PB6) ;-  Ethernet MAC Receive Data 1

+AT91C_PIO_PB7             EQU (1 <<  7) ;- Pin Controlled by PB7

+AT91C_PB7_ERXER           EQU (AT91C_PIO_PB7) ;-  Ethernet MAC Receive Error

+AT91C_PIO_PB8             EQU (1 <<  8) ;- Pin Controlled by PB8

+AT91C_PB8_EMDC            EQU (AT91C_PIO_PB8) ;-  Ethernet MAC Management Data Clock

+AT91C_PIO_PB9             EQU (1 <<  9) ;- Pin Controlled by PB9

+AT91C_PB9_EMDIO           EQU (AT91C_PIO_PB9) ;-  Ethernet MAC Management Data Input/Output

+

+// - *****************************************************************************

+// -               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X256

+// - *****************************************************************************

+AT91C_ID_FIQ              EQU ( 0) ;- Advanced Interrupt Controller (FIQ)

+AT91C_ID_SYS              EQU ( 1) ;- System Peripheral

+AT91C_ID_PIOA             EQU ( 2) ;- Parallel IO Controller A

+AT91C_ID_PIOB             EQU ( 3) ;- Parallel IO Controller B

+AT91C_ID_SPI0             EQU ( 4) ;- Serial Peripheral Interface 0

+AT91C_ID_SPI1             EQU ( 5) ;- Serial Peripheral Interface 1

+AT91C_ID_US0              EQU ( 6) ;- USART 0

+AT91C_ID_US1              EQU ( 7) ;- USART 1

+AT91C_ID_SSC              EQU ( 8) ;- Serial Synchronous Controller

+AT91C_ID_TWI              EQU ( 9) ;- Two-Wire Interface

+AT91C_ID_PWMC             EQU (10) ;- PWM Controller

+AT91C_ID_UDP              EQU (11) ;- USB Device Port

+AT91C_ID_TC0              EQU (12) ;- Timer Counter 0

+AT91C_ID_TC1              EQU (13) ;- Timer Counter 1

+AT91C_ID_TC2              EQU (14) ;- Timer Counter 2

+AT91C_ID_CAN              EQU (15) ;- Control Area Network Controller

+AT91C_ID_EMAC             EQU (16) ;- Ethernet MAC

+AT91C_ID_ADC              EQU (17) ;- Analog-to-Digital Converter

+AT91C_ID_AES              EQU (18) ;- Advanced Encryption Standard 128-bit

+AT91C_ID_TDES             EQU (19) ;- Triple Data Encryption Standard

+AT91C_ID_20_Reserved      EQU (20) ;- Reserved

+AT91C_ID_21_Reserved      EQU (21) ;- Reserved

+AT91C_ID_22_Reserved      EQU (22) ;- Reserved

+AT91C_ID_23_Reserved      EQU (23) ;- Reserved

+AT91C_ID_24_Reserved      EQU (24) ;- Reserved

+AT91C_ID_25_Reserved      EQU (25) ;- Reserved

+AT91C_ID_26_Reserved      EQU (26) ;- Reserved

+AT91C_ID_27_Reserved      EQU (27) ;- Reserved

+AT91C_ID_28_Reserved      EQU (28) ;- Reserved

+AT91C_ID_29_Reserved      EQU (29) ;- Reserved

+AT91C_ID_IRQ0             EQU (30) ;- Advanced Interrupt Controller (IRQ0)

+AT91C_ID_IRQ1             EQU (31) ;- Advanced Interrupt Controller (IRQ1)

+

+// - *****************************************************************************

+// -               BASE ADDRESS DEFINITIONS FOR AT91SAM7X256

+// - *****************************************************************************

+AT91C_BASE_SYS            EQU (0xFFFFF000) ;- (SYS) Base Address

+AT91C_BASE_AIC            EQU (0xFFFFF000) ;- (AIC) Base Address

+AT91C_BASE_PDC_DBGU       EQU (0xFFFFF300) ;- (PDC_DBGU) Base Address

+AT91C_BASE_DBGU           EQU (0xFFFFF200) ;- (DBGU) Base Address

+AT91C_BASE_PIOA           EQU (0xFFFFF400) ;- (PIOA) Base Address

+AT91C_BASE_PIOB           EQU (0xFFFFF600) ;- (PIOB) Base Address

+AT91C_BASE_CKGR           EQU (0xFFFFFC20) ;- (CKGR) Base Address

+AT91C_BASE_PMC            EQU (0xFFFFFC00) ;- (PMC) Base Address

+AT91C_BASE_RSTC           EQU (0xFFFFFD00) ;- (RSTC) Base Address

+AT91C_BASE_RTTC           EQU (0xFFFFFD20) ;- (RTTC) Base Address

+AT91C_BASE_PITC           EQU (0xFFFFFD30) ;- (PITC) Base Address

+AT91C_BASE_WDTC           EQU (0xFFFFFD40) ;- (WDTC) Base Address

+AT91C_BASE_VREG           EQU (0xFFFFFD60) ;- (VREG) Base Address

+AT91C_BASE_MC             EQU (0xFFFFFF00) ;- (MC) Base Address

+AT91C_BASE_PDC_SPI1       EQU (0xFFFE4100) ;- (PDC_SPI1) Base Address

+AT91C_BASE_SPI1           EQU (0xFFFE4000) ;- (SPI1) Base Address

+AT91C_BASE_PDC_SPI0       EQU (0xFFFE0100) ;- (PDC_SPI0) Base Address

+AT91C_BASE_SPI0           EQU (0xFFFE0000) ;- (SPI0) Base Address

+AT91C_BASE_PDC_US1        EQU (0xFFFC4100) ;- (PDC_US1) Base Address

+AT91C_BASE_US1            EQU (0xFFFC4000) ;- (US1) Base Address

+AT91C_BASE_PDC_US0        EQU (0xFFFC0100) ;- (PDC_US0) Base Address

+AT91C_BASE_US0            EQU (0xFFFC0000) ;- (US0) Base Address

+AT91C_BASE_PDC_SSC        EQU (0xFFFD4100) ;- (PDC_SSC) Base Address

+AT91C_BASE_SSC            EQU (0xFFFD4000) ;- (SSC) Base Address

+AT91C_BASE_TWI            EQU (0xFFFB8000) ;- (TWI) Base Address

+AT91C_BASE_PWMC_CH3       EQU (0xFFFCC260) ;- (PWMC_CH3) Base Address

+AT91C_BASE_PWMC_CH2       EQU (0xFFFCC240) ;- (PWMC_CH2) Base Address

+AT91C_BASE_PWMC_CH1       EQU (0xFFFCC220) ;- (PWMC_CH1) Base Address

+AT91C_BASE_PWMC_CH0       EQU (0xFFFCC200) ;- (PWMC_CH0) Base Address

+AT91C_BASE_PWMC           EQU (0xFFFCC000) ;- (PWMC) Base Address

+AT91C_BASE_UDP            EQU (0xFFFB0000) ;- (UDP) Base Address

+AT91C_BASE_TC0            EQU (0xFFFA0000) ;- (TC0) Base Address

+AT91C_BASE_TC1            EQU (0xFFFA0040) ;- (TC1) Base Address

+AT91C_BASE_TC2            EQU (0xFFFA0080) ;- (TC2) Base Address

+AT91C_BASE_TCB            EQU (0xFFFA0000) ;- (TCB) Base Address

+AT91C_BASE_CAN_MB0        EQU (0xFFFD0200) ;- (CAN_MB0) Base Address

+AT91C_BASE_CAN_MB1        EQU (0xFFFD0220) ;- (CAN_MB1) Base Address

+AT91C_BASE_CAN_MB2        EQU (0xFFFD0240) ;- (CAN_MB2) Base Address

+AT91C_BASE_CAN_MB3        EQU (0xFFFD0260) ;- (CAN_MB3) Base Address

+AT91C_BASE_CAN_MB4        EQU (0xFFFD0280) ;- (CAN_MB4) Base Address

+AT91C_BASE_CAN_MB5        EQU (0xFFFD02A0) ;- (CAN_MB5) Base Address

+AT91C_BASE_CAN_MB6        EQU (0xFFFD02C0) ;- (CAN_MB6) Base Address

+AT91C_BASE_CAN_MB7        EQU (0xFFFD02E0) ;- (CAN_MB7) Base Address

+AT91C_BASE_CAN            EQU (0xFFFD0000) ;- (CAN) Base Address

+AT91C_BASE_EMAC           EQU (0xFFFDC000) ;- (EMAC) Base Address

+AT91C_BASE_PDC_ADC        EQU (0xFFFD8100) ;- (PDC_ADC) Base Address

+AT91C_BASE_ADC            EQU (0xFFFD8000) ;- (ADC) Base Address

+AT91C_BASE_PDC_AES        EQU (0xFFFA4100) ;- (PDC_AES) Base Address

+AT91C_BASE_AES            EQU (0xFFFA4000) ;- (AES) Base Address

+AT91C_BASE_PDC_TDES       EQU (0xFFFA8100) ;- (PDC_TDES) Base Address

+AT91C_BASE_TDES           EQU (0xFFFA8000) ;- (TDES) Base Address

+

+// - *****************************************************************************

+// -               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X256

+// - *****************************************************************************

+AT91C_ISRAM               EQU (0x00200000) ;- Internal SRAM base address

+AT91C_ISRAM_SIZE          EQU (0x00010000) ;- Internal SRAM size in byte (64 Kbyte)

+AT91C_IFLASH              EQU (0x00100000) ;- Internal ROM base address

+AT91C_IFLASH_SIZE         EQU (0x00040000) ;- Internal ROM size in byte (256 Kbyte)

+

+

+

+#endif /* AT91SAM7X256_H */

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.c b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.c
new file mode 100644
index 0000000..9cbd823
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.c
@@ -0,0 +1,51 @@
+//* ----------------------------------------------------------------------------

+//*         ATMEL Microcontroller Software Support  -  ROUSSET  -

+//* ----------------------------------------------------------------------------

+//* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//* ----------------------------------------------------------------------------

+//* File Name           : lib_AT91SAM7X256.h

+//* Object              : AT91SAM7X256 inlined functions

+//* Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+//*

+//* CVS Reference       : /lib_dbgu.h/1.1/Fri Jan 31 12:18:40 2003//

+//* CVS Reference       : /lib_pmc_SAM7X.h/1.1/Tue Feb  1 08:32:10 2005//

+//* CVS Reference       : /lib_VREG_6085B.h/1.1/Tue Feb  1 16:20:47 2005//

+//* CVS Reference       : /lib_rstc_6098A.h/1.1/Wed Oct  6 10:39:20 2004//

+//* CVS Reference       : /lib_ssc.h/1.4/Fri Jan 31 12:19:20 2003//

+//* CVS Reference       : /lib_wdtc_6080A.h/1.1/Wed Oct  6 10:38:30 2004//

+//* CVS Reference       : /lib_usart.h/1.5/Thu Nov 21 16:01:54 2002//

+//* CVS Reference       : /lib_spi2.h/1.1/Mon Aug 25 14:23:52 2003//

+//* CVS Reference       : /lib_pitc_6079A.h/1.2/Tue Nov  9 14:43:56 2004//

+//* CVS Reference       : /lib_aic_6075b.h/1.1/Fri May 20 14:01:19 2005//

+//* CVS Reference       : /lib_aes_6149a.h/1.1/Mon Jan 17 07:43:09 2005//

+//* CVS Reference       : /lib_twi.h/1.3/Mon Jul 19 14:27:58 2004//

+//* CVS Reference       : /lib_adc.h/1.6/Fri Oct 17 09:12:38 2003//

+//* CVS Reference       : /lib_rttc_6081A.h/1.1/Wed Oct  6 10:39:38 2004//

+//* CVS Reference       : /lib_udp.h/1.4/Wed Feb 16 08:39:34 2005//

+//* CVS Reference       : /lib_des3_6150a.h/1.1/Mon Jan 17 09:19:19 2005//

+//* CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+//* CVS Reference       : /lib_MC_SAM7X.h/1.1/Thu Mar 25 15:19:14 2004//

+//* CVS Reference       : /lib_pio.h/1.3/Fri Jan 31 12:18:56 2003//

+//* CVS Reference       : /lib_can_AT91.h/1.4/Fri Oct 17 09:12:50 2003//

+//* CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+//* CVS Reference       : /lib_pdc.h/1.2/Tue Jul  2 13:29:40 2002//

+//* ----------------------------------------------------------------------------

+

+

+#include "AT91SAM7X256.h"

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ConfigureIt

+//* \brief Interrupt Handler Initialization

+//*----------------------------------------------------------------------------

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.h b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.h
new file mode 100644
index 0000000..e66b4e1
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/lib_AT91SAM7X256.h
@@ -0,0 +1,4558 @@
+//* ----------------------------------------------------------------------------

+//*         ATMEL Microcontroller Software Support  -  ROUSSET  -

+//* ----------------------------------------------------------------------------

+//* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//* ----------------------------------------------------------------------------

+//* File Name           : lib_AT91SAM7X256.h

+//* Object              : AT91SAM7X256 inlined functions

+//* Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+//*

+//* CVS Reference       : /lib_dbgu.h/1.1/Fri Jan 31 12:18:40 2003//

+//* CVS Reference       : /lib_pmc_SAM7X.h/1.1/Tue Feb  1 08:32:10 2005//

+//* CVS Reference       : /lib_VREG_6085B.h/1.1/Tue Feb  1 16:20:47 2005//

+//* CVS Reference       : /lib_rstc_6098A.h/1.1/Wed Oct  6 10:39:20 2004//

+//* CVS Reference       : /lib_ssc.h/1.4/Fri Jan 31 12:19:20 2003//

+//* CVS Reference       : /lib_wdtc_6080A.h/1.1/Wed Oct  6 10:38:30 2004//

+//* CVS Reference       : /lib_usart.h/1.5/Thu Nov 21 16:01:54 2002//

+//* CVS Reference       : /lib_spi2.h/1.1/Mon Aug 25 14:23:52 2003//

+//* CVS Reference       : /lib_pitc_6079A.h/1.2/Tue Nov  9 14:43:56 2004//

+//* CVS Reference       : /lib_aic_6075b.h/1.1/Fri May 20 14:01:19 2005//

+//* CVS Reference       : /lib_aes_6149a.h/1.1/Mon Jan 17 07:43:09 2005//

+//* CVS Reference       : /lib_twi.h/1.3/Mon Jul 19 14:27:58 2004//

+//* CVS Reference       : /lib_adc.h/1.6/Fri Oct 17 09:12:38 2003//

+//* CVS Reference       : /lib_rttc_6081A.h/1.1/Wed Oct  6 10:39:38 2004//

+//* CVS Reference       : /lib_udp.h/1.4/Wed Feb 16 08:39:34 2005//

+//* CVS Reference       : /lib_des3_6150a.h/1.1/Mon Jan 17 09:19:19 2005//

+//* CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+//* CVS Reference       : /lib_MC_SAM7X.h/1.1/Thu Mar 25 15:19:14 2004//

+//* CVS Reference       : /lib_pio.h/1.3/Fri Jan 31 12:18:56 2003//

+//* CVS Reference       : /lib_can_AT91.h/1.4/Fri Oct 17 09:12:50 2003//

+//* CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+//* CVS Reference       : /lib_pdc.h/1.2/Tue Jul  2 13:29:40 2002//

+//* ----------------------------------------------------------------------------

+

+#ifndef lib_AT91SAM7X256_H

+#define lib_AT91SAM7X256_H

+

+/* *****************************************************************************

+                SOFTWARE API FOR AIC

+   ***************************************************************************** */

+#define AT91C_AIC_BRANCH_OPCODE ((void (*) ()) 0xE51FFF20) // ldr, pc, [pc, #-&F20]

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ConfigureIt

+//* \brief Interrupt Handler Initialization

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AIC_ConfigureIt (

+	AT91PS_AIC pAic,  // \arg pointer to the AIC registers

+	unsigned int irq_id,     // \arg interrupt number to initialize

+	unsigned int priority,   // \arg priority to give to the interrupt

+	unsigned int src_type,   // \arg activation and sense of activation

+	void (*newHandler) (void) ) // \arg address of the interrupt handler

+{

+	unsigned int oldHandler;

+    unsigned int mask ;

+

+    oldHandler = pAic->AIC_SVR[irq_id];

+

+    mask = 0x1 << irq_id ;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Save the interrupt handler routine pointer and the interrupt priority

+    pAic->AIC_SVR[irq_id] = (unsigned int) newHandler ;

+    //* Store the Source Mode Register

+    pAic->AIC_SMR[irq_id] = src_type | priority  ;

+    //* Clear the interrupt on the interrupt controller

+    pAic->AIC_ICCR = mask ;

+

+	return oldHandler;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_EnableIt

+//* \brief Enable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_EnableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    //* Enable the interrupt on the interrupt controller

+    pAic->AIC_IECR = 0x1 << irq_id ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_DisableIt

+//* \brief Disable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_DisableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    unsigned int mask = 0x1 << irq_id;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = mask ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ClearIt

+//* \brief Clear corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_ClearIt (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number to initialize

+{

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = (0x1 << irq_id);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_AcknowledgeIt

+//* \brief Acknowledge corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_AcknowledgeIt (

+	AT91PS_AIC pAic)     // \arg pointer to the AIC registers

+{

+    pAic->AIC_EOICR = pAic->AIC_EOICR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_SetExceptionVector

+//* \brief Configure vector handler

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_SetExceptionVector (

+	unsigned int *pVector, // \arg pointer to the AIC registers

+	void (*Handler) () )   // \arg Interrupt Handler

+{

+	unsigned int oldVector = *pVector;

+

+	if ((unsigned int) Handler == (unsigned int) AT91C_AIC_BRANCH_OPCODE)

+		*pVector = (unsigned int) AT91C_AIC_BRANCH_OPCODE;

+	else

+		*pVector = (((((unsigned int) Handler) - ((unsigned int) pVector) - 0x8) >> 2) & 0x00FFFFFF) | 0xEA000000;

+

+	return oldVector;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Trig

+//* \brief Trig an IT

+//*----------------------------------------------------------------------------

+__inline void  AT91F_AIC_Trig (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number

+{

+	pAic->AIC_ISCR = (0x1 << irq_id) ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsActive

+//* \brief Test if an IT is active

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsActive (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_ISR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsPending

+//* \brief Test if an IT is pending

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsPending (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_IPR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Open

+//* \brief Set exception vectors and AIC registers to default values

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_Open(

+	AT91PS_AIC pAic,        // \arg pointer to the AIC registers

+	void (*IrqHandler) (),  // \arg Default IRQ vector exception

+	void (*FiqHandler) (),  // \arg Default FIQ vector exception

+	void (*DefaultHandler)  (), // \arg Default Handler set in ISR

+	void (*SpuriousHandler) (), // \arg Default Spurious Handler

+	unsigned int protectMode)   // \arg Debug Control Register

+{

+	int i;

+

+	// Disable all interrupts and set IVR to the default handler

+	for (i = 0; i < 32; ++i) {

+		AT91F_AIC_DisableIt(pAic, i);

+		AT91F_AIC_ConfigureIt(pAic, i, AT91C_AIC_PRIOR_LOWEST, AT91C_AIC_SRCTYPE_HIGH_LEVEL, DefaultHandler);

+	}

+

+	// Set the IRQ exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x18, IrqHandler);

+	// Set the Fast Interrupt exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x1C, FiqHandler);

+

+	pAic->AIC_SPU = (unsigned int) SpuriousHandler;

+	pAic->AIC_DCR = protectMode;

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PDC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextRx

+//* \brief Set the next receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextRx (

+	AT91PS_PDC pPDC,     // \arg pointer to a PDC controller

+	char *address,       // \arg address to the next bloc to be received

+	unsigned int bytes)  // \arg number of bytes to be received

+{

+	pPDC->PDC_RNPR = (unsigned int) address;

+	pPDC->PDC_RNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextTx

+//* \brief Set the next transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TNPR = (unsigned int) address;

+	pPDC->PDC_TNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetRx

+//* \brief Set the receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetRx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be received

+	unsigned int bytes)    // \arg number of bytes to be received

+{

+	pPDC->PDC_RPR = (unsigned int) address;

+	pPDC->PDC_RCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetTx

+//* \brief Set the transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TPR = (unsigned int) address;

+	pPDC->PDC_TCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableTx

+//* \brief Enable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableRx

+//* \brief Enable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableTx

+//* \brief Disable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableRx

+//* \brief Disable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsTxEmpty

+//* \brief Test if the current transfer descriptor has been sent

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextTxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsRxEmpty

+//* \brief Test if the current transfer descriptor has been filled

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextRxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Open

+//* \brief Open PDC: disable TX and RX reset transfer descriptors, re-enable RX and TX

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Open (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+    //* Enable the RX and TX PDC transfer requests

+	AT91F_PDC_EnableRx(pPDC);

+	AT91F_PDC_EnableTx(pPDC);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Close

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Close (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SendFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_SendFrame(

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsTxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetTx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextTx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextTxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextTx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_ReceiveFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_ReceiveFrame (

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsRxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetRx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextRx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextRxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextRx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+/* *****************************************************************************

+                SOFTWARE API FOR DBGU

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptEnable

+//* \brief Enable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptEnable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be enabled

+{

+        pDbgu->DBGU_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptDisable

+//* \brief Disable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptDisable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be disabled

+{

+        pDbgu->DBGU_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_GetInterruptMaskStatus

+//* \brief Return DBGU Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_DBGU_GetInterruptMaskStatus( // \return DBGU Interrupt Mask Status

+        AT91PS_DBGU pDbgu) // \arg  pointer to a DBGU controller

+{

+        return pDbgu->DBGU_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_IsInterruptMasked

+//* \brief Test if DBGU Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_DBGU_IsInterruptMasked(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_DBGU_GetInterruptMaskStatus(pDbgu) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PIO

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPeriph

+//* \brief Enable pins to be drived by peripheral

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPeriph(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int periphAEnable,  // \arg PERIPH A to enable

+	unsigned int periphBEnable)  // \arg PERIPH B to enable

+

+{

+	pPio->PIO_ASR = periphAEnable;

+	pPio->PIO_BSR = periphBEnable;

+	pPio->PIO_PDR = (periphAEnable | periphBEnable); // Set in Periph mode

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOutput

+//* \brief Enable PIO in output mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOutput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pioEnable)      // \arg PIO to be enabled

+{

+	pPio->PIO_PER = pioEnable; // Set in PIO mode

+	pPio->PIO_OER = pioEnable; // Configure in Output

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInput

+//* \brief Enable PIO in input mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputEnable)      // \arg PIO to be enabled

+{

+	// Disable output

+	pPio->PIO_ODR  = inputEnable;

+	pPio->PIO_PER  = inputEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOpendrain

+//* \brief Configure PIO in open drain

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOpendrain(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int multiDrvEnable) // \arg pio to be configured in open drain

+{

+	// Configure the multi-drive option

+	pPio->PIO_MDDR = ~multiDrvEnable;

+	pPio->PIO_MDER = multiDrvEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPullup

+//* \brief Enable pullup on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPullup(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pullupEnable)   // \arg enable pullup on PIO

+{

+		// Connect or not Pullup

+	pPio->PIO_PPUDR = ~pullupEnable;

+	pPio->PIO_PPUER = pullupEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgDirectDrive

+//* \brief Enable direct drive on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgDirectDrive(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int directDrive)    // \arg PIO to be configured with direct drive

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_OWDR  = ~directDrive;

+	pPio->PIO_OWER  = directDrive;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInputFilter

+//* \brief Enable input filter on input PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInputFilter(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputFilter)    // \arg PIO to be configured with input filter

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_IFDR  = ~inputFilter;

+	pPio->PIO_IFER  = inputFilter;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInput

+//* \brief Return PIO input value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInput( // \return PIO input

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+	return pPio->PIO_PDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputSet

+//* \brief Test if PIO is input flag is active

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputSet(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PIO_GetInput(pPio) & flag);

+}

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_SetOutput

+//* \brief Set to 1 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_SetOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be set

+{

+	pPio->PIO_SODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ClearOutput

+//* \brief Set to 0 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ClearOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be cleared

+{

+	pPio->PIO_CODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ForceOutput

+//* \brief Force output when Direct drive option is enabled

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ForceOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be forced

+{

+	pPio->PIO_ODSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Enable

+//* \brief Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Enable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled 

+{

+        pPio->PIO_PER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Disable

+//* \brief Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Disable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled 

+{

+        pPio->PIO_PDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetStatus

+//* \brief Return PIO Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetStatus( // \return PIO Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsSet

+//* \brief Test if PIO is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputEnable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be enabled

+{

+        pPio->PIO_OER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputDisable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be disabled

+{

+        pPio->PIO_ODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputStatus

+//* \brief Return PIO Output Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputStatus( // \return PIO Output Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOuputSet

+//* \brief Test if PIO Output is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterEnable

+//* \brief Input Filter Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be enabled

+{

+        pPio->PIO_IFER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterDisable

+//* \brief Input Filter Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be disabled

+{

+        pPio->PIO_IFDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInputFilterStatus

+//* \brief Return PIO Input Filter Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInputFilterStatus( // \return PIO Input Filter Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IFSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputFilterSet

+//* \brief Test if PIO Input filter is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputFilterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInputFilterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputDataStatus

+//* \brief Return PIO Output Data Status 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputDataStatus( // \return PIO Output Data Status 

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ODSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptEnable

+//* \brief Enable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be enabled

+{

+        pPio->PIO_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptDisable

+//* \brief Disable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be disabled

+{

+        pPio->PIO_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptMaskStatus

+//* \brief Return PIO Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptMaskStatus( // \return PIO Interrupt Mask Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptStatus( // \return PIO Interrupt Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptMasked

+//* \brief Test if PIO Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptMasked(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptMaskStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptSet

+//* \brief Test if PIO Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverEnable

+//* \brief Multi Driver Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled

+{

+        pPio->PIO_MDER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverDisable

+//* \brief Multi Driver Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled

+{

+        pPio->PIO_MDDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetMultiDriverStatus

+//* \brief Return PIO Multi Driver Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetMultiDriverStatus( // \return PIO Multi Driver Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_MDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsMultiDriverSet

+//* \brief Test if PIO MultiDriver is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsMultiDriverSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetMultiDriverStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_A_RegisterSelection

+//* \brief PIO A Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_A_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio A register selection

+{

+        pPio->PIO_ASR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_B_RegisterSelection

+//* \brief PIO B Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_B_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio B register selection 

+{

+        pPio->PIO_BSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Get_AB_RegisterStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_Get_AB_RegisterStatus( // \return PIO AB Register Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ABSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsAB_RegisterSet

+//* \brief Test if PIO AB Register is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsAB_RegisterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_Get_AB_RegisterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteEnable

+//* \brief Output Write Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be enabled

+{

+        pPio->PIO_OWER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteDisable

+//* \brief Output Write Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be disabled

+{

+        pPio->PIO_OWDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputWriteStatus

+//* \brief Return PIO Output Write Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputWriteStatus( // \return PIO Output Write Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OWSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputWriteSet

+//* \brief Test if PIO OutputWrite is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputWriteSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputWriteStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetCfgPullup

+//* \brief Return PIO Configuration Pullup

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetCfgPullup( // \return PIO Configuration Pullup 

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PPUSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputDataStatusSet

+//* \brief Test if PIO Output Data Status is Set 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputDataStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputDataStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsCfgPullupStatusSet

+//* \brief Test if PIO Configuration Pullup Status is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsCfgPullupStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (~AT91F_PIO_GetCfgPullup(pPio) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkEnableReg

+//* \brief Configure the System Clock Enable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkEnableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCER register

+	pPMC->PMC_SCER = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkDisableReg

+//* \brief Configure the System Clock Disable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkDisableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCDR register

+	pPMC->PMC_SCDR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetSysClkStatusReg

+//* \brief Return the System Clock Status Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetSysClkStatusReg (

+	AT91PS_PMC pPMC // pointer to a CAN controller

+	)

+{

+	return pPMC->PMC_SCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePeriphClock

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCER = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePeriphClock

+//* \brief Disable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCDR = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetPeriphClock

+//* \brief Get peripheral clock status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetPeriphClock (

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_PCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscillatorReg (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int mode)

+{

+	pCKGR->CKGR_MOR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainOscillatorReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MOR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_EnableMainOscillator

+//* \brief Enable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_EnableMainOscillator(

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR |= AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_DisableMainOscillator

+//* \brief Disable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_DisableMainOscillator (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscStartUpTime

+//* \brief Cfg MOR Register according to the main osc startup time

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscStartUpTime (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int startup_time,  // \arg main osc startup time in microsecond (us)

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_OSCOUNT;

+	pCKGR->CKGR_MOR |= ((slowClock * startup_time)/(8*1000000)) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClockFreqReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClockFreqReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MCFR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClock

+//* \brief Return Main clock in Hz

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClock (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	return ((pCKGR->CKGR_MCFR  & AT91C_CKGR_MAINF) * slowClock) >> 4;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgMCKReg

+//* \brief Cfg Master Clock Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgMCKReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	pPMC->PMC_MCKR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMCKReg

+//* \brief Return Master Clock Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMCKReg(

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_MCKR;

+}

+

+//*------------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMasterClock

+//* \brief Return master clock in Hz which correponds to processor clock for ARM7

+//*------------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMasterClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	unsigned int reg = pPMC->PMC_MCKR;

+	unsigned int prescaler = (1 << ((reg & AT91C_PMC_PRES) >> 2));

+	unsigned int pllDivider, pllMultiplier;

+

+	switch (reg & AT91C_PMC_CSS) {

+		case AT91C_PMC_CSS_SLOW_CLK: // Slow clock selected

+			return slowClock / prescaler;

+		case AT91C_PMC_CSS_MAIN_CLK: // Main clock is selected

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / prescaler;

+		case AT91C_PMC_CSS_PLL_CLK: // PLLB clock is selected

+			reg = pCKGR->CKGR_PLLR;

+			pllDivider    = (reg  & AT91C_CKGR_DIV);

+			pllMultiplier = ((reg  & AT91C_CKGR_MUL) >> 16) + 1;

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;

+	}

+	return 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck,  // \arg Peripheral clock identifier 0 .. 7

+	unsigned int mode)

+{

+	pPMC->PMC_PCKR[pck] = mode;

+	pPMC->PMC_SCER = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck)  // \arg Peripheral clock identifier 0 .. 7

+{

+	pPMC->PMC_SCDR = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnableIt

+//* \brief Enable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnableIt (

+	AT91PS_PMC pPMC,     // pointer to a PMC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pPMC->PMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisableIt

+//* \brief Disable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisableIt (

+	AT91PS_PMC pPMC, // pointer to a PMC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pPMC->PMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetStatus

+//* \brief Return PMC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetStatus( // \return PMC Interrupt Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetInterruptMaskStatus

+//* \brief Return PMC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetInterruptMaskStatus( // \return PMC Interrupt Mask Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsInterruptMasked

+//* \brief Test if PMC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsInterruptMasked(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetInterruptMaskStatus(pPMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsStatusSet

+//* \brief Test if PMC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsStatusSet(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetStatus(pPMC) & flag);

+}/* *****************************************************************************

+                SOFTWARE API FOR RSTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSoftReset

+//* \brief Start Software Reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSoftReset(

+        AT91PS_RSTC pRSTC,

+        unsigned int reset)

+{

+	pRSTC->RSTC_RCR = (0xA5000000 | reset);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSetMode

+//* \brief Set Reset Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSetMode(

+        AT91PS_RSTC pRSTC,

+        unsigned int mode)

+{

+	pRSTC->RSTC_RMR = (0xA5000000 | mode);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetMode

+//* \brief Get Reset Mode

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetMode(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetStatus

+//* \brief Get Reset Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetStatus(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RSR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTIsSoftRstActive

+//* \brief Return !=0 if software reset is still not completed

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTIsSoftRstActive(

+        AT91PS_RSTC pRSTC)

+{

+	return ((pRSTC->RSTC_RSR) & AT91C_RSTC_SRCMP);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR RTTC

+   ***************************************************************************** */

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_SetRTT_TimeBase()

+//* \brief  Set the RTT prescaler according to the TimeBase in ms

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetTimeBase(

+        AT91PS_RTTC pRTTC, 

+        unsigned int ms)

+{

+	if (ms > 2000)

+		return 1;   // AT91C_TIME_OUT_OF_RANGE

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (((ms << 15) /1000) & 0xFFFF);	

+	return 0;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTSetPrescaler()

+//* \brief  Set the new prescaler value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetPrescaler(

+        AT91PS_RTTC pRTTC, 

+        unsigned int rtpres)

+{

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (rtpres & 0xFFFF);	

+	return (pRTTC->RTTC_RTMR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTRestart()

+//* \brief  Restart the RTT prescaler

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTRestart(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTRST;	

+}

+

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmINT()

+//* \brief  Enable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearAlarmINT()

+//* \brief  Disable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetRttIncINT()

+//* \brief  Enable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearRttIncINT()

+//* \brief  Disable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmValue()

+//* \brief  Set RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmValue(

+        AT91PS_RTTC pRTTC, unsigned int alarm)

+{

+	pRTTC->RTTC_RTAR = alarm;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_GetAlarmValue()

+//* \brief  Get RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetAlarmValue(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTAR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTGetStatus()

+//* \brief  Read the RTT status

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetStatus(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTSR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ReadValue()

+//* \brief  Read the RTT value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTReadValue(

+        AT91PS_RTTC pRTTC)

+{

+        register volatile unsigned int val1,val2;

+	do

+	{

+		val1 = pRTTC->RTTC_RTVR;

+		val2 = pRTTC->RTTC_RTVR;

+	}	

+	while(val1 != val2);

+	return(val1);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PITC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITInit

+//* \brief System timer init : period in µsecond, system clock freq in MHz

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITInit(

+        AT91PS_PITC pPITC,

+        unsigned int period,

+        unsigned int pit_frequency)

+{

+	pPITC->PITC_PIMR = period? (period * pit_frequency + 8) >> 4 : 0; // +8 to avoid %10 and /10

+	pPITC->PITC_PIMR |= AT91C_PITC_PITEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITSetPIV

+//* \brief Set the PIT Periodic Interval Value 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITSetPIV(

+        AT91PS_PITC pPITC,

+        unsigned int piv)

+{

+	pPITC->PITC_PIMR = piv | (pPITC->PITC_PIMR & (AT91C_PITC_PITEN | AT91C_PITC_PITIEN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITEnableInt

+//* \brief Enable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITEnableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR |= AT91C_PITC_PITIEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITDisableInt

+//* \brief Disable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITDisableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR &= ~AT91C_PITC_PITIEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetMode

+//* \brief Read PIT mode register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetMode(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetStatus

+//* \brief Read PIT status register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetStatus(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PISR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIIR

+//* \brief Read PIT CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIIR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIIR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIVR

+//* \brief Read System timer CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIVR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIVR);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR WDTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSetMode

+//* \brief Set Watchdog Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTSetMode(

+        AT91PS_WDTC pWDTC,

+        unsigned int Mode)

+{

+	pWDTC->WDTC_WDMR = Mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTRestart

+//* \brief Restart Watchdog

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTRestart(

+        AT91PS_WDTC pWDTC)

+{

+	pWDTC->WDTC_WDCR = 0xA5000001;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSGettatus

+//* \brief Get Watchdog Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTSGettatus(

+        AT91PS_WDTC pWDTC)

+{

+	return(pWDTC->WDTC_WDSR & 0x3);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTGetPeriod

+//* \brief Translate ms into Watchdog Compatible value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTGetPeriod(unsigned int ms)

+{

+	if ((ms < 4) || (ms > 16000))

+		return 0;

+	return((ms << 8) / 1000);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR VREG

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Enable_LowPowerMode

+//* \brief Enable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Enable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR |= AT91C_VREG_PSTDBY;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Disable_LowPowerMode

+//* \brief Disable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Disable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR &= ~AT91C_VREG_PSTDBY;	 

+}/* *****************************************************************************

+                SOFTWARE API FOR MC

+   ***************************************************************************** */

+

+#define AT91C_MC_CORRECT_KEY  ((unsigned int) 0x5A << 24) // (MC) Correct Protect Key

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_Remap

+//* \brief Make Remap

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_Remap (void)     //  

+{

+    AT91PS_MC pMC = (AT91PS_MC) AT91C_BASE_MC;

+    

+    pMC->MC_RCR = AT91C_MC_RCB;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_CfgModeReg

+//* \brief Configure the EFC Mode Register of the MC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_CfgModeReg (

+	AT91PS_MC pMC, // pointer to a MC controller

+	unsigned int mode)        // mode register 

+{

+	// Write to the FMR register

+	pMC->MC_FMR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetModeReg

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetModeReg(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_ComputeFMCN

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_ComputeFMCN(

+	int master_clock) // master clock in Hz

+{

+	return (master_clock/1000000 +2);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_PerformCmd

+//* \brief Perform EFC Command

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_PerformCmd (

+	AT91PS_MC pMC, // pointer to a MC controller

+    unsigned int transfer_cmd)

+{

+	pMC->MC_FCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetStatus

+//* \brief Return MC EFC Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetStatus(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptMasked

+//* \brief Test if EFC MC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptMasked(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetModeReg(pMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptSet

+//* \brief Test if EFC MC Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptSet(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetStatus(pMC) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SPI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Open

+//* \brief Open a SPI Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgCs

+//* \brief Configure SPI chip select register

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgCs (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	int cs,     // SPI cs number (0 to 3)

+ 	int val)   //  chip select register

+{

+	//* Write to the CSR register

+	*(pSPI->SPI_CSR + cs) = val;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_EnableIt

+//* \brief Enable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_EnableIt (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pSPI->SPI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_DisableIt

+//* \brief Disable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_DisableIt (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pSPI->SPI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Reset

+//* \brief Reset the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Reset (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SWRST;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Enable

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Enable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Disable

+//* \brief Disable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Disable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgMode

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgMode (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	int mode)        // mode register 

+{

+	//* Write to the MR register

+	pSPI->SPI_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPCS

+//* \brief Switch to the correct PCS of SPI Mode Register : Fixed Peripheral Selected

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPCS (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	char PCS_Device) // PCS of the Device

+{	

+ 	//* Write to the MR register

+	pSPI->SPI_MR &= 0xFFF0FFFF;

+	pSPI->SPI_MR |= ( (PCS_Device<<16) & AT91C_SPI_PCS );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_ReceiveFrame (

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is bSPIy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_SendFrame(

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Close

+//* \brief Close SPI: disable IT disable transfert, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Close (

+	AT91PS_SPI pSPI)     // \arg pointer to a SPI controller

+{

+    //* Reset all the Chip Select register

+    pSPI->SPI_CSR[0] = 0 ;

+    pSPI->SPI_CSR[1] = 0 ;

+    pSPI->SPI_CSR[2] = 0 ;

+    pSPI->SPI_CSR[3] = 0 ;

+

+    //* Reset the SPI mode

+    pSPI->SPI_MR = 0  ;

+

+    //* Disable all interrupts

+    pSPI->SPI_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pSPI->SPI_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_PutChar (

+	AT91PS_SPI pSPI,

+	unsigned int character,

+             unsigned int cs_number )

+{

+    unsigned int value_for_cs;

+    value_for_cs = (~(1 << cs_number)) & 0xF;  //Place a zero among a 4 ONEs number

+    pSPI->SPI_TDR = (character & 0xFFFF) | (value_for_cs << 16);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_GetChar (

+	const AT91PS_SPI pSPI)

+{

+    return((pSPI->SPI_RDR) & 0xFFFF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetInterruptMaskStatus

+//* \brief Return SPI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_GetInterruptMaskStatus( // \return SPI Interrupt Mask Status

+        AT91PS_SPI pSpi) // \arg  pointer to a SPI controller

+{

+        return pSpi->SPI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_IsInterruptMasked

+//* \brief Test if SPI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_IsInterruptMasked(

+        AT91PS_SPI pSpi,   // \arg  pointer to a SPI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SPI_GetInterruptMaskStatus(pSpi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR USART

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Calculate the baudrate

+//* Standard Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_MODE ( AT91C_US_USMODE_NORMAL + \

+                        AT91C_US_NBSTOP_1_BIT + \

+                        AT91C_US_PAR_NONE + \

+                        AT91C_US_CHRL_8_BITS + \

+                        AT91C_US_CLKS_CLOCK )

+

+//* Standard External Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_SCK_MODE ( AT91C_US_USMODE_NORMAL + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_EXT )

+

+//* Standard Synchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_SYNC_MODE ( AT91C_US_SYNC + \

+                       AT91C_US_USMODE_NORMAL + \

+                       AT91C_US_NBSTOP_1_BIT + \

+                       AT91C_US_PAR_NONE + \

+                       AT91C_US_CHRL_8_BITS + \

+                       AT91C_US_CLKS_CLOCK )

+

+//* SCK used Label

+#define AT91C_US_SCK_USED (AT91C_US_CKLO | AT91C_US_CLKS_EXT)

+

+//* Standard ISO T=0 Mode : 8 bits , 1 stop , parity

+#define AT91C_US_ISO_READER_MODE ( AT91C_US_USMODE_ISO7816_0 + \

+					   		 AT91C_US_CLKS_CLOCK +\

+                       		 AT91C_US_NBSTOP_1_BIT + \

+                       		 AT91C_US_PAR_EVEN + \

+                       		 AT91C_US_CHRL_8_BITS + \

+                       		 AT91C_US_CKLO +\

+                       		 AT91C_US_OVER)

+

+//* Standard IRDA mode

+#define AT91C_US_ASYNC_IRDA_MODE (  AT91C_US_USMODE_IRDA + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_CLOCK )

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Caluculate baud_value according to the main clock and the baud rate

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Baudrate (

+	const unsigned int main_clock, // \arg peripheral clock

+	const unsigned int baud_rate)  // \arg UART baudrate

+{

+	unsigned int baud_value = ((main_clock*10)/(baud_rate * 16));

+	if ((baud_value % 10) >= 5)

+		baud_value = (baud_value / 10) + 1;

+	else

+		baud_value /= 10;

+	return baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetBaudrate (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int mainClock, // \arg peripheral clock

+	unsigned int speed)     // \arg UART baudrate

+{

+	//* Define the baud rate divisor register

+	pUSART->US_BRGR = AT91F_US_Baudrate(mainClock, speed);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetTimeguard

+//* \brief Set USART timeguard

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetTimeguard (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int timeguard) // \arg timeguard value

+{

+	//* Write the Timeguard Register

+	pUSART->US_TTGR = timeguard ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableIt

+//* \brief Enable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUSART->US_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableIt

+//* \brief Disable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IER register

+	pUSART->US_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Configure

+//* \brief Configure USART

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Configure (

+	AT91PS_USART pUSART,     // \arg pointer to a USART controller

+	unsigned int mainClock,  // \arg peripheral clock

+	unsigned int mode ,      // \arg mode Register to be programmed

+	unsigned int baudRate ,  // \arg baudrate to be programmed

+	unsigned int timeguard ) // \arg timeguard to be programmed

+{

+    //* Disable interrupts

+    pUSART->US_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+    pUSART->US_CR = AT91C_US_RSTRX | AT91C_US_RSTTX | AT91C_US_RXDIS | AT91C_US_TXDIS ;

+

+	//* Define the baud rate divisor register

+	AT91F_US_SetBaudrate(pUSART, mainClock, baudRate);

+

+	//* Write the Timeguard Register

+	AT91F_US_SetTimeguard(pUSART, timeguard);

+

+    //* Clear Transmit and Receive Counters

+    AT91F_PDC_Open((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Define the USART mode

+    pUSART->US_MR = mode  ;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableRx

+//* \brief Enable receiving characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableTx

+//* \brief Enable sending characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable  transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetRx

+//* \brief Reset Receiver and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset receiver

+	pUSART->US_CR = AT91C_US_RSTRX;

+    //* Re-Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetTx

+//* \brief Reset Transmitter and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset transmitter

+	pUSART->US_CR = AT91C_US_RSTTX;

+    //* Enable transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableRx

+//* \brief Disable Receiver

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable receiver

+    pUSART->US_CR = AT91C_US_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableTx

+//* \brief Disable Transmitter

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable transmitter

+    pUSART->US_CR = AT91C_US_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Close

+//* \brief Close USART: disable IT disable receiver and transmitter, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Close (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Reset the baud rate divisor register

+    pUSART->US_BRGR = 0 ;

+

+    //* Reset the USART mode

+    pUSART->US_MR = 0  ;

+

+    //* Reset the Timeguard Register

+    pUSART->US_TTGR = 0;

+

+    //* Disable all interrupts

+    pUSART->US_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pUSART->US_CR = AT91C_US_TXDIS | AT91C_US_RXDIS | AT91C_US_RSTTX | AT91C_US_RSTRX ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_TxReady

+//* \brief Return 1 if a character can be written in US_THR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_TxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_TXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_RxReady

+//* \brief Return 1 if a character can be read in US_RHR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_RxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_RXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Error

+//* \brief Return the error flag

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Error (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR &

+    	(AT91C_US_OVRE |  // Overrun error

+    	 AT91C_US_FRAME | // Framing error

+    	 AT91C_US_PARE));  // Parity error

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_PutChar (

+	AT91PS_USART pUSART,

+	int character )

+{

+    pUSART->US_THR = (character & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_US_GetChar (

+	const AT91PS_USART pUSART)

+{

+    return((pUSART->US_RHR) & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_SendFrame(

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_ReceiveFrame (

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetIrdaFilter

+//* \brief Set the value of IrDa filter tregister

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetIrdaFilter (

+	AT91PS_USART pUSART,

+	unsigned char value

+)

+{

+	pUSART->US_IF = value;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SSC

+   ***************************************************************************** */

+//* Define the standard I2S mode configuration

+

+//* Configuration to set in the SSC Transmit Clock Mode Register

+//* Parameters :  nb_bit_by_slot : 8, 16 or 32 bits

+//* 			  nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_MASTER_TX_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									   AT91C_SSC_CKS_DIV   +\

+                            		   AT91C_SSC_CKO_CONTINOUS      +\

+                            		   AT91C_SSC_CKG_NONE    +\

+                                       AT91C_SSC_START_FALL_RF +\

+                           			   AT91C_SSC_STTOUT  +\

+                            		   ((1<<16) & AT91C_SSC_STTDLY) +\

+                            		   ((((nb_bit_by_slot*nb_slot_by_frame)/2)-1) <<24))

+

+

+//* Configuration to set in the SSC Transmit Frame Mode Register

+//* Parameters : nb_bit_by_slot : 8, 16 or 32 bits

+//* 			 nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_TX_FRAME_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									(nb_bit_by_slot-1)  +\

+                            		AT91C_SSC_MSBF   +\

+                            		(((nb_slot_by_frame-1)<<8) & AT91C_SSC_DATNB)  +\

+                            		(((nb_bit_by_slot-1)<<16) & AT91C_SSC_FSLEN) +\

+                            		AT91C_SSC_FSOS_NEGATIVE)

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_SetBaudrate (

+        AT91PS_SSC pSSC,        // \arg pointer to a SSC controller

+        unsigned int mainClock, // \arg peripheral clock

+        unsigned int speed)     // \arg SSC baudrate

+{

+        unsigned int baud_value;

+        //* Define the baud rate divisor register

+        if (speed == 0)

+           baud_value = 0;

+        else

+        {

+           baud_value = (unsigned int) (mainClock * 10)/(2*speed);

+           if ((baud_value % 10) >= 5)

+                  baud_value = (baud_value / 10) + 1;

+           else

+                  baud_value /= 10;

+        }

+

+        pSSC->SSC_CMR = baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_Configure

+//* \brief Configure SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_Configure (

+             AT91PS_SSC pSSC,          // \arg pointer to a SSC controller

+             unsigned int syst_clock,  // \arg System Clock Frequency

+             unsigned int baud_rate,   // \arg Expected Baud Rate Frequency

+             unsigned int clock_rx,    // \arg Receiver Clock Parameters

+             unsigned int mode_rx,     // \arg mode Register to be programmed

+             unsigned int clock_tx,    // \arg Transmitter Clock Parameters

+             unsigned int mode_tx)     // \arg mode Register to be programmed

+{

+    //* Disable interrupts

+	pSSC->SSC_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+	pSSC->SSC_CR = AT91C_SSC_SWRST | AT91C_SSC_RXDIS | AT91C_SSC_TXDIS ;

+

+    //* Define the Clock Mode Register

+	AT91F_SSC_SetBaudrate(pSSC, syst_clock, baud_rate);

+

+     //* Write the Receive Clock Mode Register

+	pSSC->SSC_RCMR =  clock_rx;

+

+     //* Write the Transmit Clock Mode Register

+	pSSC->SSC_TCMR =  clock_tx;

+

+     //* Write the Receive Frame Mode Register

+	pSSC->SSC_RFMR =  mode_rx;

+

+     //* Write the Transmit Frame Mode Register

+	pSSC->SSC_TFMR =  mode_tx;

+

+    //* Clear Transmit and Receive Counters

+	AT91F_PDC_Open((AT91PS_PDC) &(pSSC->SSC_RPR));

+

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableRx

+//* \brief Enable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableRx

+//* \brief Disable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableTx

+//* \brief Enable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableTx

+//* \brief Disable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableIt

+//* \brief Enable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pSSC->SSC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableIt

+//* \brief Disable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pSSC->SSC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_ReceiveFrame (

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_SendFrame(

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_GetInterruptMaskStatus

+//* \brief Return SSC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_GetInterruptMaskStatus( // \return SSC Interrupt Mask Status

+        AT91PS_SSC pSsc) // \arg  pointer to a SSC controller

+{

+        return pSsc->SSC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_IsInterruptMasked

+//* \brief Test if SSC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SSC_IsInterruptMasked(

+        AT91PS_SSC pSsc,   // \arg  pointer to a SSC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SSC_GetInterruptMaskStatus(pSsc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TWI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_EnableIt

+//* \brief Enable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_EnableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pTWI->TWI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_DisableIt

+//* \brief Disable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_DisableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pTWI->TWI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_Configure

+//* \brief Configure TWI in master mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_Configure ( AT91PS_TWI pTWI )          // \arg pointer to a TWI controller

+{

+    //* Disable interrupts

+	pTWI->TWI_IDR = (unsigned int) -1;

+

+    //* Reset peripheral

+	pTWI->TWI_CR = AT91C_TWI_SWRST;

+

+	//* Set Master mode

+	pTWI->TWI_CR = AT91C_TWI_MSEN;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_GetInterruptMaskStatus

+//* \brief Return TWI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TWI_GetInterruptMaskStatus( // \return TWI Interrupt Mask Status

+        AT91PS_TWI pTwi) // \arg  pointer to a TWI controller

+{

+        return pTwi->TWI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_IsInterruptMasked

+//* \brief Test if TWI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TWI_IsInterruptMasked(

+        AT91PS_TWI pTwi,   // \arg  pointer to a TWI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TWI_GetInterruptMaskStatus(pTwi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PWMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetStatus

+//* \brief Return PWM Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetStatus( // \return PWM Interrupt Status

+	AT91PS_PWMC pPWM) // pointer to a PWM controller

+{

+	return pPWM->PWMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptEnable

+//* \brief Enable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptEnable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be enabled

+{

+        pPwm->PWMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptDisable

+//* \brief Disable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptDisable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be disabled

+{

+        pPwm->PWMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetInterruptMaskStatus

+//* \brief Return PWM Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetInterruptMaskStatus( // \return PWM Interrupt Mask Status

+        AT91PS_PWMC pPwm) // \arg  pointer to a PWM controller

+{

+        return pPwm->PWMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsInterruptMasked

+//* \brief Test if PWM Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsInterruptMasked(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetInterruptMaskStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsStatusSet

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsStatusSet(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_CfgChannel

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int mode, // \arg  PWM mode

+        unsigned int period, // \arg PWM period

+        unsigned int duty) // \arg PWM duty cycle

+{

+	pPWM->PWMC_CH[channelId].PWMC_CMR = mode;

+	pPWM->PWMC_CH[channelId].PWMC_CDTYR = duty;

+	pPWM->PWMC_CH[channelId].PWMC_CPRDR = period;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StartChannel

+//* \brief Enable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StartChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_ENA = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StopChannel

+//* \brief Disable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StopChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_DIS = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_UpdateChannel

+//* \brief Update Period or Duty Cycle

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_UpdateChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int update) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_CH[channelId].PWMC_CUPDR = update;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR UDP

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableIt

+//* \brief Enable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUDP->UDP_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableIt

+//* \brief Disable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pUDP->UDP_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetAddress

+//* \brief Set UDP functional address

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetAddress (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char address)   // \arg new UDP address

+{

+	pUDP->UDP_FADDR = (AT91C_UDP_FEN | address);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] &= ~AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetState

+//* \brief Set UDP Device state

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetState (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg new UDP address

+{

+	pUDP->UDP_GLBSTATE  &= ~(AT91C_UDP_FADDEN | AT91C_UDP_CONFG);

+	pUDP->UDP_GLBSTATE  |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetState

+//* \brief return UDP Device state

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetState ( // \return the UDP device state

+	AT91PS_UDP pUDP)     // \arg pointer to a UDP controller

+{

+	return (pUDP->UDP_GLBSTATE  & (AT91C_UDP_FADDEN | AT91C_UDP_CONFG));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_ResetEp

+//* \brief Reset UDP endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_ResetEp ( // \return the UDP device state

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg Endpoints to be reset

+{

+	pUDP->UDP_RSTEP = flag;

+	pUDP->UDP_RSTEP = 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStall

+//* \brief Endpoint will STALL requests

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpStall(

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_FORCESTALL;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpWrite

+//* \brief Write value in the DPR

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpWrite(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned char value)     // \arg value to be written in the DPR

+{

+	pUDP->UDP_FDR[endpoint] = value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpRead

+//* \brief Return value from the DPR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpRead(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_FDR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpEndOfWr

+//* \brief Notify the UDP that values in DPR are ready to be sent

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpEndOfWr(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_TXPKTRDY;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpClear

+//* \brief Clear flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpClear(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] &= ~(flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpSet

+//* \brief Set flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpSet(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStatus

+//* \brief Return the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpStatus(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_CSR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetInterruptMaskStatus

+//* \brief Return UDP Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetInterruptMaskStatus( // \return UDP Interrupt Mask Status

+        AT91PS_UDP pUdp) // \arg  pointer to a UDP controller

+{

+        return pUdp->UDP_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_IsInterruptMasked

+//* \brief Test if UDP Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_UDP_IsInterruptMasked(

+        AT91PS_UDP pUdp,   // \arg  pointer to a UDP controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_UDP_GetInterruptMaskStatus(pUdp) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptEnable

+//* \brief Enable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptEnable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be enabled

+{

+        pTc->TC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptDisable

+//* \brief Disable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptDisable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be disabled

+{

+        pTc->TC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_GetInterruptMaskStatus

+//* \brief Return TC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TC_GetInterruptMaskStatus( // \return TC Interrupt Mask Status

+        AT91PS_TC pTc) // \arg  pointer to a TC controller

+{

+        return pTc->TC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_IsInterruptMasked

+//* \brief Test if TC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TC_IsInterruptMasked(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TC_GetInterruptMaskStatus(pTc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR CAN

+   ***************************************************************************** */

+#define	STANDARD_FORMAT 0

+#define	EXTENDED_FORMAT 1

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_InitMailboxRegisters()

+//* \brief Configure the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_InitMailboxRegisters(AT91PS_CAN_MB	CAN_Mailbox,

+								int  			mode_reg,

+								int 			acceptance_mask_reg,

+								int  			id_reg,

+								int  			data_low_reg,

+								int  			data_high_reg,

+								int  			control_reg)

+{

+	CAN_Mailbox->CAN_MB_MCR 	= 0x0;

+	CAN_Mailbox->CAN_MB_MMR 	= mode_reg;

+	CAN_Mailbox->CAN_MB_MAM 	= acceptance_mask_reg;

+	CAN_Mailbox->CAN_MB_MID 	= id_reg;

+	CAN_Mailbox->CAN_MB_MDL 	= data_low_reg; 		

+	CAN_Mailbox->CAN_MB_MDH 	= data_high_reg;

+	CAN_Mailbox->CAN_MB_MCR 	= control_reg;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EnableCAN()

+//* \brief 

+//*----------------------------------------------------------------------------

+__inline void AT91F_EnableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR |= AT91C_CAN_CANEN;

+

+	// Wait for WAKEUP flag raising <=> 11-recessive-bit were scanned by the transceiver

+	while( (pCAN->CAN_SR & AT91C_CAN_WAKEUP) != AT91C_CAN_WAKEUP );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DisableCAN()

+//* \brief 

+//*----------------------------------------------------------------------------

+__inline void AT91F_DisableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR &= ~AT91C_CAN_CANEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_EnableIt

+//* \brief Enable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_EnableIt (

+	AT91PS_CAN pCAN,     // pointer to a CAN controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pCAN->CAN_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_DisableIt

+//* \brief Disable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_DisableIt (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pCAN->CAN_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetStatus

+//* \brief Return CAN Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetStatus( // \return CAN Interrupt Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInterruptMaskStatus

+//* \brief Return CAN Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInterruptMaskStatus( // \return CAN Interrupt Mask Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsInterruptMasked

+//* \brief Test if CAN Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsInterruptMasked(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetInterruptMaskStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsStatusSet

+//* \brief Test if CAN Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsStatusSet(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgModeReg

+//* \brief Configure the Mode Register of the CAN controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgModeReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pCAN->CAN_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetModeReg

+//* \brief Return the Mode Register of the CAN controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetModeReg (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgBaudrateReg

+//* \brief Configure the Baudrate of the CAN controller for the network

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgBaudrateReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int baudrate_cfg)

+{

+	//* Write to the BR register

+	pCAN->CAN_BR = baudrate_cfg;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetBaudrate

+//* \brief Return the Baudrate of the CAN controller for the network value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetBaudrate (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_BR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInternalCounter

+//* \brief Return CAN Timer Regsiter Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInternalCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIM;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetTimestamp

+//* \brief Return CAN Timestamp Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetTimestamp (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIMESTP;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetErrorCounter

+//* \brief Return CAN Error Counter Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetErrorCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_ECR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitTransferRequest

+//* \brief Request for a transfer on the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitTransferRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int transfer_cmd)

+{

+	pCAN->CAN_TCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitAbortRequest

+//* \brief Abort the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitAbortRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int abort_cmd)

+{

+	pCAN->CAN_ACR = abort_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageModeReg

+//* \brief Program the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mode)

+{

+	CAN_Mailbox->CAN_MB_MMR = mode;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageModeReg

+//* \brief Return the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MMR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageIDReg

+//* \brief Program the Message ID Register

+//* \brief Version == 0 for Standard messsage, Version == 1 for Extended  

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int id,

+    unsigned char version)

+{

+	if(version==0)	// IDvA Standard Format

+		CAN_Mailbox->CAN_MB_MID = id<<18;

+	else	// IDvB Extended Format

+		CAN_Mailbox->CAN_MB_MID = id | (1<<29);	// set MIDE bit

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageIDReg

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MID;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageAcceptanceMaskReg

+//* \brief Program the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mask)

+{

+	CAN_Mailbox->CAN_MB_MAM = mask;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageAcceptanceMaskReg

+//* \brief Return the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MAM;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetFamilyID

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetFamilyID (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MFID;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageCtrl

+//* \brief Request and config for a transfer on the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageCtrlReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int message_ctrl_cmd)

+{

+	CAN_Mailbox->CAN_MB_MCR = message_ctrl_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageStatus

+//* \brief Return CAN Mailbox Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageStatus (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataLow

+//* \brief Program data low value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDL = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataLow

+//* \brief Return data low value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDL;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataHigh

+//* \brief Program data high value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDH = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataHigh

+//* \brief Return data high value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDH;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_Open

+//* \brief Open a CAN Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+/* *****************************************************************************

+                SOFTWARE API FOR ADC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableIt

+//* \brief Enable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableIt (

+	AT91PS_ADC pADC,     // pointer to a ADC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pADC->ADC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableIt

+//* \brief Disable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableIt (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pADC->ADC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetStatus

+//* \brief Return ADC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetStatus( // \return ADC Interrupt Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetInterruptMaskStatus

+//* \brief Return ADC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetInterruptMaskStatus( // \return ADC Interrupt Mask Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsInterruptMasked

+//* \brief Test if ADC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsInterruptMasked(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetInterruptMaskStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsStatusSet

+//* \brief Test if ADC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsStatusSet(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgModeReg

+//* \brief Configure the Mode Register of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgModeReg (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pADC->ADC_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetModeReg

+//* \brief Return the Mode Register of the ADC controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetModeReg (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgTimings

+//* \brief Configure the different necessary timings of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgTimings (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mck_clock, // in MHz 

+	unsigned int adc_clock, // in MHz 

+	unsigned int startup_time, // in us 

+	unsigned int sample_and_hold_time)	// in ns  

+{

+	unsigned int prescal,startup,shtim;

+	

+	prescal = mck_clock/(2*adc_clock) - 1;

+	startup = adc_clock*startup_time/8 - 1;

+	shtim = adc_clock*sample_and_hold_time/1000 - 1;

+	

+	//* Write to the MR register

+	pADC->ADC_MR = ( (prescal<<8) & AT91C_ADC_PRESCAL) | ( (startup<<16) & AT91C_ADC_STARTUP) | ( (shtim<<24) & AT91C_ADC_SHTIM);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHER register

+	pADC->ADC_CHER = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHDR register

+	pADC->ADC_CHDR = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetChannelStatus

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetChannelStatus (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CHSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_StartConversion

+//* \brief Software request for a analog to digital conversion 

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_StartConversion (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_SoftReset

+//* \brief Software reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_SoftReset (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetLastConvertedData

+//* \brief Return the Last Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetLastConvertedData (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_LCDR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH0

+//* \brief Return the Channel 0 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH0 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR0;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH1

+//* \brief Return the Channel 1 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH1 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR1;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH2

+//* \brief Return the Channel 2 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH2 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR2;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH3

+//* \brief Return the Channel 3 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH3 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR3;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH4

+//* \brief Return the Channel 4 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH4 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR4;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH5

+//* \brief Return the Channel 5 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH5 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR5;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH6

+//* \brief Return the Channel 6 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH6 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR6;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH7

+//* \brief Return the Channel 7 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH7 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR7;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR AES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_EnableIt

+//* \brief Enable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_EnableIt (

+	AT91PS_AES pAES,     // pointer to a AES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pAES->AES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_DisableIt

+//* \brief Disable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_DisableIt (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pAES->AES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetStatus

+//* \brief Return AES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetStatus( // \return AES Interrupt Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetInterruptMaskStatus

+//* \brief Return AES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetInterruptMaskStatus( // \return AES Interrupt Mask Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsInterruptMasked

+//* \brief Test if AES Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsInterruptMasked(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetInterruptMaskStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsStatusSet

+//* \brief Test if AES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsStatusSet(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgModeReg

+//* \brief Configure the Mode Register of the AES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgModeReg (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pAES->AES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetModeReg

+//* \brief Return the Mode Register of the AES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetModeReg (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	return pAES->AES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_StartProcessing (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SoftReset

+//* \brief Reset AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SoftReset (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_LoadNewSeed

+//* \brief Load New Seed in the random number generator

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_LoadNewSeed (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_LOADSEED;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetCryptoKey

+//* \brief Set Cryptographic Key x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetCryptoKey (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pAES->AES_KEYWxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_InputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pAES->AES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetOutputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index

+	)

+{

+	return pAES->AES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetInitializationVector

+//* \brief Set Initialization Vector (or Counter) x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetInitializationVector (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pAES->AES_IVxR[index] = initvector;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TDES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_EnableIt

+//* \brief Enable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_EnableIt (

+	AT91PS_TDES pTDES,     // pointer to a TDES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pTDES->TDES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_DisableIt

+//* \brief Disable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_DisableIt (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pTDES->TDES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetStatus

+//* \brief Return TDES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetStatus( // \return TDES Interrupt Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetInterruptMaskStatus

+//* \brief Return TDES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetInterruptMaskStatus( // \return TDES Interrupt Mask Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsInterruptMasked

+//* \brief Test if TDES Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsInterruptMasked(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetInterruptMaskStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsStatusSet

+//* \brief Test if TDES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsStatusSet(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgModeReg

+//* \brief Configure the Mode Register of the TDES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgModeReg (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pTDES->TDES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetModeReg

+//* \brief Return the Mode Register of the TDES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetModeReg (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	return pTDES->TDES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_StartProcessing (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SoftReset

+//* \brief Reset TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SoftReset (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey1

+//* \brief Set Cryptographic Key 1 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey1 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY1WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey2

+//* \brief Set Cryptographic Key 2 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey2 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY2WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey3

+//* \brief Set Cryptographic Key 3 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey3 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY3WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_InputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pTDES->TDES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetOutputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index

+	)

+{

+	return pTDES->TDES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetInitializationVector

+//* \brief Set Initialization Vector x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetInitializationVector (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pTDES->TDES_IVxR[index] = initvector;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  DBGU

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPIO

+//* \brief Configure PIO controllers to drive DBGU signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA27_DRXD    ) |

+		((unsigned int) AT91C_PA28_DTXD    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPIO

+//* \brief Configure PIO controllers to drive PMC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB30_PCK2    ) |

+		((unsigned int) AT91C_PB29_PCK1    ), // Peripheral A

+		((unsigned int) AT91C_PB20_PCK0    ) |

+		((unsigned int) AT91C_PB0_PCK0    ) |

+		((unsigned int) AT91C_PB22_PCK2    ) |

+		((unsigned int) AT91C_PB21_PCK1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA30_PCK2    ) |

+		((unsigned int) AT91C_PA13_PCK1    ) |

+		((unsigned int) AT91C_PA27_PCK3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  VREG

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RSTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SSC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPIO

+//* \brief Configure PIO controllers to drive SSC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA25_RK      ) |

+		((unsigned int) AT91C_PA22_TK      ) |

+		((unsigned int) AT91C_PA21_TF      ) |

+		((unsigned int) AT91C_PA24_RD      ) |

+		((unsigned int) AT91C_PA26_RF      ) |

+		((unsigned int) AT91C_PA23_TD      ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  WDTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US1

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPIO

+//* \brief Configure PIO controllers to drive US1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB26_RI1     ) |

+		((unsigned int) AT91C_PB24_DSR1    ) |

+		((unsigned int) AT91C_PB23_DCD1    ) |

+		((unsigned int) AT91C_PB25_DTR1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA7_SCK1    ) |

+		((unsigned int) AT91C_PA8_RTS1    ) |

+		((unsigned int) AT91C_PA6_TXD1    ) |

+		((unsigned int) AT91C_PA5_RXD1    ) |

+		((unsigned int) AT91C_PA9_CTS1    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US0

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPIO

+//* \brief Configure PIO controllers to drive US0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA0_RXD0    ) |

+		((unsigned int) AT91C_PA4_CTS0    ) |

+		((unsigned int) AT91C_PA3_RTS0    ) |

+		((unsigned int) AT91C_PA2_SCK0    ) |

+		((unsigned int) AT91C_PA1_TXD0    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI1

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPIO

+//* \brief Configure PIO controllers to drive SPI1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB16_NPCS13  ) |

+		((unsigned int) AT91C_PB10_NPCS11  ) |

+		((unsigned int) AT91C_PB11_NPCS12  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA4_NPCS13  ) |

+		((unsigned int) AT91C_PA29_NPCS13  ) |

+		((unsigned int) AT91C_PA21_NPCS10  ) |

+		((unsigned int) AT91C_PA22_SPCK1   ) |

+		((unsigned int) AT91C_PA25_NPCS11  ) |

+		((unsigned int) AT91C_PA2_NPCS11  ) |

+		((unsigned int) AT91C_PA24_MISO1   ) |

+		((unsigned int) AT91C_PA3_NPCS12  ) |

+		((unsigned int) AT91C_PA26_NPCS12  ) |

+		((unsigned int) AT91C_PA23_MOSI1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI0

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPIO

+//* \brief Configure PIO controllers to drive SPI0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB13_NPCS01  ) |

+		((unsigned int) AT91C_PB17_NPCS03  ) |

+		((unsigned int) AT91C_PB14_NPCS02  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA16_MISO0   ) |

+		((unsigned int) AT91C_PA13_NPCS01  ) |

+		((unsigned int) AT91C_PA15_NPCS03  ) |

+		((unsigned int) AT91C_PA17_MOSI0   ) |

+		((unsigned int) AT91C_PA18_SPCK0   ) |

+		((unsigned int) AT91C_PA14_NPCS02  ) |

+		((unsigned int) AT91C_PA12_NPCS00  ), // Peripheral A

+		((unsigned int) AT91C_PA7_NPCS01  ) |

+		((unsigned int) AT91C_PA9_NPCS03  ) |

+		((unsigned int) AT91C_PA8_NPCS02  )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PITC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AIC

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_FIQ) |

+		((unsigned int) 1 << AT91C_ID_IRQ0) |

+		((unsigned int) 1 << AT91C_ID_IRQ1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPIO

+//* \brief Configure PIO controllers to drive AIC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA30_IRQ0    ) |

+		((unsigned int) AT91C_PA29_FIQ     ), // Peripheral A

+		((unsigned int) AT91C_PA14_IRQ1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_AES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TWI

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TWI));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPIO

+//* \brief Configure PIO controllers to drive TWI signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA11_TWCK    ) |

+		((unsigned int) AT91C_PA10_TWD     ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  ADC

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_ADC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPIO

+//* \brief Configure PIO controllers to drive ADC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB18_ADTRG   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH3_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH3 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH3_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB22_PWM3    ), // Peripheral A

+		((unsigned int) AT91C_PB30_PWM3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH2_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB21_PWM2    ), // Peripheral A

+		((unsigned int) AT91C_PB29_PWM2    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH1_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB20_PWM1    ), // Peripheral A

+		((unsigned int) AT91C_PB28_PWM1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH0_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB19_PWM0    ), // Peripheral A

+		((unsigned int) AT91C_PB27_PWM0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RTTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RTTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RTTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  UDP

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_UDP));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TDES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  EMAC

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_EMAC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPIO

+//* \brief Configure PIO controllers to drive EMAC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB2_ETX0    ) |

+		((unsigned int) AT91C_PB12_ETXER   ) |

+		((unsigned int) AT91C_PB16_ECOL    ) |

+		((unsigned int) AT91C_PB11_ETX3    ) |

+		((unsigned int) AT91C_PB6_ERX1    ) |

+		((unsigned int) AT91C_PB15_ERXDV   ) |

+		((unsigned int) AT91C_PB13_ERX2    ) |

+		((unsigned int) AT91C_PB3_ETX1    ) |

+		((unsigned int) AT91C_PB8_EMDC    ) |

+		((unsigned int) AT91C_PB5_ERX0    ) |

+		//((unsigned int) AT91C_PB18_EF100   ) |

+		((unsigned int) AT91C_PB14_ERX3    ) |

+		((unsigned int) AT91C_PB4_ECRS_ECRSDV) |

+		((unsigned int) AT91C_PB1_ETXEN   ) |

+		((unsigned int) AT91C_PB10_ETX2    ) |

+		((unsigned int) AT91C_PB0_ETXCK_EREFCK) |

+		((unsigned int) AT91C_PB9_EMDIO   ) |

+		((unsigned int) AT91C_PB7_ERXER   ) |

+		((unsigned int) AT91C_PB17_ERXCK   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC0

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPIO

+//* \brief Configure PIO controllers to drive TC0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB23_TIOA0   ) |

+		((unsigned int) AT91C_PB24_TIOB0   ), // Peripheral A

+		((unsigned int) AT91C_PB12_TCLK0   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC1

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPIO

+//* \brief Configure PIO controllers to drive TC1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB25_TIOA1   ) |

+		((unsigned int) AT91C_PB26_TIOB1   ), // Peripheral A

+		((unsigned int) AT91C_PB19_TCLK1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC2

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC2));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPIO

+//* \brief Configure PIO controllers to drive TC2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB28_TIOB2   ) |

+		((unsigned int) AT91C_PB27_TIOA2   ), // Peripheral A

+		0); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA15_TCLK2   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  MC

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOA_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOA

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOA_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOA));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOB_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOB

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOB_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOB));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  CAN

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_CAN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPIO

+//* \brief Configure PIO controllers to drive CAN signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA20_CANTX   ) |

+		((unsigned int) AT91C_PA19_CANRX   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PWMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PWMC));

+}

+

+#endif // lib_AT91SAM7X256_H

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/port.c b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/port.c
new file mode 100644
index 0000000..01531a2
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/port.c
@@ -0,0 +1,252 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM7 port.

+ *

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in this file.  The ISR routines, which can only be compiled

+ * to ARM mode are contained in portISR.c.

+ *----------------------------------------------------------*/

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Processor constants. */

+#include "AT91SAM7X256.h"

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+#define portNO_CRITICAL_SECTION_NESTING	( ( portSTACK_TYPE ) 0 )

+

+/* Constants required to setup the tick ISR. */

+#define portENABLE_TIMER			( ( unsigned char ) 0x01 )

+#define portPRESCALE_VALUE			0x00

+#define portINTERRUPT_ON_MATCH		( ( unsigned long ) 0x01 )

+#define portRESET_COUNT_ON_MATCH	( ( unsigned long ) 0x02 )

+

+/* Constants required to setup the PIT. */

+#define portPIT_CLOCK_DIVISOR			( ( unsigned long ) 16 )

+#define portPIT_COUNTER_VALUE			( ( ( configCPU_CLOCK_HZ / portPIT_CLOCK_DIVISOR ) / 1000UL ) * portTICK_RATE_MS )

+

+#define portINT_LEVEL_SENSITIVE  0

+#define portPIT_ENABLE      	( ( unsigned short ) 0x1 << 24 )

+#define portPIT_INT_ENABLE     	( ( unsigned short ) 0x1 << 25 )

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * The scheduler can only be started from ARM mode, so 

+ * vPortISRStartFirstSTask() is defined in portISR.c. 

+ */

+extern void vPortISRStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The last thing onto the stack is the status register, which is set for

+	system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	#ifdef THUMB_INTERWORK

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+	#endif

+

+	pxTopOfStack--;

+

+	/* Some optimisation levels use the stack differently to others.  This 

+	means the interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_SECTION_NESTING;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortISRStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the timer 0 to generate the tick interrupts at the required frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+AT91PS_PITC pxPIT = AT91C_BASE_PITC;

+

+	/* Setup the AIC for PIT interrupts.  The interrupt routine chosen depends

+	on whether the preemptive or cooperative scheduler is being used. */

+	#if configUSE_PREEMPTION == 0

+

+		extern void ( vNonPreemptiveTick ) ( void );

+		AT91F_AIC_ConfigureIt( AT91C_ID_SYS, AT91C_AIC_PRIOR_HIGHEST, portINT_LEVEL_SENSITIVE, ( void (*)(void) ) vNonPreemptiveTick );

+

+	#else

+		

+		extern void ( vPreemptiveTick )( void );

+		AT91F_AIC_ConfigureIt( AT91C_ID_SYS, AT91C_AIC_PRIOR_HIGHEST, portINT_LEVEL_SENSITIVE, ( void (*)(void) ) vPreemptiveTick );

+

+	#endif

+

+	/* Configure the PIT period. */

+	pxPIT->PITC_PIMR = portPIT_ENABLE | portPIT_INT_ENABLE | portPIT_COUNTER_VALUE;

+

+	/* Enable the interrupt.  Global interrupts are disables at this point so 

+	this is safe. */

+    AT91C_BASE_AIC->AIC_IECR = 0x1 << AT91C_ID_SYS;

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portISR.c b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portISR.c
new file mode 100644
index 0000000..744a58e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portISR.c
@@ -0,0 +1,265 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in port.c  The ISR routines, which can only be compiled

+ * to ARM mode, are contained in this file.

+ *----------------------------------------------------------*/

+

+/*

+	Changes from V3.2.4

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#include "AT91SAM7X256.h"

+

+/* Constants required to handle interrupts. */

+#define portTIMER_MATCH_ISR_BIT		( ( unsigned char ) 0x01 )

+#define portCLEAR_VIC_INTERRUPT		( ( unsigned long ) 0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING		( ( unsigned long ) 0 )

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* ISR to handle manual context switches (from a call to taskYIELD()). */

+void vPortYieldProcessor( void ) __attribute__((interrupt("SWI"), naked));

+

+/* 

+ * The scheduler can only be started from ARM mode, hence the inclusion of this

+ * function here.

+ */

+void vPortISRStartFirstTask( void );

+/*-----------------------------------------------------------*/

+

+void vPortISRStartFirstTask( void )

+{

+	/* Simply start the scheduler.  This is included here as it can only be

+	called from ARM mode. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Called by portYIELD() or taskYIELD() to manually force a context switch.

+ *

+ * When a context switch is performed from the task level the saved task 

+ * context is made to look as if it occurred from within the tick ISR.  This

+ * way the same restore context function can be used when restoring the context

+ * saved from the ISR or that saved from a call to vPortYieldProcessor.

+ */

+void vPortYieldProcessor( void )

+{

+	/* Within an IRQ ISR the link register has an offset from the true return 

+	address, but an SWI ISR does not.  Add the offset manually so the same 

+	ISR return code can be used in both cases. */

+	asm volatile ( "ADD		LR, LR, #4" );

+

+	/* Perform the context switch.  First save the context of the current task. */

+	portSAVE_CONTEXT();

+

+	/* Find the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();	

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+

+#if configUSE_PREEMPTION == 0

+

+	/* The cooperative scheduler requires a normal IRQ service routine to 

+	simply increment the system tick. */

+	void vNonPreemptiveTick( void ) __attribute__ ((interrupt ("IRQ")));

+	void vNonPreemptiveTick( void )

+	{		

+		unsigned long ulDummy;

+		

+		/* Increment the tick count - which may wake some tasks but as the

+		preemptive scheduler is not being used any woken task is not given

+		processor time no matter what its priority. */

+		vTaskIncrementTick();

+		

+		/* Clear the PIT interrupt. */

+		ulDummy = AT91C_BASE_PITC->PITC_PIVR;

+		

+		/* End the interrupt in the AIC. */

+		AT91C_BASE_AIC->AIC_EOICR = ulDummy;

+	}

+

+#else

+

+	/* The preemptive scheduler is defined as "naked" as the full context is

+	saved on entry as part of the context switch. */

+	void vPreemptiveTick( void ) __attribute__((naked));

+	void vPreemptiveTick( void )

+	{

+		/* Save the context of the current task. */

+		portSAVE_CONTEXT();			

+

+		/* Increment the tick count - this may wake a task. */

+		vTaskIncrementTick();

+

+		/* Find the highest priority task that is ready to run. */

+		vTaskSwitchContext();

+		

+		/* End the interrupt in the AIC. */

+		AT91C_BASE_AIC->AIC_EOICR = AT91C_BASE_PITC->PITC_PIVR;;

+		

+		portRESTORE_CONTEXT();

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions here to

+ * ensure a switch to ARM mode.  When THUMB_INTERWORK is not defined then

+ * the utilities are defined as macros in portmacro.h - as per other ports.

+ */

+void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+void vPortDisableInterruptsFromThumb( void )

+{

+	asm volatile ( 

+		"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/

+		"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/

+		"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.						*/

+		"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/

+		"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+		"BX		R14" );					/* Return back to thumb.					*/

+}

+		

+void vPortEnableInterruptsFromThumb( void )

+{

+	asm volatile ( 

+		"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/	

+		"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/	

+		"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.							*/	

+		"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/	

+		"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+		"BX		R14" );					/* Return back to thumb.					*/

+}

+

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	asm volatile ( 

+		"STMDB	SP!, {R0}			\n\t"	/* Push R0.								*/

+		"MRS	R0, CPSR			\n\t"	/* Get CPSR.							*/

+		"ORR	R0, R0, #0xC0		\n\t"	/* Disable IRQ, FIQ.					*/

+		"MSR	CPSR, R0			\n\t"	/* Write back modified value.			*/

+		"LDMIA	SP!, {R0}" );				/* Pop R0.								*/

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL().					*/

+			asm volatile ( 

+				"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	

+				"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	

+				"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	

+				"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	

+				"LDMIA	SP!, {R0}" );			/* Pop R0.						*/

+		}

+	}

+}

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portmacro.h
new file mode 100644
index 0000000..a9b466e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_AT91SAM7S/portmacro.h
@@ -0,0 +1,284 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+	Changes from V3.2.3

+	

+	+ Modified portENTER_SWITCHING_ISR() to allow use with GCC V4.0.1.

+

+	Changes from V3.2.4

+

+	+ Removed the use of the %0 parameter within the assembler macros and 

+	  replaced them with hard coded registers.  This will ensure the

+	  assembler does not select the link register as the temp register as

+	  was occasionally happening previously.

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+

+	Changes from V4.5.0

+

+	+ Removed the portENTER_SWITCHING_ISR() and portEXIT_SWITCHING_ISR() macros

+	  and replaced them with portYIELD_FROM_ISR() macro.  Application code 

+	  should now make use of the portSAVE_CONTEXT() and portRESTORE_CONTEXT()

+	  macros as per the V4.5.1 demo code.

+*/

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portNOP()					asm volatile ( "NOP" );

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+

+/*

+ * portRESTORE_CONTEXT, portRESTORE_CONTEXT, portENTER_SWITCHING_ISR

+ * and portEXIT_SWITCHING_ISR can only be called from ARM mode, but

+ * are included here for efficiency.  An attempt to call one from

+ * THUMB mode code will result in a compile time error.

+ */

+

+#define portRESTORE_CONTEXT()											\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Set the LR to the task stack. */									\

+	asm volatile (														\

+	"LDR		R0, =pxCurrentTCB								\n\t"	\

+	"LDR		R0, [R0]										\n\t"	\

+	"LDR		LR, [R0]										\n\t"	\

+																		\

+	/* The critical nesting depth is the first item on the stack. */	\

+	/* Load it into the ulCriticalNesting variable. */					\

+	"LDR		R0, =ulCriticalNesting							\n\t"	\

+	"LDMFD	LR!, {R1}											\n\t"	\

+	"STR		R1, [R0]										\n\t"	\

+																		\

+	/* Get the SPSR from the stack. */									\

+	"LDMFD	LR!, {R0}											\n\t"	\

+	"MSR		SPSR, R0										\n\t"	\

+																		\

+	/* Restore all system mode registers for the task. */				\

+	"LDMFD	LR, {R0-R14}^										\n\t"	\

+	"NOP														\n\t"	\

+																		\

+	/* Restore the return address. */									\

+	"LDR		LR, [LR, #+60]									\n\t"	\

+																		\

+	/* And return - correcting the offset in the LR to obtain the */	\

+	/* correct address. */												\

+	"SUBS	PC, LR, #4											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+/*-----------------------------------------------------------*/

+

+#define portSAVE_CONTEXT()												\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Push R0 as we are going to use the register. */					\

+	asm volatile (														\

+	"STMDB	SP!, {R0}											\n\t"	\

+																		\

+	/* Set R0 to point to the task stack pointer. */					\

+	"STMDB	SP,{SP}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	SP, SP, #4											\n\t"	\

+	"LDMIA	SP!,{R0}											\n\t"	\

+																		\

+	/* Push the return address onto the stack. */						\

+	"STMDB	R0!, {LR}											\n\t"	\

+																		\

+	/* Now we have saved LR we can use it instead of R0. */				\

+	"MOV	LR, R0												\n\t"	\

+																		\

+	/* Pop R0 so we can save it onto the system mode stack. */			\

+	"LDMIA	SP!, {R0}											\n\t"	\

+																		\

+	/* Push all the system mode registers onto the task stack. */		\

+	"STMDB	LR,{R0-LR}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	LR, LR, #60											\n\t"	\

+																		\

+	/* Push the SPSR onto the task stack. */							\

+	"MRS	R0, SPSR											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	"LDR	R0, =ulCriticalNesting								\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	/* Store the new top of stack for the task. */						\

+	"LDR	R0, =pxCurrentTCB									\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STR	LR, [R0]											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+

+

+#define portYIELD_FROM_ISR()		vTaskSwitchContext()

+#define portYIELD()					asm volatile ( "SWI 0" )

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions in 

+ * portISR.c to ensure a switch to ARM mode.  When THUMB_INTERWORK is not 

+ * defined then the utilities are defined as macros here - as per other ports.

+ */

+

+#ifdef THUMB_INTERWORK

+

+	extern void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	extern void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()

+	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

+	

+#else

+

+	#define portDISABLE_INTERRUPTS()											\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.			*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+			

+	#define portENABLE_INTERRUPTS()												\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+

+#endif /* THUMB_INTERWORK */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/port.c b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/port.c
new file mode 100644
index 0000000..011a726
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/port.c
@@ -0,0 +1,260 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM7 port.

+ *

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in this file.  The ISR routines, which can only be compiled

+ * to ARM mode are contained in portISR.c.

+ *----------------------------------------------------------*/

+

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+#define portNO_CRITICAL_SECTION_NESTING	( ( portSTACK_TYPE ) 0 )

+

+/* Constants required to setup the tick ISR. */

+#define portENABLE_TIMER			( ( unsigned char ) 0x01 )

+#define portPRESCALE_VALUE			0x00

+#define portINTERRUPT_ON_MATCH		( ( unsigned long ) 0x01 )

+#define portRESET_COUNT_ON_MATCH	( ( unsigned long ) 0x02 )

+

+/* Constants required to setup the VIC for the tick ISR. */

+#define portTIMER_VIC_CHANNEL		( ( unsigned long ) 0x0004 )

+#define portTIMER_VIC_CHANNEL_BIT	( ( unsigned long ) 0x0010 )

+#define portTIMER_VIC_ENABLE		( ( unsigned long ) 0x0020 )

+

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * The scheduler can only be started from ARM mode, so 

+ * vPortISRStartFirstSTask() is defined in portISR.c. 

+ */

+extern void vPortISRStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The last thing onto the stack is the status register, which is set for

+	system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00 )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+

+	pxTopOfStack--;

+

+	/* Some optimisation levels use the stack differently to others.  This 

+	means the interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_SECTION_NESTING;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortISRStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the timer 0 to generate the tick interrupts at the required frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+unsigned long ulCompareMatch;

+extern void ( vTickISR )( void );

+

+	/* A 1ms tick does not require the use of the timer prescale.  This is

+	defaulted to zero but can be used if necessary. */

+	T0_PR = portPRESCALE_VALUE;

+

+	/* Calculate the match value required for our wanted tick rate. */

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* Protect against divide by zero.  Using an if() statement still results

+	in a warning - hence the #if. */

+	#if portPRESCALE_VALUE != 0

+	{

+		ulCompareMatch /= ( portPRESCALE_VALUE + 1 );

+	}

+	#endif

+	T0_MR0 = ulCompareMatch;

+

+	/* Generate tick with timer 0 compare match. */

+	T0_MCR = portRESET_COUNT_ON_MATCH | portINTERRUPT_ON_MATCH;

+

+	/* Setup the VIC for the timer. */

+	VICIntSelect &= ~( portTIMER_VIC_CHANNEL_BIT );

+	VICIntEnable |= portTIMER_VIC_CHANNEL_BIT;

+	

+	/* The ISR installed depends on whether the preemptive or cooperative

+	scheduler is being used. */

+

+	VICVectAddr0 = ( long ) vTickISR;

+	VICVectCntl0 = portTIMER_VIC_CHANNEL | portTIMER_VIC_ENABLE;

+

+	/* Start the timer - interrupts are disabled when this function is called

+	so it is okay to do this here. */

+	T0_TCR = portENABLE_TIMER;

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portISR.c b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portISR.c
new file mode 100644
index 0000000..7bd25f0
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portISR.c
@@ -0,0 +1,251 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in port.c  The ISR routines, which can only be compiled

+ * to ARM mode, are contained in this file.

+ *----------------------------------------------------------*/

+

+/*

+	Changes from V2.5.2

+		

+	+ The critical section management functions have been changed.  These no

+	  longer modify the stack and are safe to use at all optimisation levels.

+	  The functions are now also the same for both ARM and THUMB modes.

+

+	Changes from V2.6.0

+

+	+ Removed the 'static' from the definition of vNonPreemptiveTick() to 

+	  allow the demo to link when using the cooperative scheduler.

+

+	Changes from V3.2.4

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+

+/* Constants required to handle interrupts. */

+#define portTIMER_MATCH_ISR_BIT		( ( unsigned char ) 0x01 )

+#define portCLEAR_VIC_INTERRUPT		( ( unsigned long ) 0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING		( ( unsigned long ) 0 )

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* ISR to handle manual context switches (from a call to taskYIELD()). */

+void vPortYieldProcessor( void ) __attribute__((interrupt("SWI"), naked));

+

+/* 

+ * The scheduler can only be started from ARM mode, hence the inclusion of this

+ * function here.

+ */

+void vPortISRStartFirstTask( void );

+/*-----------------------------------------------------------*/

+

+void vPortISRStartFirstTask( void )

+{

+	/* Simply start the scheduler.  This is included here as it can only be

+	called from ARM mode. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Called by portYIELD() or taskYIELD() to manually force a context switch.

+ *

+ * When a context switch is performed from the task level the saved task 

+ * context is made to look as if it occurred from within the tick ISR.  This

+ * way the same restore context function can be used when restoring the context

+ * saved from the ISR or that saved from a call to vPortYieldProcessor.

+ */

+void vPortYieldProcessor( void )

+{

+	/* Within an IRQ ISR the link register has an offset from the true return 

+	address, but an SWI ISR does not.  Add the offset manually so the same 

+	ISR return code can be used in both cases. */

+	__asm volatile ( "ADD		LR, LR, #4" );

+

+	/* Perform the context switch.  First save the context of the current task. */

+	portSAVE_CONTEXT();

+

+	/* Find the highest priority task that is ready to run. */

+	__asm volatile ( "bl vTaskSwitchContext" );

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();	

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The ISR used for the scheduler tick.

+ */

+void vTickISR( void ) __attribute__((naked));

+void vTickISR( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT();	

+

+	/* Increment the RTOS tick count, then look for the highest priority 

+	task that is ready to run. */

+	__asm volatile( "bl vTaskIncrementTick" );

+

+	#if configUSE_PREEMPTION == 1

+		__asm volatile( "bl vTaskSwitchContext" );

+	#endif

+

+	/* Ready for the next interrupt. */

+	T0_IR = portTIMER_MATCH_ISR_BIT;

+	VICVectAddr = portCLEAR_VIC_INTERRUPT;

+	

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions here to

+ * ensure a switch to ARM mode.  When THUMB_INTERWORK is not defined then

+ * the utilities are defined as macros in portmacro.h - as per other ports.

+ */

+#ifdef THUMB_INTERWORK

+

+	void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	void vPortDisableInterruptsFromThumb( void )

+	{

+		__asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.						*/

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+			

+	void vPortEnableInterruptsFromThumb( void )

+	{

+		__asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/	

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/	

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.							*/	

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/	

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+

+#endif /* THUMB_INTERWORK */

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	__asm volatile ( 

+		"STMDB	SP!, {R0}			\n\t"	/* Push R0.								*/

+		"MRS	R0, CPSR			\n\t"	/* Get CPSR.							*/

+		"ORR	R0, R0, #0xC0		\n\t"	/* Disable IRQ, FIQ.					*/

+		"MSR	CPSR, R0			\n\t"	/* Write back modified value.			*/

+		"LDMIA	SP!, {R0}" );				/* Pop R0.								*/

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL().					*/

+			__asm volatile ( 

+				"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	

+				"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	

+				"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	

+				"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	

+				"LDMIA	SP!, {R0}" );			/* Pop R0.						*/

+		}

+	}

+}

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portmacro.h
new file mode 100644
index 0000000..ee6b6cc
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC2000/portmacro.h
@@ -0,0 +1,261 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portNOP()					__asm volatile ( "NOP" );

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+

+/*

+ * portRESTORE_CONTEXT, portRESTORE_CONTEXT, portENTER_SWITCHING_ISR

+ * and portEXIT_SWITCHING_ISR can only be called from ARM mode, but

+ * are included here for efficiency.  An attempt to call one from

+ * THUMB mode code will result in a compile time error.

+ */

+

+#define portRESTORE_CONTEXT()											\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Set the LR to the task stack. */									\

+	__asm volatile (													\

+	"LDR		R0, =pxCurrentTCB								\n\t"	\

+	"LDR		R0, [R0]										\n\t"	\

+	"LDR		LR, [R0]										\n\t"	\

+																		\

+	/* The critical nesting depth is the first item on the stack. */	\

+	/* Load it into the ulCriticalNesting variable. */					\

+	"LDR		R0, =ulCriticalNesting							\n\t"	\

+	"LDMFD	LR!, {R1}											\n\t"	\

+	"STR		R1, [R0]										\n\t"	\

+																		\

+	/* Get the SPSR from the stack. */									\

+	"LDMFD	LR!, {R0}											\n\t"	\

+	"MSR		SPSR, R0										\n\t"	\

+																		\

+	/* Restore all system mode registers for the task. */				\

+	"LDMFD	LR, {R0-R14}^										\n\t"	\

+	"NOP														\n\t"	\

+																		\

+	/* Restore the return address. */									\

+	"LDR		LR, [LR, #+60]									\n\t"	\

+																		\

+	/* And return - correcting the offset in the LR to obtain the */	\

+	/* correct address. */												\

+	"SUBS	PC, LR, #4											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+/*-----------------------------------------------------------*/

+

+#define portSAVE_CONTEXT()												\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Push R0 as we are going to use the register. */					\

+	__asm volatile (													\

+	"STMDB	SP!, {R0}											\n\t"	\

+																		\

+	/* Set R0 to point to the task stack pointer. */					\

+	"STMDB	SP,{SP}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	SP, SP, #4											\n\t"	\

+	"LDMIA	SP!,{R0}											\n\t"	\

+																		\

+	/* Push the return address onto the stack. */						\

+	"STMDB	R0!, {LR}											\n\t"	\

+																		\

+	/* Now we have saved LR we can use it instead of R0. */				\

+	"MOV	LR, R0												\n\t"	\

+																		\

+	/* Pop R0 so we can save it onto the system mode stack. */			\

+	"LDMIA	SP!, {R0}											\n\t"	\

+																		\

+	/* Push all the system mode registers onto the task stack. */		\

+	"STMDB	LR,{R0-LR}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	LR, LR, #60											\n\t"	\

+																		\

+	/* Push the SPSR onto the task stack. */							\

+	"MRS	R0, SPSR											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	"LDR	R0, =ulCriticalNesting								\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	/* Store the new top of stack for the task. */						\

+	"LDR	R0, =pxCurrentTCB									\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STR	LR, [R0]											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR()		vTaskSwitchContext()

+#define portYIELD()					__asm volatile ( "SWI 0" )

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions in 

+ * portISR.c to ensure a switch to ARM mode.  When THUMB_INTERWORK is not 

+ * defined then the utilities are defined as macros here - as per other ports.

+ */

+

+#ifdef THUMB_INTERWORK

+

+	extern void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	extern void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()

+	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

+	

+#else

+

+	#define portDISABLE_INTERRUPTS()											\

+		__asm volatile (														\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.			*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+			

+	#define portENABLE_INTERRUPTS()												\

+		__asm volatile (														\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+

+#endif /* THUMB_INTERWORK */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/port.c b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/port.c
new file mode 100644
index 0000000..f7a031f
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/port.c
@@ -0,0 +1,272 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM7 port.

+ *

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in this file.  The ISR routines, which can only be compiled

+ * to ARM mode are contained in portISR.c.

+ *----------------------------------------------------------*/

+

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+#define portNO_CRITICAL_SECTION_NESTING	( ( portSTACK_TYPE ) 0 )

+

+/* Constants required to setup the tick ISR. */

+#define portENABLE_TIMER                ( ( unsigned portCHAR ) 0x01 )

+#define portPRESCALE_VALUE              0x00

+#define portINTERRUPT_ON_MATCH          ( ( unsigned portLONG ) 0x01 )

+#define portRESET_COUNT_ON_MATCH        ( ( unsigned portLONG ) 0x02 )

+

+/* Constants required to setup the VIC for the tick ISR. */

+#define portTIMER_VIC_CHANNEL           ( ( unsigned portLONG ) 0x0004 )

+#define portTIMER_VIC_CHANNEL_BIT       ( ( unsigned portLONG ) 0x0010 )

+#define portTIMER_VIC_ENABLE            ( ( unsigned portLONG ) 0x0020 )

+

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * The scheduler can only be started from ARM mode, so 

+ * vPortISRStartFirstSTask() is defined in portISR.c. 

+ */

+extern void vPortISRStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+	

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The last thing onto the stack is the status register, which is set for

+	system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00 )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+

+	pxTopOfStack--;

+

+	/* Some optimisation levels use the stack differently to others.  This 

+	means the interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_SECTION_NESTING;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortISRStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the timer 0 to generate the tick interrupts at the required frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+unsigned portLONG ulCompareMatch;

+

+	PCLKSEL0 = (PCLKSEL0 & (~(0x3<<2))) | (0x01 << 2);

+	T0TCR  = 2;         /* Stop and reset the timer */

+	T0CTCR = 0;         /* Timer mode               */

+	

+	/* A 1ms tick does not require the use of the timer prescale.  This is

+	defaulted to zero but can be used if necessary. */

+	T0PR = portPRESCALE_VALUE;

+

+	/* Calculate the match value required for our wanted tick rate. */

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* Protect against divide by zero.  Using an if() statement still results

+	in a warning - hence the #if. */

+	#if portPRESCALE_VALUE != 0

+	{

+		ulCompareMatch /= ( portPRESCALE_VALUE + 1 );

+	}

+	#endif

+	T0MR1 = ulCompareMatch;

+

+	/* Generate tick with timer 0 compare match. */

+	T0MCR  = (3 << 3);  /* Reset timer on match and generate interrupt */

+

+	/* Setup the VIC for the timer. */

+	VICIntEnable = 0x00000010;

+	

+	/* The ISR installed depends on whether the preemptive or cooperative

+	scheduler is being used. */

+	#if configUSE_PREEMPTION == 1

+	{

+		extern void ( vPreemptiveTick )( void );

+		VICVectAddr4 = ( portLONG ) vPreemptiveTick;

+	}

+	#else

+	{

+		extern void ( vNonPreemptiveTick )( void );

+		VICVectAddr4 = ( portLONG ) vNonPreemptiveTick;

+	}

+	#endif

+

+	VICVectCntl4 = 1;

+

+	/* Start the timer - interrupts are disabled when this function is called

+	so it is okay to do this here. */

+	T0TCR = portENABLE_TIMER;

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portISR.c b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portISR.c
new file mode 100644
index 0000000..39cc742
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portISR.c
@@ -0,0 +1,251 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in port.c  The ISR routines, which can only be compiled

+ * to ARM mode, are contained in this file.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to handle interrupts. */

+#define portTIMER_MATCH_ISR_BIT		( ( unsigned portCHAR ) 0x01 )

+#define portCLEAR_VIC_INTERRUPT		( ( unsigned portLONG ) 0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING		( ( unsigned portLONG ) 0 )

+volatile unsigned portLONG ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* ISR to handle manual context switches (from a call to taskYIELD()). */

+void vPortYieldProcessor( void ) __attribute__((interrupt("SWI"), naked));

+

+/* 

+ * The scheduler can only be started from ARM mode, hence the inclusion of this

+ * function here.

+ */

+void vPortISRStartFirstTask( void );

+/*-----------------------------------------------------------*/

+

+void vPortISRStartFirstTask( void )

+{

+	/* Simply start the scheduler.  This is included here as it can only be

+	called from ARM mode. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Called by portYIELD() or taskYIELD() to manually force a context switch.

+ *

+ * When a context switch is performed from the task level the saved task 

+ * context is made to look as if it occurred from within the tick ISR.  This

+ * way the same restore context function can be used when restoring the context

+ * saved from the ISR or that saved from a call to vPortYieldProcessor.

+ */

+void vPortYieldProcessor( void )

+{

+	/* Within an IRQ ISR the link register has an offset from the true return 

+	address, but an SWI ISR does not.  Add the offset manually so the same 

+	ISR return code can be used in both cases. */

+	__asm volatile ( "ADD		LR, LR, #4" );

+

+	/* Perform the context switch.  First save the context of the current task. */

+	portSAVE_CONTEXT();

+

+	/* Find the highest priority task that is ready to run. */

+	__asm volatile( "bl			vTaskSwitchContext" );

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();	

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+

+

+#if configUSE_PREEMPTION == 0

+

+	/* The cooperative scheduler requires a normal IRQ service routine to 

+	simply increment the system tick. */

+	void vNonPreemptiveTick( void ) __attribute__ ((interrupt ("IRQ")));

+	void vNonPreemptiveTick( void )

+	{	

+		vTaskIncrementTick();

+		T0IR = 2;

+		VICVectAddr = portCLEAR_VIC_INTERRUPT;

+	}

+

+#else

+

+	/* The preemptive scheduler is defined as "naked" as the full context is

+	saved on entry as part of the context switch. */

+	void vPreemptiveTick( void ) __attribute__((naked));

+	void vPreemptiveTick( void )

+	{

+		/* Save the context of the interrupted task. */

+		portSAVE_CONTEXT();	

+

+		/* Increment the RTOS tick count, then look for the highest priority 

+		task that is ready to run. */

+		__asm volatile( "bl vTaskIncrementTick" );

+		__asm volatile( "bl vTaskSwitchContext" );

+

+		/* Ready for the next interrupt. */

+		T0IR = 2;

+		VICVectAddr = portCLEAR_VIC_INTERRUPT;

+		

+		/* Restore the context of the new task. */

+		portRESTORE_CONTEXT();

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions here to

+ * ensure a switch to ARM mode.  When THUMB_INTERWORK is not defined then

+ * the utilities are defined as macros in portmacro.h - as per other ports.

+ */

+#ifdef THUMB_INTERWORK

+

+	void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	void vPortDisableInterruptsFromThumb( void )

+	{

+		__asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.						*/

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+			

+	void vPortEnableInterruptsFromThumb( void )

+	{

+		__asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/	

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/	

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.							*/	

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/	

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+

+#endif /* THUMB_INTERWORK */

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	__asm volatile ( 

+		"STMDB	SP!, {R0}			\n\t"	/* Push R0.								*/

+		"MRS	R0, CPSR			\n\t"	/* Get CPSR.							*/

+		"ORR	R0, R0, #0xC0		\n\t"	/* Disable IRQ, FIQ.					*/

+		"MSR	CPSR, R0			\n\t"	/* Write back modified value.			*/

+		"LDMIA	SP!, {R0}" );				/* Pop R0.								*/

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL().					*/

+			__asm volatile ( 

+				"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	

+				"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	

+				"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	

+				"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	

+				"LDMIA	SP!, {R0}" );			/* Pop R0.						*/

+		}

+	}

+}

diff --git a/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portmacro.h
new file mode 100644
index 0000000..a607d21
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM7_LPC23xx/portmacro.h
@@ -0,0 +1,284 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+	Changes from V3.2.3

+	

+	+ Modified portENTER_SWITCHING_ISR() to allow use with GCC V4.0.1.

+

+	Changes from V3.2.4

+

+	+ Removed the use of the %0 parameter within the assembler macros and 

+	  replaced them with hard coded registers.  This will ensure the

+	  assembler does not select the link register as the temp register as

+	  was occasionally happening previously.

+

+	+ The assembler statements are now included in a single asm block rather

+	  than each line having its own asm block.

+

+	Changes from V4.5.0

+

+	+ Removed the portENTER_SWITCHING_ISR() and portEXIT_SWITCHING_ISR() macros

+	  and replaced them with portYIELD_FROM_ISR() macro.  Application code 

+	  should now make use of the portSAVE_CONTEXT() and portRESTORE_CONTEXT()

+	  macros as per the V4.5.1 demo code.

+*/

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portNOP()					__asm volatile ( "NOP" );

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+

+/*

+ * portRESTORE_CONTEXT, portRESTORE_CONTEXT, portENTER_SWITCHING_ISR

+ * and portEXIT_SWITCHING_ISR can only be called from ARM mode, but

+ * are included here for efficiency.  An attempt to call one from

+ * THUMB mode code will result in a compile time error.

+ */

+

+#define portRESTORE_CONTEXT()											\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Set the LR to the task stack. */									\

+	__asm volatile (													\

+	"LDR		R0, =pxCurrentTCB								\n\t"	\

+	"LDR		R0, [R0]										\n\t"	\

+	"LDR		LR, [R0]										\n\t"	\

+																		\

+	/* The critical nesting depth is the first item on the stack. */	\

+	/* Load it into the ulCriticalNesting variable. */					\

+	"LDR		R0, =ulCriticalNesting							\n\t"	\

+	"LDMFD	LR!, {R1}											\n\t"	\

+	"STR		R1, [R0]										\n\t"	\

+																		\

+	/* Get the SPSR from the stack. */									\

+	"LDMFD	LR!, {R0}											\n\t"	\

+	"MSR		SPSR, R0										\n\t"	\

+																		\

+	/* Restore all system mode registers for the task. */				\

+	"LDMFD	LR, {R0-R14}^										\n\t"	\

+	"NOP														\n\t"	\

+																		\

+	/* Restore the return address. */									\

+	"LDR		LR, [LR, #+60]									\n\t"	\

+																		\

+	/* And return - correcting the offset in the LR to obtain the */	\

+	/* correct address. */												\

+	"SUBS	PC, LR, #4											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+/*-----------------------------------------------------------*/

+

+#define portSAVE_CONTEXT()												\

+{																		\

+extern volatile void * volatile pxCurrentTCB;							\

+extern volatile unsigned portLONG ulCriticalNesting;					\

+																		\

+	/* Push R0 as we are going to use the register. */					\

+	__asm volatile (													\

+	"STMDB	SP!, {R0}											\n\t"	\

+																		\

+	/* Set R0 to point to the task stack pointer. */					\

+	"STMDB	SP,{SP}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	SP, SP, #4											\n\t"	\

+	"LDMIA	SP!,{R0}											\n\t"	\

+																		\

+	/* Push the return address onto the stack. */						\

+	"STMDB	R0!, {LR}											\n\t"	\

+																		\

+	/* Now we have saved LR we can use it instead of R0. */				\

+	"MOV	LR, R0												\n\t"	\

+																		\

+	/* Pop R0 so we can save it onto the system mode stack. */			\

+	"LDMIA	SP!, {R0}											\n\t"	\

+																		\

+	/* Push all the system mode registers onto the task stack. */		\

+	"STMDB	LR,{R0-LR}^											\n\t"	\

+	"NOP														\n\t"	\

+	"SUB	LR, LR, #60											\n\t"	\

+																		\

+	/* Push the SPSR onto the task stack. */							\

+	"MRS	R0, SPSR											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	"LDR	R0, =ulCriticalNesting								\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STMDB	LR!, {R0}											\n\t"	\

+																		\

+	/* Store the new top of stack for the task. */						\

+	"LDR	R0, =pxCurrentTCB									\n\t"	\

+	"LDR	R0, [R0]											\n\t"	\

+	"STR	LR, [R0]											\n\t"	\

+	);																	\

+	( void ) ulCriticalNesting;											\

+	( void ) pxCurrentTCB;												\

+}

+

+

+#define portYIELD_FROM_ISR()		vTaskSwitchContext()

+#define portYIELD()					__asm volatile ( "SWI 0" )

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions in 

+ * portISR.c to ensure a switch to ARM mode.  When THUMB_INTERWORK is not 

+ * defined then the utilities are defined as macros here - as per other ports.

+ */

+

+#ifdef THUMB_INTERWORK

+

+	extern void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	extern void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()

+	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

+	

+#else

+

+	#define portDISABLE_INTERRUPTS()											\

+		__asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.			*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+			

+	#define portENABLE_INTERRUPTS()												\

+		__asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+

+#endif /* THUMB_INTERWORK */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM0/port.c b/FreeRTOS/Source/portable/GCC/ARM_CM0/port.c
new file mode 100644
index 0000000..2f38ed1
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM0/port.c
@@ -0,0 +1,305 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM0 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portMIN_INTERRUPT_PRIORITY	( 255UL )

+#define portNVIC_PENDSV_PRI			( portMIN_INTERRUPT_PRIORITY << 16UL )

+#define portNVIC_SYSTICK_PRI		( portMIN_INTERRUPT_PRIORITY << 24UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void ) __attribute__ (( naked ));

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void ) __attribute__ (( naked ));

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+static void vPortStartFirstTask( void ) __attribute__ (( naked ));

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack -= 6;	/* LR, R12, R3..R1 */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8; /* R11..R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSVCHandler( void )

+{

+	__asm volatile (

+					"	ldr	r3, pxCurrentTCBConst2		\n" /* Restore the context. */

+					"	ldr r1, [r3]					\n" /* Use pxCurrentTCBConst to get the pxCurrentTCB address. */

+					"	ldr r0, [r1]					\n" /* The first item in pxCurrentTCB is the task top of stack. */

+					"	add r0, r0, #16					\n" /* Move to the high registers. */

+					"	ldmia r0!, {r4-r7}				\n" /* Pop the high registers. */

+					" 	mov r8, r4						\n"

+					" 	mov r9, r5						\n"

+					" 	mov r10, r6						\n"

+					" 	mov r11, r7						\n"

+					"									\n"

+					"	msr psp, r0						\n" /* Remember the new top of stack for the task. */

+					"									\n"

+					"	sub r0, r0, #32					\n" /* Go back for the low registers that are not automatically restored. */

+					" 	ldmia r0!, {r4-r7}              \n" /* Pop low registers.  */

+					"	mov r1, r14						\n" /* OR R14 with 0x0d. */

+					"	movs r0, #0x0d					\n"

+					"	orr r1, r0						\n"

+					"	bx r1							\n"

+					"									\n"

+					"	.align 2						\n"

+					"pxCurrentTCBConst2: .word pxCurrentTCB	\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+void vPortStartFirstTask( void )

+{

+	__asm volatile(

+					" movs r0, #0x00 	\n" /* Locate the top of stack. */

+					" ldr r0, [r0] 		\n"

+					" msr msp, r0		\n" /* Set the msp back to the start of the stack. */

+					" cpsie i			\n" /* Globally enable interrupts. */

+					" svc 0				\n" /* System call to start first task. */

+					" nop				\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV, CallSV and SysTick the same priroity as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+  /* It is unlikely that the CM0 port will require this function as there

+    is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*( portNVIC_INT_CTRL ) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+    portDISABLE_INTERRUPTS();

+    uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+    uxCriticalNesting--;

+    if( uxCriticalNesting == 0 )

+    {

+        portENABLE_INTERRUPTS();

+    }

+}

+/*-----------------------------------------------------------*/

+

+void xPortPendSVHandler( void )

+{

+	/* This is a naked function. */

+

+	__asm volatile

+	(

+	"	mrs r0, psp							\n"

+	"										\n"

+	"	ldr	r3, pxCurrentTCBConst			\n" /* Get the location of the current TCB. */

+	"	ldr	r2, [r3]						\n"

+	"										\n"

+	"	sub r0, r0, #32						\n" /* Make space for the remaining low registers. */

+	"	str r0, [r2]						\n" /* Save the new top of stack. */

+	"	stmia r0!, {r4-r7}					\n" /* Store the low registers that are not saved automatically. */

+	" 	mov r4, r8							\n" /* Store the high registers. */

+	" 	mov r5, r9							\n"

+	" 	mov r6, r10							\n"

+	" 	mov r7, r11							\n"

+	" 	stmia r0!, {r4-r7}              	\n"

+	"										\n"

+	"	push {r3, r14}						\n"

+	"	cpsid i								\n"

+	"	bl vTaskSwitchContext				\n"

+	"	cpsie i								\n"

+	"	pop {r2, r3}						\n" /* lr goes in r3. r2 now holds tcb pointer. */

+	"										\n"

+	"	ldr r1, [r2]						\n"

+	"	ldr r0, [r1]						\n" /* The first item in pxCurrentTCB is the task top of stack. */

+	"	add r0, r0, #16						\n" /* Move to the high registers. */

+	"	ldmia r0!, {r4-r7}					\n" /* Pop the high registers. */

+	" 	mov r8, r4							\n"

+	" 	mov r9, r5							\n"

+	" 	mov r10, r6							\n"

+	" 	mov r11, r7							\n"

+	"										\n"

+	"	msr psp, r0							\n" /* Remember the new top of stack for the task. */

+	"										\n"

+	"	sub r0, r0, #32						\n" /* Go back for the low registers that are not automatically restored. */

+	" 	ldmia r0!, {r4-r7}              	\n" /* Pop low registers.  */

+	"										\n"

+	"	bx r3								\n"

+	"										\n"

+	"	.align 2							\n"

+	"pxCurrentTCBConst: .word pxCurrentTCB	  "

+	);

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM0/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM_CM0/portmacro.h
new file mode 100644
index 0000000..e10b871
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM0/portmacro.h
@@ -0,0 +1,142 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+#define portYIELD()									vPortYieldFromISR()

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portSET_INTERRUPT_MASK()				__asm volatile 	( " cpsid i " )

+#define portCLEAR_INTERRUPT_MASK()				__asm volatile 	( " cpsie i " )

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+#define portDISABLE_INTERRUPTS()				portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()					portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3/port.c b/FreeRTOS/Source/portable/GCC/ARM_CM3/port.c
new file mode 100644
index 0000000..04faca2
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3/port.c
@@ -0,0 +1,301 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM3 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.4.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 255

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* The priority used by the kernel is assigned to a variable to make access

+from inline assembler easier. */

+const unsigned long ulKernelPriority = configKERNEL_INTERRUPT_PRIORITY;

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void ) __attribute__ (( naked ));

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void ) __attribute__ (( naked ));

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+static void prvPortStartFirstTask( void ) __attribute__ (( naked ));

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSVCHandler( void )

+{

+	__asm volatile (

+					"	ldr	r3, pxCurrentTCBConst2		\n" /* Restore the context. */

+					"	ldr r1, [r3]					\n" /* Use pxCurrentTCBConst to get the pxCurrentTCB address. */

+					"	ldr r0, [r1]					\n" /* The first item in pxCurrentTCB is the task top of stack. */

+					"	ldmia r0!, {r4-r11}				\n" /* Pop the registers that are not automatically saved on exception entry and the critical nesting count. */

+					"	msr psp, r0						\n" /* Restore the task stack pointer. */

+					"	mov r0, #0 						\n"

+					"	msr	basepri, r0					\n"

+					"	orr r14, #0xd					\n"

+					"	bx r14							\n"

+					"									\n"

+					"	.align 4						\n"

+					"pxCurrentTCBConst2: .word pxCurrentTCB\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+static void prvPortStartFirstTask( void )

+{

+	__asm volatile(

+					" ldr r0, =0xE000ED08 	\n" /* Use the NVIC offset register to locate the stack. */

+					" ldr r0, [r0] 			\n"

+					" ldr r0, [r0] 			\n"

+					" msr msp, r0			\n" /* Set the msp back to the start of the stack. */

+					" cpsie i				\n" /* Globally enable interrupts. */

+					" svc 0					\n" /* System call to start first task. */

+					" nop					\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  

+	See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html */

+	configASSERT( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+

+	/* Make PendSV, CallSV and SysTick the same priroity as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	prvPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM3 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortPendSVHandler( void )

+{

+	/* This is a naked function. */

+

+	__asm volatile

+	(

+	"	clrex								\n"

+	"	mrs r0, psp							\n"

+	"										\n"

+	"	ldr	r3, pxCurrentTCBConst			\n" /* Get the location of the current TCB. */

+	"	ldr	r2, [r3]						\n"

+	"										\n"

+	"	stmdb r0!, {r4-r11}					\n" /* Save the remaining registers. */

+	"	str r0, [r2]						\n" /* Save the new top of stack into the first member of the TCB. */

+	"										\n"

+	"	stmdb sp!, {r3, r14}				\n"

+	"	mov r0, %0							\n"

+	"	msr basepri, r0						\n"

+	"	bl vTaskSwitchContext				\n"

+	"	mov r0, #0							\n"

+	"	msr basepri, r0						\n"

+	"	ldmia sp!, {r3, r14}				\n"

+	"										\n"	/* Restore the context, including the critical nesting count. */

+	"	ldr r1, [r3]						\n"

+	"	ldr r0, [r1]						\n" /* The first item in pxCurrentTCB is the task top of stack. */

+	"	ldmia r0!, {r4-r11}					\n" /* Pop the registers. */

+	"	msr psp, r0							\n"

+	"	bx r14								\n"

+	"										\n"

+	"	.align 2							\n"

+	"pxCurrentTCBConst: .word pxCurrentTCB	\n"

+	::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY)

+	);

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM_CM3/portmacro.h
new file mode 100644
index 0000000..80e2d67
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3/portmacro.h
@@ -0,0 +1,173 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/* 

+ * Set basepri to portMAX_SYSCALL_INTERRUPT_PRIORITY without effecting other

+ * registers.  r0 is clobbered.

+ */ 

+#define portSET_INTERRUPT_MASK()						\

+	__asm volatile										\

+	(													\

+		"	mov r0, %0								\n"	\

+		"	msr basepri, r0							\n" \

+		::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY):"r0"	\

+	)

+	

+/*

+ * Set basepri back to 0 without effective other registers.

+ * r0 is clobbered.  FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+ * http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing.

+ */

+#define portCLEAR_INTERRUPT_MASK()			\

+	__asm volatile							\

+	(										\

+		"	mov r0, #0					\n"	\

+		"	msr basepri, r0				\n"	\

+		:::"r0"								\

+	)

+

+/* FAQ:  Setting BASEPRI to 0 in portCLEAR_INTERRUPT_MASK_FROM_ISR() is not a 

+bug.  Please see http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before 

+disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/port.c b/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/port.c
new file mode 100644
index 0000000..63062cd
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/port.c
@@ -0,0 +1,414 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+

+    http://www.FreeRTOS.org - Documentation, training, latest information,

+    license and contact details.

+

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell

+    the code with commercial support, indemnification, and middleware, under

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM3 port.

+ *

+ * This is a specialization for the Freescale Kxx series that uses

+ * LPTMR instead of SYSTICK to generate portTICKs.

+ *----------------------------------------------------------*/

+

+/* Configuration */

+#include "FreeRTOSConfig.h"

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.4.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 255

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* The priority used by the kernel is assigned to a variable to make access

+from inline assembler easier. */

+const unsigned long ulKernelPriority = configKERNEL_INTERRUPT_PRIORITY;

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void ) __attribute__ (( naked ));

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void ) __attribute__ (( naked ));

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+static void prvPortStartFirstTask( void ) __attribute__ (( naked ));

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSVCHandler( void )

+{

+	__asm volatile (

+					"	ldr	r3, pxCurrentTCBConst2		\n" /* Restore the context. */

+					"	ldr r1, [r3]					\n" /* Use pxCurrentTCBConst to get the pxCurrentTCB address. */

+					"	ldr r0, [r1]					\n" /* The first item in pxCurrentTCB is the task top of stack. */

+					"	ldmia r0!, {r4-r11}				\n" /* Pop the registers that are not automatically saved on exception entry and the critical nesting count. */

+					"	msr psp, r0						\n" /* Restore the task stack pointer. */

+					"	mov r0, #0 						\n"

+					"	msr	basepri, r0					\n"

+					"	orr r14, #0xd					\n"

+					"	bx r14							\n"

+					"									\n"

+					"	.align 4						\n"

+					"pxCurrentTCBConst2: .word pxCurrentTCB\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+static void prvPortStartFirstTask( void )

+{

+	__asm volatile(

+					" ldr r0, =0xE000ED08 	\n" /* Use the NVIC offset register to locate the stack. */

+					" ldr r0, [r0] 			\n"

+					" ldr r0, [r0] 			\n"

+					" msr msp, r0			\n" /* Set the msp back to the start of the stack. */

+					" cpsie i				\n" /* Globally enable interrupts. */

+					" svc 0					\n" /* System call to start first task. */

+					" nop					\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.

+	See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html */

+	configASSERT( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+

+	/* Make PendSV, CallSV and SysTick the same priroity as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	prvPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM3 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortPendSVHandler( void )

+{

+	/* This is a naked function. */

+

+	__asm volatile

+	(

+    "   clrex                               \n"

+	"	mrs r0, psp							\n"

+	"										\n"

+	"	ldr	r3, pxCurrentTCBConst			\n" /* Get the location of the current TCB. */

+	"	ldr	r2, [r3]						\n"

+	"										\n"

+	"	stmdb r0!, {r4-r11}					\n" /* Save the remaining registers. */

+	"	str r0, [r2]						\n" /* Save the new top of stack into the first member of the TCB. */

+	"										\n"

+	"	stmdb sp!, {r3, r14}				\n"

+	"	mov r0, %0							\n"

+	"	msr basepri, r0						\n"

+	"	bl vTaskSwitchContext				\n"

+	"	mov r0, #0							\n"

+	"	msr basepri, r0						\n"

+	"	ldmia sp!, {r3, r14}				\n"

+	"										\n"	/* Restore the context, including the critical nesting count. */

+	"	ldr r1, [r3]						\n"

+	"	ldr r0, [r1]						\n" /* The first item in pxCurrentTCB is the task top of stack. */

+	"	ldmia r0!, {r4-r11}					\n" /* Pop the registers. */

+	"	msr psp, r0							\n"

+	"	bx r14								\n"

+	"										\n"

+	"	.align 2							\n"

+	"pxCurrentTCBConst: .word pxCurrentTCB	\n"

+	::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY)

+	);

+}

+/*-----------------------------------------------------------*/

+

+/* Constants required to manipulate the LPTMR. */

+

+#define SIM_BASE				(0x40047000)

+#define SIM_REGISTER(r)			( ( volatile unsigned long *) (SIM_BASE+(r)) )

+#define portSIM_SOPT1			SIM_REGISTER( 0x0000 )

+#define portSIM_SCGC5			SIM_REGISTER( 0x1038 )

+

+#define SIM_SOPT1_OSC32KSEL_MASK	( ( (unsigned long) 0x3) << 18)

+#define SIM_SOPT1_OSC32KSEL_RTC	( ( (unsigned long) 0x2) << 18)

+#define SIM_SOPT1_OSC32KSEL_LPO	( ( (unsigned long) 0x3) << 18)

+

+#define SIM_SCGC5_LPTIMER		( ( (unsigned long) 1) << 0)

+

+#define LPT_BASE				(0x40040000)

+#define LPT_REGISTER(r)			( ( volatile unsigned long *) (LPT_BASE+(r)) )

+#define portLPTMR_CSR			LPT_REGISTER( 0x00 )

+#define portLPTMR_PSR			LPT_REGISTER( 0x04 )

+#define portLPTMR_CMR			LPT_REGISTER( 0x08 )

+#define portLPTMR_CNR			LPT_REGISTER( 0x0C )

+

+#define LPTMR_CSR_TEN			( ( (unsigned long) 1) << 0 )

+#define LPTMR_CSR_TIE			( ( (unsigned long) 1) << 6 )

+#define LPTMR_CSR_TCF			( ( (unsigned long) 1) << 7 )

+

+#define LPTMR_PSR_PRESCALE_DIV_2	( ( (unsigned long) 0x0) << 3 )

+#define LPTMR_PSR_PBYP	        ( ( (unsigned long) 0x1) << 2 )

+#define LPTMR_PSR_PCS_ERCLK32K	( ( (unsigned long) 0x2) << 0 )

+#define LPTMR_PSR_PCS_LPO	    ( ( (unsigned long) 0x1) << 0 )

+

+

+/* The interrupt vector number for LPTMR differs between K24 and K60:

+   K60 is 85 (0x55) = 2*32 + 21,  K24 is 58 (0x3A) = 1*32 + 26 */

+

+#ifdef KINETIS_K24

+#define LPTMR_ISR			(0x3A)

+#else

+#ifdef KINETIS_K60

+#define LPTMR_ISR			(0x55)

+#else

+#error No recognized KINETIS_<MCU>

+#endif

+#endif

+

+#define NVIC_ISER				(0xe000e100)

+#define portNVIC_ISERW			( ( volatile unsigned long *) (NVIC_ISER+4*(LPTMR_ISR/32)) )

+#define NVIC_ISERW_LPTMR		( ( (unsigned long) 1) << (LPTMR_ISR%32) )

+

+#define NVIC_PRI				(0xe000e400)

+#define portNVIC_LPTMR_PRI		( ( volatile unsigned char *) (NVIC_PRI+LPTMR_ISR) )

+

+void lptmr_isr( void );

+void lptmr_isr( void )

+{

+	unsigned long ulDummy;

+

+	*(portLPTMR_CSR) |= LPTMR_CSR_TCF;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the LPTMR to generate the tick interrupts at the required

+ * frequency.  Assumes 32kHz RTC clock already enabled.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	unsigned long ulDummy;

+	unsigned long sopt1;

+

+	/* Enable access to LPTMR */

+	*(portSIM_SCGC5) |= SIM_SCGC5_LPTIMER;

+

+	*(portNVIC_LPTMR_PRI) = configKERNEL_INTERRUPT_PRIORITY;

+

+	/* Route the 32kHz RTC_XTAL to ERCLK32K */

+	sopt1 = *(portSIM_SOPT1);

+	sopt1 &= ~SIM_SOPT1_OSC32KSEL_MASK;

+	sopt1 |=  SIM_SOPT1_OSC32KSEL_RTC;

+	*(portSIM_SOPT1) = sopt1;

+

+	/* Configure LPTMR to interrupt at the requested rate. */

+	*(portLPTMR_CSR) &= ~LPTMR_CSR_TEN;

+	ulDummy = *(portLPTMR_CSR); (void)ulDummy;

+	*(portLPTMR_CSR) |= (LPTMR_CSR_TCF | LPTMR_CSR_TIE);

+	*(portLPTMR_PSR) =  (LPTMR_PSR_PRESCALE_DIV_2 | LPTMR_PSR_PCS_ERCLK32K);

+	*(portLPTMR_CMR) = (32768/1024)/2 - 1;

+	*(portNVIC_ISERW) |= NVIC_ISERW_LPTMR;

+	*(portLPTMR_CSR) |=  LPTMR_CSR_TEN;

+}

+/*-----------------------------------------------------------*/

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the LPTMR to generate the tick interrupts at the required

+ * frequency.  Use the internal 1K LPO clock for Diags

+ */

+void prvSetupTimerInterruptLpo( void );

+void prvSetupTimerInterruptLpo( void )

+{

+	unsigned long ulDummy;

+	unsigned long sopt1;

+

+	/* Enable access to LPTMR */

+	*(portSIM_SCGC5) |= SIM_SCGC5_LPTIMER;

+

+	*(portNVIC_LPTMR_PRI) = configKERNEL_INTERRUPT_PRIORITY;

+

+	/* Route the LPO 1kHZ to ERCLK32K */

+	sopt1 = *(portSIM_SOPT1);

+	sopt1 &= ~SIM_SOPT1_OSC32KSEL_MASK;

+	sopt1 |=  SIM_SOPT1_OSC32KSEL_LPO;

+	*(portSIM_SOPT1) = sopt1;

+

+	/* Configure LPTMR to interrupt at the requested rate. */

+	*(portLPTMR_CSR) &= ~LPTMR_CSR_TEN;

+	ulDummy = *(portLPTMR_CSR); (void)ulDummy;

+	*(portLPTMR_CSR) |= (LPTMR_CSR_TCF | LPTMR_CSR_TIE);

+	*(portLPTMR_PSR) = (LPTMR_PSR_PBYP | LPTMR_PSR_PCS_LPO);

+	*(portLPTMR_CMR) = 0;

+	*(portNVIC_ISERW) |= NVIC_ISERW_LPTMR;

+	*(portLPTMR_CSR) |=  LPTMR_CSR_TEN;

+

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/portmacro.h
new file mode 100644
index 0000000..d14e697
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3_KXX/portmacro.h
@@ -0,0 +1,191 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+

+/*

+ * Additions to deal better with TICK_RATE_HZ values that are not

+ * exact divisors of 1000 for portTICK_RATE_MS (above).

+ *

+ * For the Kinetis LPTMR with 32kHz clock, interrupts happen at 1024 Hz.

+ *   1024:1000 is 128:125 and 128 = 2**7.

+ * To avoid overflow when converting large values, we observe that

+ *  (1) 33554375*128 = 34359680*125

+ *  (2) the produces above are less than 2**32

+ * XXXehs: Need to parameterize this ratio in the local config file.

+ */

+#define portTICKS_TO_MSEC(n) \

+    ((n) >= 34359680U ? ((n)/34359680U)*33554375U + ((((n)%34359680U)*125)>>7) \

+                      : ((n)*125)>>7)

+#define portMSEC_TO_TICKS(n) \

+    ((n) >= 33554375U ? ((n)/33554375U)*34359680U + (((n)%33554375U)<<7)/125 \

+                      : ((n)<<7)/125)

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/* 

+ * Set basepri to portMAX_SYSCALL_INTERRUPT_PRIORITY without effecting other

+ * registers.  r0 is clobbered.

+ */ 

+#define portSET_INTERRUPT_MASK()						\

+	__asm volatile										\

+	(													\

+		"	mov r0, %0								\n"	\

+		"	msr basepri, r0							\n" \

+		::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY):"r0"	\

+	)

+	

+/*

+ * Set basepri back to 0 without effective other registers.

+ * r0 is clobbered.  FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+ * http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing.

+ */

+#define portCLEAR_INTERRUPT_MASK()			\

+	__asm volatile							\

+	(										\

+		"	mov r0, #0					\n"	\

+		"	msr basepri, r0				\n"	\

+		:::"r0"								\

+	)

+

+/* FAQ:  Setting BASEPRI to 0 in portCLEAR_INTERRUPT_MASK_FROM_ISR() is not a 

+bug.  Please see http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before 

+disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/port.c b/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/port.c
new file mode 100644
index 0000000..6bd0159
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/port.c
@@ -0,0 +1,1099 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+

+    http://www.FreeRTOS.org - Documentation, training, latest information,

+    license and contact details.

+

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell

+    the code with commercial support, indemnification, and middleware, under

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM3 port.

+ *----------------------------------------------------------*/

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+#include "queue.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* Constants required to access and manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL					( ( volatile unsigned long * ) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD					( ( volatile unsigned long * ) 0xe000e014 )

+#define portNVIC_SYSPRI2						( ( volatile unsigned long * ) 0xe000ed20 )

+#define portNVIC_SYSPRI1						( ( volatile unsigned long * ) 0xe000ed1c )

+#define portNVIC_SYS_CTRL_STATE					( ( volatile unsigned long * ) 0xe000ed24 )

+#define portNVIC_MEM_FAULT_ENABLE				( 1UL << 16UL )

+

+/* Constants required to access and manipulate the MPU. */

+#define portMPU_TYPE							( ( volatile unsigned long * ) 0xe000ed90 )

+#define portMPU_REGION_BASE_ADDRESS				( ( volatile unsigned long * ) 0xe000ed9C )

+#define portMPU_REGION_ATTRIBUTE				( ( volatile unsigned long * ) 0xe000edA0 )

+#define portMPU_CTRL							( ( volatile unsigned long * ) 0xe000ed94 )

+#define portEXPECTED_MPU_TYPE_VALUE				( 8UL << 8UL ) /* 8 regions, unified. */

+#define portMPU_ENABLE							( 0x01UL )

+#define portMPU_BACKGROUND_ENABLE				( 1UL << 2UL )

+#define portPRIVILEGED_EXECUTION_START_ADDRESS	( 0UL )

+#define portMPU_REGION_VALID					( 0x10UL )

+#define portMPU_REGION_ENABLE					( 0x01UL )

+#define portPERIPHERALS_START_ADDRESS			0x40000000UL

+#define portPERIPHERALS_END_ADDRESS				0x5FFFFFFFUL

+

+/* Constants required to access and manipulate the SysTick. */

+#define portNVIC_SYSTICK_CLK					( 0x00000004UL )

+#define portNVIC_SYSTICK_INT					( 0x00000002UL )

+#define portNVIC_SYSTICK_ENABLE					( 0x00000001UL )

+#define portNVIC_PENDSV_PRI						( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16UL )

+#define portNVIC_SYSTICK_PRI					( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24UL )

+#define portNVIC_SVC_PRI						( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR						( 0x01000000 )

+#define portINITIAL_CONTROL_IF_UNPRIVILEGED		( 0x03 )

+#define portINITIAL_CONTROL_IF_PRIVILEGED		( 0x02 )

+

+/* Offsets in the stack to the parameters when inside the SVC handler. */

+#define portOFFSET_TO_PC						( 6 )

+

+/* Set the privilege level to user mode if xRunningPrivileged is false. */

+#define portRESET_PRIVILEGE( xRunningPrivileged ) if( xRunningPrivileged != pdTRUE ) __asm volatile ( " mrs r0, control \n orr r0, #1 \n msr control, r0" :::"r0" )

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable.  Note this is not saved as part of the task context as context

+switches can only occur when uxCriticalNesting is zero. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Configure a number of standard MPU regions that are used by all tasks.

+ */

+static void prvSetupMPU( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Return the smallest MPU region size that a given number of bytes will fit

+ * into.  The region size is returned as the value that should be programmed

+ * into the region attribute register for that region.

+ */

+static unsigned long prvGetMPURegionSizeSetting( unsigned long ulActualSizeInBytes ) PRIVILEGED_FUNCTION;

+

+/*

+ * Checks to see if being called from the context of an unprivileged task, and

+ * if so raises the privilege level and returns false - otherwise does nothing

+ * other than return true.

+ */

+static portBASE_TYPE prvRaisePrivilege( void ) __attribute__(( naked ));

+

+/*

+ * Standard FreeRTOS exception handlers.

+ */

+void xPortPendSVHandler( void ) __attribute__ (( naked )) PRIVILEGED_FUNCTION;

+void xPortSysTickHandler( void )  __attribute__ ((optimize("3"))) PRIVILEGED_FUNCTION;

+void vPortSVCHandler( void ) __attribute__ (( naked )) PRIVILEGED_FUNCTION;

+

+/*

+ * Starts the scheduler by restoring the context of the first task to run.

+ */

+static void prvRestoreContextOfFirstTask( void ) __attribute__(( naked )) PRIVILEGED_FUNCTION;

+

+/*

+ * C portion of the SVC handler.  The SVC handler is split between an asm entry

+ * and a C wrapper for simplicity of coding and maintenance.

+ */

+static void prvSVCHandler( unsigned long *pulRegisters ) __attribute__(( noinline )) PRIVILEGED_FUNCTION;

+

+/*

+ * Prototypes for all the MPU wrappers.

+ */

+signed portBASE_TYPE MPU_xTaskGenericCreate( pdTASK_CODE pvTaskCode, const signed char * const pcName, unsigned short usStackDepth, void *pvParameters, unsigned portBASE_TYPE uxPriority, xTaskHandle *pxCreatedTask, portSTACK_TYPE *puxStackBuffer, const xMemoryRegion * const xRegions );

+void MPU_vTaskAllocateMPURegions( xTaskHandle xTask, const xMemoryRegion * const xRegions );

+void MPU_vTaskDelete( xTaskHandle pxTaskToDelete );

+void MPU_vTaskDelayUntil( portTickType * const pxPreviousWakeTime, portTickType xTimeIncrement );

+void MPU_vTaskDelay( portTickType xTicksToDelay );

+unsigned portBASE_TYPE MPU_uxTaskPriorityGet( xTaskHandle pxTask );

+void MPU_vTaskPrioritySet( xTaskHandle pxTask, unsigned portBASE_TYPE uxNewPriority );

+void MPU_vTaskSuspend( xTaskHandle pxTaskToSuspend );

+signed portBASE_TYPE MPU_xTaskIsTaskSuspended( xTaskHandle xTask );

+void MPU_vTaskResume( xTaskHandle pxTaskToResume );

+void MPU_vTaskSuspendAll( void );

+signed portBASE_TYPE MPU_xTaskResumeAll( void );

+portTickType MPU_xTaskGetTickCount( void );

+unsigned portBASE_TYPE MPU_uxTaskGetNumberOfTasks( void );

+void MPU_vTaskList( signed char *pcWriteBuffer );

+void MPU_vTaskGetRunTimeStats( signed char *pcWriteBuffer );

+void MPU_vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxTagValue );

+pdTASK_HOOK_CODE MPU_xTaskGetApplicationTaskTag( xTaskHandle xTask );

+portBASE_TYPE MPU_xTaskCallApplicationTaskHook( xTaskHandle xTask, void *pvParameter );

+unsigned portBASE_TYPE MPU_uxTaskGetStackHighWaterMark( xTaskHandle xTask );

+xTaskHandle MPU_xTaskGetCurrentTaskHandle( void );

+portBASE_TYPE MPU_xTaskGetSchedulerState( void );

+xQueueHandle MPU_xQueueGenericCreate( unsigned portBASE_TYPE uxQueueLength, unsigned portBASE_TYPE uxItemSize, unsigned char ucQueueType );

+signed portBASE_TYPE MPU_xQueueGenericSend( xQueueHandle xQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition );

+unsigned portBASE_TYPE MPU_uxQueueMessagesWaiting( const xQueueHandle pxQueue );

+signed portBASE_TYPE MPU_xQueueGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking );

+xQueueHandle MPU_xQueueCreateMutex( void );

+xQueueHandle MPU_xQueueCreateCountingSemaphore( unsigned portBASE_TYPE uxCountValue, unsigned portBASE_TYPE uxInitialCount );

+portBASE_TYPE MPU_xQueueTakeMutexRecursive( xQueueHandle xMutex, portTickType xBlockTime );

+portBASE_TYPE MPU_xQueueGiveMutexRecursive( xQueueHandle xMutex );

+signed portBASE_TYPE MPU_xQueueAltGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition );

+signed portBASE_TYPE MPU_xQueueAltGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking );

+void MPU_vQueueAddToRegistry( xQueueHandle xQueue, signed char *pcName );

+void MPU_vQueueDelete( xQueueHandle xQueue );

+void *MPU_pvPortMalloc( size_t xSize );

+void MPU_vPortFree( void *pv );

+void MPU_vPortInitialiseBlocks( void );

+size_t MPU_xPortGetFreeHeapSize( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters, portBASE_TYPE xRunPrivileged )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 9;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	if( xRunPrivileged == pdTRUE )

+	{

+		*pxTopOfStack = portINITIAL_CONTROL_IF_PRIVILEGED;

+	}

+	else

+	{

+		*pxTopOfStack = portINITIAL_CONTROL_IF_UNPRIVILEGED;

+	}

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSVCHandler( void )

+{

+	/* Assumes psp was in use. */

+	__asm volatile

+	(

+		#ifndef USE_PROCESS_STACK	/* Code should not be required if a main() is using the process stack. */

+			"	tst lr, #4						\n"

+			"	ite eq							\n"

+			"	mrseq r0, msp					\n"

+			"	mrsne r0, psp					\n"

+		#else

+			"	mrs r0, psp						\n"

+		#endif

+			"	b %0							\n"

+			::"i"(prvSVCHandler):"r0"

+	);

+}

+/*-----------------------------------------------------------*/

+

+static void prvSVCHandler(	unsigned long *pulParam )

+{

+unsigned char ucSVCNumber;

+

+	/* The stack contains: r0, r1, r2, r3, r12, r14, the return address and

+	xPSR.  The first argument (r0) is pulParam[ 0 ]. */

+	ucSVCNumber = ( ( unsigned char * ) pulParam[ portOFFSET_TO_PC ] )[ -2 ];

+	switch( ucSVCNumber )

+	{

+		case portSVC_START_SCHEDULER	:	*(portNVIC_SYSPRI1) |= portNVIC_SVC_PRI;

+											prvRestoreContextOfFirstTask();

+											break;

+

+		case portSVC_YIELD				:	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+											break;

+

+		case portSVC_RAISE_PRIVILEGE	:	__asm volatile

+											(

+												"	mrs r1, control		\n" /* Obtain current control value. */

+												"	bic r1, #1			\n" /* Set privilege bit. */

+												"	msr control, r1		\n" /* Write back new control value. */

+												:::"r1"

+											);

+											break;

+

+		default							:	/* Unknown SVC call. */

+											break;

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvRestoreContextOfFirstTask( void )

+{

+	__asm volatile

+	(

+		"	ldr r0, =0xE000ED08				\n" /* Use the NVIC offset register to locate the stack. */

+		"	ldr r0, [r0]					\n"

+		"	ldr r0, [r0]					\n"

+		"	msr msp, r0						\n" /* Set the msp back to the start of the stack. */

+		"	ldr	r3, pxCurrentTCBConst2		\n" /* Restore the context. */

+		"	ldr r1, [r3]					\n"

+		"	ldr r0, [r1]					\n" /* The first item in the TCB is the task top of stack. */

+		"	add r1, r1, #4					\n" /* Move onto the second item in the TCB... */

+		"	ldr r2, =0xe000ed9c				\n" /* Region Base Address register. */

+		"	ldmia r1!, {r4-r11}				\n" /* Read 4 sets of MPU registers. */

+		"	stmia r2!, {r4-r11}				\n" /* Write 4 sets of MPU registers. */

+		"	ldmia r0!, {r3, r4-r11}			\n" /* Pop the registers that are not automatically saved on exception entry. */

+		"	msr control, r3					\n"

+		"	msr psp, r0						\n" /* Restore the task stack pointer. */

+		"	mov r0, #0						\n"

+		"	msr	basepri, r0					\n"

+		"	ldr r14, =0xfffffffd			\n" /* Load exec return code. */

+		"	bx r14							\n"

+		"									\n"

+		"	.align 2						\n"

+		"pxCurrentTCBConst2: .word pxCurrentTCB	\n"

+	);

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  See

+	http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html */

+	configASSERT( ( configMAX_SYSCALL_INTERRUPT_PRIORITY ) );

+

+	/* Make PendSV and SysTick the same priority as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Configure the regions in the MPU that are common to all tasks. */

+	prvSetupMPU();

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	__asm volatile( "	svc %0			\n"

+					:: "i" (portSVC_START_SCHEDULER) );

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM3 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+void xPortPendSVHandler( void )

+{

+	/* This is a naked function. */

+

+	__asm volatile

+	(

+		"	mrs r0, psp							\n"

+		"										\n"

+		"	ldr	r3, pxCurrentTCBConst			\n" /* Get the location of the current TCB. */

+		"	ldr	r2, [r3]						\n"

+		"										\n"

+		"	mrs r1, control						\n"

+		"	stmdb r0!, {r1, r4-r11}				\n" /* Save the remaining registers. */

+		"	str r0, [r2]						\n" /* Save the new top of stack into the first member of the TCB. */

+		"										\n"

+		"	stmdb sp!, {r3, r14}				\n"

+		"	mov r0, %0							\n"

+		"	msr basepri, r0						\n"

+		"	bl vTaskSwitchContext				\n"

+		"	mov r0, #0							\n"

+		"	msr basepri, r0						\n"

+		"	ldmia sp!, {r3, r14}				\n"

+		"										\n"	/* Restore the context. */

+		"	ldr r1, [r3]						\n"

+		"	ldr r0, [r1]						\n" /* The first item in the TCB is the task top of stack. */

+		"	add r1, r1, #4						\n" /* Move onto the second item in the TCB... */

+		"	ldr r2, =0xe000ed9c					\n" /* Region Base Address register. */

+		"	ldmia r1!, {r4-r11}					\n" /* Read 4 sets of MPU registers. */

+		"	stmia r2!, {r4-r11}					\n" /* Write 4 sets of MPU registers. */

+		"	ldmia r0!, {r3, r4-r11}				\n" /* Pop the registers that are not automatically saved on exception entry. */

+		"	msr control, r3						\n"

+		"										\n"

+		"	msr psp, r0							\n"

+		"	bx r14								\n"

+		"										\n"

+		"	.align 2							\n"

+		"pxCurrentTCBConst: .word pxCurrentTCB	\n"

+		::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY)

+	);

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupMPU( void )

+{

+extern unsigned long __privileged_functions_end__[];

+extern unsigned long __FLASH_segment_start__[];

+extern unsigned long __FLASH_segment_end__[];

+extern unsigned long __privileged_data_start__[];

+extern unsigned long __privileged_data_end__[];

+

+	/* Check the expected MPU is present. */

+	if( *portMPU_TYPE == portEXPECTED_MPU_TYPE_VALUE )

+	{

+		/* First setup the entire flash for unprivileged read only access. */

+        *portMPU_REGION_BASE_ADDRESS =	( ( unsigned long ) __FLASH_segment_start__ ) | /* Base address. */

+										( portMPU_REGION_VALID ) |

+										( portUNPRIVILEGED_FLASH_REGION );

+

+		*portMPU_REGION_ATTRIBUTE =		( portMPU_REGION_READ_ONLY ) |

+										( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+										( prvGetMPURegionSizeSetting( ( unsigned long ) __FLASH_segment_end__ - ( unsigned long ) __FLASH_segment_start__ ) ) |

+										( portMPU_REGION_ENABLE );

+

+		/* Setup the first 16K for privileged only access (even though less

+		than 10K is actually being used).  This is where the kernel code is

+		placed. */

+        *portMPU_REGION_BASE_ADDRESS =	( ( unsigned long ) __FLASH_segment_start__ ) | /* Base address. */

+										( portMPU_REGION_VALID ) |

+										( portPRIVILEGED_FLASH_REGION );

+

+		*portMPU_REGION_ATTRIBUTE =		( portMPU_REGION_PRIVILEGED_READ_ONLY ) |

+										( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+										( prvGetMPURegionSizeSetting( ( unsigned long ) __privileged_functions_end__ - ( unsigned long ) __FLASH_segment_start__ ) ) |

+										( portMPU_REGION_ENABLE );

+

+		/* Setup the privileged data RAM region.  This is where the kernel data

+		is placed. */

+		*portMPU_REGION_BASE_ADDRESS =	( ( unsigned long ) __privileged_data_start__ ) | /* Base address. */

+										( portMPU_REGION_VALID ) |

+										( portPRIVILEGED_RAM_REGION );

+

+		*portMPU_REGION_ATTRIBUTE =		( portMPU_REGION_PRIVILEGED_READ_WRITE ) |

+										( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+										prvGetMPURegionSizeSetting( ( unsigned long ) __privileged_data_end__ - ( unsigned long ) __privileged_data_start__ ) |

+										( portMPU_REGION_ENABLE );

+

+		/* By default allow everything to access the general peripherals.  The

+		system peripherals and registers are protected. */

+		*portMPU_REGION_BASE_ADDRESS =	( portPERIPHERALS_START_ADDRESS ) |

+										( portMPU_REGION_VALID ) |

+										( portGENERAL_PERIPHERALS_REGION );

+

+		*portMPU_REGION_ATTRIBUTE =		( portMPU_REGION_READ_WRITE | portMPU_REGION_EXECUTE_NEVER ) |

+										( prvGetMPURegionSizeSetting( portPERIPHERALS_END_ADDRESS - portPERIPHERALS_START_ADDRESS ) ) |

+										( portMPU_REGION_ENABLE );

+

+		/* Enable the memory fault exception. */

+		*portNVIC_SYS_CTRL_STATE |= portNVIC_MEM_FAULT_ENABLE;

+

+		/* Enable the MPU with the background region configured. */

+		*portMPU_CTRL |= ( portMPU_ENABLE | portMPU_BACKGROUND_ENABLE );

+	}

+}

+/*-----------------------------------------------------------*/

+

+static unsigned long prvGetMPURegionSizeSetting( unsigned long ulActualSizeInBytes )

+{

+unsigned long ulRegionSize, ulReturnValue = 4;

+

+	/* 32 is the smallest region size, 31 is the largest valid value for

+	ulReturnValue. */

+	for( ulRegionSize = 32UL; ulReturnValue < 31UL; ( ulRegionSize <<= 1UL ) )

+	{

+		if( ulActualSizeInBytes <= ulRegionSize )

+		{

+			break;

+		}

+		else

+		{

+			ulReturnValue++;

+		}

+	}

+

+	/* Shift the code by one before returning so it can be written directly

+	into the the correct bit position of the attribute register. */

+	return ( ulReturnValue << 1UL );

+}

+/*-----------------------------------------------------------*/

+

+static portBASE_TYPE prvRaisePrivilege( void )

+{

+	__asm volatile

+	(

+		"	mrs r0, control						\n"

+		"	tst r0, #1							\n" /* Is the task running privileged? */

+		"	itte ne								\n"

+		"	movne r0, #0						\n" /* CONTROL[0]!=0, return false. */

+		"	svcne %0							\n" /* Switch to privileged. */

+		"	moveq r0, #1						\n" /* CONTROL[0]==0, return true. */

+		"	bx lr								\n"

+		:: "i" (portSVC_RAISE_PRIVILEGE) : "r0"

+	);

+

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortStoreTaskMPUSettings( xMPU_SETTINGS *xMPUSettings, const struct xMEMORY_REGION * const xRegions, portSTACK_TYPE *pxBottomOfStack, unsigned short usStackDepth )

+{

+extern unsigned long __SRAM_segment_start__[];

+extern unsigned long __SRAM_segment_end__[];

+extern unsigned long __privileged_data_start__[];

+extern unsigned long __privileged_data_end__[];

+long lIndex;

+unsigned long ul;

+

+	if( xRegions == NULL )

+	{

+		/* No MPU regions are specified so allow access to all RAM. */

+        xMPUSettings->xRegion[ 0 ].ulRegionBaseAddress =

+				( ( unsigned long ) __SRAM_segment_start__ ) | /* Base address. */

+				( portMPU_REGION_VALID ) |

+				( portSTACK_REGION );

+

+		xMPUSettings->xRegion[ 0 ].ulRegionAttribute =

+				( portMPU_REGION_READ_WRITE ) |

+				( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+				( prvGetMPURegionSizeSetting( ( unsigned long ) __SRAM_segment_end__ - ( unsigned long ) __SRAM_segment_start__ ) ) |

+				( portMPU_REGION_ENABLE );

+

+		/* Re-instate the privileged only RAM region as xRegion[ 0 ] will have

+		just removed the privileged only parameters. */

+		xMPUSettings->xRegion[ 1 ].ulRegionBaseAddress =

+				( ( unsigned long ) __privileged_data_start__ ) | /* Base address. */

+				( portMPU_REGION_VALID ) |

+				( portSTACK_REGION + 1 );

+

+		xMPUSettings->xRegion[ 1 ].ulRegionAttribute =

+				( portMPU_REGION_PRIVILEGED_READ_WRITE ) |

+				( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+				prvGetMPURegionSizeSetting( ( unsigned long ) __privileged_data_end__ - ( unsigned long ) __privileged_data_start__ ) |

+				( portMPU_REGION_ENABLE );

+

+		/* Invalidate all other regions. */

+		for( ul = 2; ul <= portNUM_CONFIGURABLE_REGIONS; ul++ )

+		{

+			xMPUSettings->xRegion[ ul ].ulRegionBaseAddress = ( portSTACK_REGION + ul ) | portMPU_REGION_VALID;

+			xMPUSettings->xRegion[ ul ].ulRegionAttribute = 0UL;

+		}

+	}

+	else

+	{

+		/* This function is called automatically when the task is created - in

+		which case the stack region parameters will be valid.  At all other

+		times the stack parameters will not be valid and it is assumed that the

+		stack region has already been configured. */

+		if( usStackDepth > 0 )

+		{

+			/* Define the region that allows access to the stack. */

+			xMPUSettings->xRegion[ 0 ].ulRegionBaseAddress =

+					( ( unsigned long ) pxBottomOfStack ) |

+					( portMPU_REGION_VALID ) |

+					( portSTACK_REGION ); /* Region number. */

+

+			xMPUSettings->xRegion[ 0 ].ulRegionAttribute =

+					( portMPU_REGION_READ_WRITE ) | /* Read and write. */

+					( prvGetMPURegionSizeSetting( ( unsigned long ) usStackDepth * ( unsigned long ) sizeof( portSTACK_TYPE ) ) ) |

+					( portMPU_REGION_CACHEABLE_BUFFERABLE ) |

+					( portMPU_REGION_ENABLE );

+		}

+

+		lIndex = 0;

+

+		for( ul = 1; ul <= portNUM_CONFIGURABLE_REGIONS; ul++ )

+		{

+			if( ( xRegions[ lIndex ] ).ulLengthInBytes > 0UL )

+			{

+				/* Translate the generic region definition contained in

+				xRegions into the CM3 specific MPU settings that are then

+				stored in xMPUSettings. */

+				xMPUSettings->xRegion[ ul ].ulRegionBaseAddress =

+						( ( unsigned long ) xRegions[ lIndex ].pvBaseAddress ) |

+						( portMPU_REGION_VALID ) |

+						( portSTACK_REGION + ul ); /* Region number. */

+

+				xMPUSettings->xRegion[ ul ].ulRegionAttribute =

+						( prvGetMPURegionSizeSetting( xRegions[ lIndex ].ulLengthInBytes ) ) |

+						( xRegions[ lIndex ].ulParameters ) |

+						( portMPU_REGION_ENABLE );

+			}

+			else

+			{

+				/* Invalidate the region. */

+				xMPUSettings->xRegion[ ul ].ulRegionBaseAddress = ( portSTACK_REGION + ul ) | portMPU_REGION_VALID;

+				xMPUSettings->xRegion[ ul ].ulRegionAttribute = 0UL;

+			}

+

+			lIndex++;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE MPU_xTaskGenericCreate( pdTASK_CODE pvTaskCode, const signed char * const pcName, unsigned short usStackDepth, void *pvParameters, unsigned portBASE_TYPE uxPriority, xTaskHandle *pxCreatedTask, portSTACK_TYPE *puxStackBuffer, const xMemoryRegion * const xRegions )

+{

+signed portBASE_TYPE xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xTaskGenericCreate( pvTaskCode, pcName, usStackDepth, pvParameters, uxPriority, pxCreatedTask, puxStackBuffer, xRegions );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+void MPU_vTaskAllocateMPURegions( xTaskHandle xTask, const xMemoryRegion * const xRegions )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	vTaskAllocateMPURegions( xTask, xRegions );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelete == 1 )

+	void MPU_vTaskDelete( xTaskHandle pxTaskToDelete )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskDelete( pxTaskToDelete );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelayUntil == 1 )

+	void MPU_vTaskDelayUntil( portTickType * const pxPreviousWakeTime, portTickType xTimeIncrement )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskDelayUntil( pxPreviousWakeTime, xTimeIncrement );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelay == 1 )

+	void MPU_vTaskDelay( portTickType xTicksToDelay )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskDelay( xTicksToDelay );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_uxTaskPriorityGet == 1 )

+	unsigned portBASE_TYPE MPU_uxTaskPriorityGet( xTaskHandle pxTask )

+	{

+	unsigned portBASE_TYPE uxReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		uxReturn = uxTaskPriorityGet( pxTask );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return uxReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskPrioritySet == 1 )

+	void MPU_vTaskPrioritySet( xTaskHandle pxTask, unsigned portBASE_TYPE uxNewPriority )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskPrioritySet( pxTask, uxNewPriority );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+	void MPU_vTaskSuspend( xTaskHandle pxTaskToSuspend )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskSuspend( pxTaskToSuspend );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+	signed portBASE_TYPE MPU_xTaskIsTaskSuspended( xTaskHandle xTask )

+	{

+	signed portBASE_TYPE xReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xTaskIsTaskSuspended( xTask );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+	void MPU_vTaskResume( xTaskHandle pxTaskToResume )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskResume( pxTaskToResume );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+void MPU_vTaskSuspendAll( void )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	vTaskSuspendAll();

+    portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE MPU_xTaskResumeAll( void )

+{

+signed portBASE_TYPE xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xTaskResumeAll();

+    portRESET_PRIVILEGE( xRunningPrivileged );

+    return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+portTickType MPU_xTaskGetTickCount( void )

+{

+portTickType xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xTaskGetTickCount();

+    portRESET_PRIVILEGE( xRunningPrivileged );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE MPU_uxTaskGetNumberOfTasks( void )

+{

+unsigned portBASE_TYPE uxReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	uxReturn = uxTaskGetNumberOfTasks();

+    portRESET_PRIVILEGE( xRunningPrivileged );

+	return uxReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+	void MPU_vTaskList( signed char *pcWriteBuffer )

+	{

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskList( pcWriteBuffer );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configGENERATE_RUN_TIME_STATS == 1 )

+	void MPU_vTaskGetRunTimeStats( signed char *pcWriteBuffer )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskGetRunTimeStats( pcWriteBuffer );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+	void MPU_vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxTagValue )

+	{

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vTaskSetApplicationTaskTag( xTask, pxTagValue );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+	pdTASK_HOOK_CODE MPU_xTaskGetApplicationTaskTag( xTaskHandle xTask )

+	{

+	pdTASK_HOOK_CODE xReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xTaskGetApplicationTaskTag( xTask );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+	portBASE_TYPE MPU_xTaskCallApplicationTaskHook( xTaskHandle xTask, void *pvParameter )

+	{

+	portBASE_TYPE xReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xTaskCallApplicationTaskHook( xTask, pvParameter );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_uxTaskGetStackHighWaterMark == 1 )

+	unsigned portBASE_TYPE MPU_uxTaskGetStackHighWaterMark( xTaskHandle xTask )

+	{

+	unsigned portBASE_TYPE uxReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		uxReturn = uxTaskGetStackHighWaterMark( xTask );

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return uxReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_xTaskGetCurrentTaskHandle == 1 )

+	xTaskHandle MPU_xTaskGetCurrentTaskHandle( void )

+	{

+	xTaskHandle xReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xTaskGetCurrentTaskHandle();

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_xTaskGetSchedulerState == 1 )

+	portBASE_TYPE MPU_xTaskGetSchedulerState( void )

+	{

+	portBASE_TYPE xReturn;

+    portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xTaskGetSchedulerState();

+        portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+xQueueHandle MPU_xQueueGenericCreate( unsigned portBASE_TYPE uxQueueLength, unsigned portBASE_TYPE uxItemSize, unsigned char ucQueueType )

+{

+xQueueHandle xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xQueueGenericCreate( uxQueueLength, uxItemSize, ucQueueType );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE MPU_xQueueGenericSend( xQueueHandle xQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition )

+{

+signed portBASE_TYPE xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xQueueGenericSend( xQueue, pvItemToQueue, xTicksToWait, xCopyPosition );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE MPU_uxQueueMessagesWaiting( const xQueueHandle pxQueue )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+unsigned portBASE_TYPE uxReturn;

+

+	uxReturn = uxQueueMessagesWaiting( pxQueue );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+	return uxReturn;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE MPU_xQueueGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+signed portBASE_TYPE xReturn;

+

+	xReturn = xQueueGenericReceive( pxQueue, pvBuffer, xTicksToWait, xJustPeeking );

+	portRESET_PRIVILEGE( xRunningPrivileged );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+	xQueueHandle MPU_xQueueCreateMutex( void )

+	{

+    xQueueHandle xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xQueueCreateMutex( queueQUEUE_TYPE_MUTEX );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_COUNTING_SEMAPHORES == 1

+	xQueueHandle MPU_xQueueCreateCountingSemaphore( unsigned portBASE_TYPE uxCountValue, unsigned portBASE_TYPE uxInitialCount )

+	{

+    xQueueHandle xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xQueueCreateCountingSemaphore( uxCountValue, uxInitialCount );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+	portBASE_TYPE MPU_xQueueTakeMutexRecursive( xQueueHandle xMutex, portTickType xBlockTime )

+	{

+	portBASE_TYPE xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xQueueTakeMutexRecursive( xMutex, xBlockTime );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+	portBASE_TYPE MPU_xQueueGiveMutexRecursive( xQueueHandle xMutex )

+	{

+	portBASE_TYPE xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xQueueGiveMutexRecursive( xMutex );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_ALTERNATIVE_API == 1

+	signed portBASE_TYPE MPU_xQueueAltGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition )

+	{

+   	signed portBASE_TYPE xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = 	signed portBASE_TYPE xQueueAltGenericSend( pxQueue, pvItemToQueue, xTicksToWait, xCopyPosition );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_ALTERNATIVE_API == 1

+	signed portBASE_TYPE MPU_xQueueAltGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking )

+	{

+    signed portBASE_TYPE xReturn;

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		xReturn = xQueueAltGenericReceive( pxQueue, pvBuffer, xTicksToWait, xJustPeeking );

+		portRESET_PRIVILEGE( xRunningPrivileged );

+		return xReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configQUEUE_REGISTRY_SIZE > 0

+	void MPU_vQueueAddToRegistry( xQueueHandle xQueue, signed char *pcName )

+	{

+	portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+		vQueueAddToRegistry( xQueue, pcName );

+

+		portRESET_PRIVILEGE( xRunningPrivileged );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+void MPU_vQueueDelete( xQueueHandle xQueue )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	vQueueDelete( xQueue );

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+void *MPU_pvPortMalloc( size_t xSize )

+{

+void *pvReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	pvReturn = pvPortMalloc( xSize );

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+void MPU_vPortFree( void *pv )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	vPortFree( pv );

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+void MPU_vPortInitialiseBlocks( void )

+{

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	vPortInitialiseBlocks();

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+}

+/*-----------------------------------------------------------*/

+

+size_t MPU_xPortGetFreeHeapSize( void )

+{

+size_t xReturn;

+portBASE_TYPE xRunningPrivileged = prvRaisePrivilege();

+

+	xReturn = xPortGetFreeHeapSize();

+

+	portRESET_PRIVILEGE( xRunningPrivileged );

+

+	return xReturn;

+}

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/portmacro.h
new file mode 100644
index 0000000..7b15dcc
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM3_MPU/portmacro.h
@@ -0,0 +1,215 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* MPU specific constants. */

+#define portUSING_MPU_WRAPPERS		1

+#define portPRIVILEGE_BIT			( 0x80000000UL )

+

+#define portMPU_REGION_READ_WRITE				( 0x03UL << 24UL )

+#define portMPU_REGION_PRIVILEGED_READ_ONLY		( 0x05UL << 24UL )

+#define portMPU_REGION_READ_ONLY				( 0x06UL << 24UL )

+#define portMPU_REGION_PRIVILEGED_READ_WRITE	( 0x01UL << 24UL )

+#define portMPU_REGION_CACHEABLE_BUFFERABLE		( 0x07UL << 16UL )

+#define portMPU_REGION_EXECUTE_NEVER			( 0x01UL << 28UL )

+

+#define portUNPRIVILEGED_FLASH_REGION		( 0UL )

+#define portPRIVILEGED_FLASH_REGION			( 1UL )

+#define portPRIVILEGED_RAM_REGION			( 2UL )

+#define portGENERAL_PERIPHERALS_REGION		( 3UL )

+#define portSTACK_REGION					( 4UL )

+#define portFIRST_CONFIGURABLE_REGION	    ( 5UL )

+#define portLAST_CONFIGURABLE_REGION		( 7UL )

+#define portNUM_CONFIGURABLE_REGIONS		( ( portLAST_CONFIGURABLE_REGION - portFIRST_CONFIGURABLE_REGION ) + 1 )

+#define portTOTAL_NUM_REGIONS				( portNUM_CONFIGURABLE_REGIONS + 1 ) /* Plus one to make space for the stack region. */

+

+#define portSWITCH_TO_USER_MODE() __asm volatile ( " mrs r0, control \n orr r0, #1 \n msr control, r0 " :::"r0" )

+

+typedef struct MPU_REGION_REGISTERS

+{

+	unsigned portLONG ulRegionBaseAddress;

+	unsigned portLONG ulRegionAttribute;

+} xMPU_REGION_REGISTERS;

+

+/* Plus 1 to create space for the stack region. */

+typedef struct MPU_SETTINGS

+{

+	xMPU_REGION_REGISTERS xRegion[ portTOTAL_NUM_REGIONS ];

+} xMPU_SETTINGS;

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/

+

+/* SVC numbers for various services. */

+#define portSVC_START_SCHEDULER				0

+#define portSVC_YIELD						1

+#define portSVC_RAISE_PRIVILEGE				2

+

+/* Scheduler utilities. */

+

+#define portYIELD()				__asm volatile ( "	SVC	%0	\n" :: "i" (portSVC_YIELD) )

+#define portYIELD_WITHIN_API()	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET

+

+#define portNVIC_INT_CTRL			( ( volatile unsigned portLONG *) 0xe000ed04 )

+#define portNVIC_PENDSVSET			0x10000000

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) *(portNVIC_INT_CTRL) = portNVIC_PENDSVSET

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/*

+ * Set basepri to portMAX_SYSCALL_INTERRUPT_PRIORITY without effecting other

+ * registers.  r0 is clobbered.

+ */

+#define portSET_INTERRUPT_MASK()						\

+	__asm volatile										\

+	(													\

+		"	mov r0, %0								\n"	\

+		"	msr basepri, r0							\n" \

+		::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY):"r0"	\

+	)

+

+/*

+ * Set basepri back to 0 without effective other registers.

+ * r0 is clobbered.  FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+ * http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing.

+ */

+#define portCLEAR_INTERRUPT_MASK()			\

+	__asm volatile							\

+	(										\

+		"	mov r0, #0					\n"	\

+		"	msr basepri, r0				\n"	\

+		:::"r0"								\

+	)

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM4F/port.c b/FreeRTOS/Source/portable/GCC/ARM_CM4F/port.c
new file mode 100644
index 0000000..c2c143f
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM4F/port.c
@@ -0,0 +1,350 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM4F port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#ifndef __VFP_FP__

+	#error This port can only be used when the project options are configured to enable hardware floating point support.

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long * ) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long * ) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long * ) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long * ) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to manipulate the VFP. */

+#define portFPCCR					( ( volatile unsigned long * ) 0xe000ef34 ) /* Floating point context control register. */

+#define portASPEN_AND_LSPEN_BITS	( 0x3UL << 30UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+#define portINITIAL_EXEC_RETURN		( 0xfffffffd )

+

+/* The priority used by the kernel is assigned to a variable to make access

+from inline assembler easier. */

+const unsigned long ulKernelPriority = configKERNEL_INTERRUPT_PRIORITY;

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void ) __attribute__ (( naked ));

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void ) __attribute__ (( naked ));

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+static void vPortStartFirstTask( void ) __attribute__ (( naked ));

+

+/*

+ * Function to enable the VFP.

+ */

+ static void vPortEnableVFP( void ) __attribute__ (( naked ));

+

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+

+	/* Offset added to account for the way the MCU uses the stack on entry/exit

+	of interrupts, and to ensure alignment. */

+	pxTopOfStack--;

+

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+

+	/* Save code space by skipping register initialisation. */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+

+	/* A save method is being used that requires each task to maintain its

+	own exec return value. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_EXEC_RETURN;

+

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSVCHandler( void )

+{

+	__asm volatile (

+					"	ldr	r3, pxCurrentTCBConst2		\n" /* Restore the context. */

+					"	ldr r1, [r3]					\n" /* Use pxCurrentTCBConst to get the pxCurrentTCB address. */

+					"	ldr r0, [r1]					\n" /* The first item in pxCurrentTCB is the task top of stack. */

+					"	ldmia r0!, {r4-r11, r14}		\n" /* Pop the registers that are not automatically saved on exception entry and the critical nesting count. */

+					"	msr psp, r0						\n" /* Restore the task stack pointer. */

+					"	mov r0, #0 						\n"

+					"	msr	basepri, r0					\n"

+					"	bx r14							\n"

+					"									\n"

+					"	.align 2						\n"

+					"pxCurrentTCBConst2: .word pxCurrentTCB				\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+static void vPortStartFirstTask( void )

+{

+	__asm volatile(

+					" ldr r0, =0xE000ED08 	\n" /* Use the NVIC offset register to locate the stack. */

+					" ldr r0, [r0] 			\n"

+					" ldr r0, [r0] 			\n"

+					" msr msp, r0			\n" /* Set the msp back to the start of the stack. */

+					" cpsie i				\n" /* Globally enable interrupts. */

+					" svc 0					\n" /* System call to start first task. */

+					" nop					\n"

+				);

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  

+	See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html */

+	configASSERT( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+

+	/* Make PendSV and SysTick the lowest priority interrupts. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Ensure the VFP is enabled - it should be anyway. */

+	vPortEnableVFP();

+

+	/* Lazy save always. */

+	*( portFPCCR ) |= portASPEN_AND_LSPEN_BITS;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM4F port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortPendSVHandler( void )

+{

+	/* This is a naked function. */

+

+	__asm volatile

+	(

+	"	mrs r0, psp							\n"

+	"										\n"

+	"	ldr	r3, pxCurrentTCBConst				\n" /* Get the location of the current TCB. */

+	"	ldr	r2, [r3]						\n"

+	"										\n"

+	"	tst r14, #0x10						\n" /* Is the task using the FPU context?  If so, push high vfp registers. */

+	"	it eq								\n"

+	"	vstmdbeq r0!, {s16-s31}				\n"

+	"										\n"

+	"	stmdb r0!, {r4-r11, r14}			\n" /* Save the core registers. */

+	"										\n"

+	"	str r0, [r2]						\n" /* Save the new top of stack into the first member of the TCB. */

+	"										\n"

+	"	stmdb sp!, {r3, r14}				\n"

+	"	mov r0, %0 							\n"

+	"	msr basepri, r0						\n"

+	"	bl vTaskSwitchContext				\n"

+	"	mov r0, #0							\n"

+	"	msr basepri, r0						\n"

+	"	ldmia sp!, {r3, r14}				\n"

+	"										\n"

+	"	ldr r1, [r3]						\n" /* The first item in pxCurrentTCB is the task top of stack. */

+	"	ldr r0, [r1]						\n"

+	"										\n"

+	"	ldmia r0!, {r4-r11, r14}			\n" /* Pop the core registers. */

+	"										\n"

+	"	tst r14, #0x10						\n" /* Is the task using the FPU context?  If so, pop the high vfp registers too. */

+	"	it eq								\n"

+	"	vldmiaeq r0!, {s16-s31}				\n"

+	"										\n"

+	"	msr psp, r0							\n"

+	"	bx r14								\n"

+	"										\n"

+	"	.align 2							\n"

+	"pxCurrentTCBConst: .word pxCurrentTCB	\n"

+	::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY)

+	);

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

+/* This is a naked function. */

+static void vPortEnableVFP( void )

+{

+	__asm volatile

+	(

+		"	ldr.w r0, =0xE000ED88		\n" /* The FPU enable bits are in the CPACR. */

+		"	ldr r1, [r0]				\n"

+		"								\n"

+		"	orr r1, r1, #( 0xf << 20 )	\n" /* Enable CP10 and CP11 coprocessors, then save back. */

+		"	str r1, [r0]				\n"

+		"	bx r14						"

+	);

+}

+

diff --git a/FreeRTOS/Source/portable/GCC/ARM_CM4F/portmacro.h b/FreeRTOS/Source/portable/GCC/ARM_CM4F/portmacro.h
new file mode 100644
index 0000000..798be5e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ARM_CM4F/portmacro.h
@@ -0,0 +1,178 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/* 

+ * Set basepri to portMAX_SYSCALL_INTERRUPT_PRIORITY without effecting other

+ * registers.  r0 is clobbered.

+ */ 

+#define portSET_INTERRUPT_MASK()						\

+	__asm volatile										\

+	(													\

+		"	mov r0, %0								\n"	\

+		"	msr basepri, r0							\n" \

+		::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY):"r0"	\

+	)

+	

+/*

+ * Set basepri back to 0 without effective other registers.

+ * r0 is clobbered.  FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+ * http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing.

+ */

+#define portCLEAR_INTERRUPT_MASK()			\

+	__asm volatile							\

+	(										\

+		"	mov r0, #0					\n"	\

+		"	msr basepri, r0				\n"	\

+		:::"r0"								\

+	)

+

+/* FAQ:  Setting BASEPRI to 0 in portCLEAR_INTERRUPT_MASK_FROM_ISR() is not a 

+bug.  Please see http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before 

+disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+/* There are an uneven number of items on the initial stack, so 

+portALIGNMENT_ASSERT_pxCurrentTCB() will trigger false positive asserts. */

+#define portALIGNMENT_ASSERT_pxCurrentTCB ( void )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/ATMega323/port.c b/FreeRTOS/Source/portable/GCC/ATMega323/port.c
new file mode 100644
index 0000000..6846eb5
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ATMega323/port.c
@@ -0,0 +1,463 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* 

+

+Changes from V2.6.0

+

+	+ AVR port - Replaced the inb() and outb() functions with direct memory

+	  access.  This allows the port to be built with the 20050414 build of

+	  WinAVR.

+*/

+

+#include <stdlib.h>

+#include <avr/interrupt.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the AVR port.

+ *----------------------------------------------------------*/

+

+/* Start tasks with interrupts enables. */

+#define portFLAGS_INT_ENABLED					( ( portSTACK_TYPE ) 0x80 )

+

+/* Hardware constants for timer 1. */

+#define portCLEAR_COUNTER_ON_MATCH				( ( unsigned char ) 0x08 )

+#define portPRESCALE_64							( ( unsigned char ) 0x03 )

+#define portCLOCK_PRESCALER						( ( unsigned long ) 64 )

+#define portCOMPARE_MATCH_A_INTERRUPT_ENABLE	( ( unsigned char ) 0x10 )

+

+/*-----------------------------------------------------------*/

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Macro to save all the general purpose registers, the save the stack pointer

+ * into the TCB.  

+ * 

+ * The first thing we do is save the flags then disable interrupts.  This is to 

+ * guard our stack against having a context switch interrupt after we have already 

+ * pushed the registers onto the stack - causing the 32 registers to be on the 

+ * stack twice. 

+ * 

+ * r1 is set to zero as the compiler expects it to be thus, however some

+ * of the math routines make use of R1. 

+ * 

+ * The interrupts will have been disabled during the call to portSAVE_CONTEXT()

+ * so we need not worry about reading/writing to the stack pointer. 

+ */

+

+#define portSAVE_CONTEXT()									\

+	asm volatile (	"push	r0						\n\t"	\

+					"in		r0, __SREG__			\n\t"	\

+					"cli							\n\t"	\

+					"push	r0						\n\t"	\

+					"push	r1						\n\t"	\

+					"clr	r1						\n\t"	\

+					"push	r2						\n\t"	\

+					"push	r3						\n\t"	\

+					"push	r4						\n\t"	\

+					"push	r5						\n\t"	\

+					"push	r6						\n\t"	\

+					"push	r7						\n\t"	\

+					"push	r8						\n\t"	\

+					"push	r9						\n\t"	\

+					"push	r10						\n\t"	\

+					"push	r11						\n\t"	\

+					"push	r12						\n\t"	\

+					"push	r13						\n\t"	\

+					"push	r14						\n\t"	\

+					"push	r15						\n\t"	\

+					"push	r16						\n\t"	\

+					"push	r17						\n\t"	\

+					"push	r18						\n\t"	\

+					"push	r19						\n\t"	\

+					"push	r20						\n\t"	\

+					"push	r21						\n\t"	\

+					"push	r22						\n\t"	\

+					"push	r23						\n\t"	\

+					"push	r24						\n\t"	\

+					"push	r25						\n\t"	\

+					"push	r26						\n\t"	\

+					"push	r27						\n\t"	\

+					"push	r28						\n\t"	\

+					"push	r29						\n\t"	\

+					"push	r30						\n\t"	\

+					"push	r31						\n\t"	\

+					"lds	r26, pxCurrentTCB		\n\t"	\

+					"lds	r27, pxCurrentTCB + 1	\n\t"	\

+					"in		r0, 0x3d				\n\t"	\

+					"st		x+, r0					\n\t"	\

+					"in		r0, 0x3e				\n\t"	\

+					"st		x+, r0					\n\t"	\

+				);

+

+/* 

+ * Opposite to portSAVE_CONTEXT().  Interrupts will have been disabled during

+ * the context save so we can write to the stack pointer. 

+ */

+

+#define portRESTORE_CONTEXT()								\

+	asm volatile (	"lds	r26, pxCurrentTCB		\n\t"	\

+					"lds	r27, pxCurrentTCB + 1	\n\t"	\

+					"ld		r28, x+					\n\t"	\

+					"out	__SP_L__, r28			\n\t"	\

+					"ld		r29, x+					\n\t"	\

+					"out	__SP_H__, r29			\n\t"	\

+					"pop	r31						\n\t"	\

+					"pop	r30						\n\t"	\

+					"pop	r29						\n\t"	\

+					"pop	r28						\n\t"	\

+					"pop	r27						\n\t"	\

+					"pop	r26						\n\t"	\

+					"pop	r25						\n\t"	\

+					"pop	r24						\n\t"	\

+					"pop	r23						\n\t"	\

+					"pop	r22						\n\t"	\

+					"pop	r21						\n\t"	\

+					"pop	r20						\n\t"	\

+					"pop	r19						\n\t"	\

+					"pop	r18						\n\t"	\

+					"pop	r17						\n\t"	\

+					"pop	r16						\n\t"	\

+					"pop	r15						\n\t"	\

+					"pop	r14						\n\t"	\

+					"pop	r13						\n\t"	\

+					"pop	r12						\n\t"	\

+					"pop	r11						\n\t"	\

+					"pop	r10						\n\t"	\

+					"pop	r9						\n\t"	\

+					"pop	r8						\n\t"	\

+					"pop	r7						\n\t"	\

+					"pop	r6						\n\t"	\

+					"pop	r5						\n\t"	\

+					"pop	r4						\n\t"	\

+					"pop	r3						\n\t"	\

+					"pop	r2						\n\t"	\

+					"pop	r1						\n\t"	\

+					"pop	r0						\n\t"	\

+					"out	__SREG__, r0			\n\t"	\

+					"pop	r0						\n\t"	\

+				);

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Perform hardware setup to enable ticks from timer 1, compare match A.

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned short usAddress;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x11;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack--;

+

+	/* Simulate how the stack would look after a call to vPortYield() generated by 

+	the compiler. */

+

+	/*lint -e950 -e611 -e923 Lint doesn't like this much - but nothing I can do about it. */

+

+	/* The start of the task code will be popped off the stack last, so place

+	it on first. */

+	usAddress = ( unsigned short ) pxCode;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	usAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	/* Next simulate the stack as if after a call to portSAVE_CONTEXT().  

+	portSAVE_CONTEXT places the flags on the stack immediately after r0

+	to ensure the interrupts get disabled as soon as possible, and so ensuring

+	the stack use is minimal should a context switch interrupt occur. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;	/* R0 */

+	pxTopOfStack--;

+	*pxTopOfStack = portFLAGS_INT_ENABLED;

+	pxTopOfStack--;

+

+

+	/* Now the remaining registers.   The compiler expects R1 to be 0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;	/* R1 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02;	/* R2 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03;	/* R3 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04;	/* R4 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05;	/* R5 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06;	/* R6 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07;	/* R7 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08;	/* R8 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09;	/* R9 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10;	/* R10 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11;	/* R11 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12;	/* R12 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x13;	/* R13 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x14;	/* R14 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x15;	/* R15 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x16;	/* R16 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x17;	/* R17 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x18;	/* R18 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x19;	/* R19 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x20;	/* R20 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x21;	/* R21 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22;	/* R22 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x23;	/* R23 */

+	pxTopOfStack--;

+

+	/* Place the parameter on the stack in the expected location. */

+	usAddress = ( unsigned short ) pvParameters;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	usAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x26;	/* R26 X */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x27;	/* R27 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x28;	/* R28 Y */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x29;	/* R29 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x30;	/* R30 Z */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x031;	/* R31 */

+	pxTopOfStack--;

+

+	/*lint +e950 +e611 +e923 */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	portRESTORE_CONTEXT();

+

+	/* Simulate a function call end as generated by the compiler.  We will now

+	jump to the start of the task the context of which we have just restored. */

+	asm volatile ( "ret" );

+

+	/* Should not get here. */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the AVR port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch.  The first thing we do is save the registers so we

+ * can use a naked attribute.

+ */

+void vPortYield( void ) __attribute__ ( ( naked ) );

+void vPortYield( void )

+{

+	portSAVE_CONTEXT();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT();

+

+	asm volatile ( "ret" );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Context switch function used by the tick.  This must be identical to 

+ * vPortYield() from the call to vTaskSwitchContext() onwards.  The only

+ * difference from vPortYield() is the tick count is incremented as the

+ * call comes from the tick ISR.

+ */

+void vPortYieldFromTick( void ) __attribute__ ( ( naked ) );

+void vPortYieldFromTick( void )

+{

+	portSAVE_CONTEXT();

+	vTaskIncrementTick();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT();

+

+	asm volatile ( "ret" );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup timer 1 compare match A to generate a tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+unsigned long ulCompareMatch;

+unsigned char ucHighByte, ucLowByte;

+

+	/* Using 16bit timer 1 to generate the tick.  Correct fuses must be

+	selected for the configCPU_CLOCK_HZ clock. */

+

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* We only have 16 bits so have to scale to get our required tick rate. */

+	ulCompareMatch /= portCLOCK_PRESCALER;

+

+	/* Adjust for correct value. */

+	ulCompareMatch -= ( unsigned long ) 1;

+

+	/* Setup compare match value for compare match A.  Interrupts are disabled 

+	before this is called so we need not worry here. */

+	ucLowByte = ( unsigned char ) ( ulCompareMatch & ( unsigned long ) 0xff );

+	ulCompareMatch >>= 8;

+	ucHighByte = ( unsigned char ) ( ulCompareMatch & ( unsigned long ) 0xff );

+	OCR1AH = ucHighByte;

+	OCR1AL = ucLowByte;

+

+	/* Setup clock source and compare match behaviour. */

+	ucLowByte = portCLEAR_COUNTER_ON_MATCH | portPRESCALE_64;

+	TCCR1B = ucLowByte;

+

+	/* Enable the interrupt - this is okay as interrupt are currently globally

+	disabled. */

+	ucLowByte = TIMSK;

+	ucLowByte |= portCOMPARE_MATCH_A_INTERRUPT_ENABLE;

+	TIMSK = ucLowByte;

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 1

+

+	/*

+	 * Tick ISR for preemptive scheduler.  We can use a naked attribute as

+	 * the context is saved at the start of vPortYieldFromTick().  The tick

+	 * count is incremented after the context is saved.

+	 */

+	void SIG_OUTPUT_COMPARE1A( void ) __attribute__ ( ( signal, naked ) );

+	void SIG_OUTPUT_COMPARE1A( void )

+	{

+		vPortYieldFromTick();

+		asm volatile ( "reti" );

+	}

+#else

+

+	/*

+	 * Tick ISR for the cooperative scheduler.  All this does is increment the

+	 * tick count.  We don't need to switch context, this can only be done by

+	 * manual calls to taskYIELD();

+	 */

+	void SIG_OUTPUT_COMPARE1A( void ) __attribute__ ( ( signal ) );

+	void SIG_OUTPUT_COMPARE1A( void )

+	{

+		vTaskIncrementTick();

+	}

+#endif

+

+

+	

diff --git a/FreeRTOS/Source/portable/GCC/ATMega323/portmacro.h b/FreeRTOS/Source/portable/GCC/ATMega323/portmacro.h
new file mode 100644
index 0000000..75b17f5
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ATMega323/portmacro.h
@@ -0,0 +1,142 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.2.3

+

+	+ portCPU_CLOSK_HZ definition changed to 8MHz base 10, previously it 

+	  base 16.

+*/

+

+#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		int

+#define portSTACK_TYPE	unsigned portCHAR

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Critical section management. */

+#define portENTER_CRITICAL()		asm volatile ( "in		__tmp_reg__, __SREG__" :: );	\

+									asm volatile ( "cli" :: );								\

+									asm volatile ( "push	__tmp_reg__" :: )

+

+#define portEXIT_CRITICAL()			asm volatile ( "pop		__tmp_reg__" :: );				\

+									asm volatile ( "out		__SREG__, __tmp_reg__" :: )

+

+#define portDISABLE_INTERRUPTS()	asm volatile ( "cli" :: );

+#define portENABLE_INTERRUPTS()		asm volatile ( "sei" :: );

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			1

+#define portNOP()					asm volatile ( "nop" );

+/*-----------------------------------------------------------*/

+

+/* Kernel utilities. */

+extern void vPortYield( void ) __attribute__ ( ( naked ) );

+#define portYIELD()					vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/AVR32_UC3/exception.S b/FreeRTOS/Source/portable/GCC/AVR32_UC3/exception.S
new file mode 100644
index 0000000..9a2833f
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/AVR32_UC3/exception.S
@@ -0,0 +1,297 @@
+/*This file is prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief Exception and interrupt vectors.

+ *

+ * This file maps all events supported by an AVR32UC.

+ *

+ * - Compiler:           GNU GCC for AVR32

+ * - Supported devices:  All AVR32UC devices with an INTC module can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ ******************************************************************************/

+

+/* Copyright (c) 2007, Atmel Corporation All rights reserved.

+ *

+ * Redistribution and use in source and binary forms, with or without

+ * modification, are permitted provided that the following conditions are met:

+ *

+ * 1. Redistributions of source code must retain the above copyright notice,

+ * this list of conditions and the following disclaimer.

+ *

+ * 2. Redistributions in binary form must reproduce the above copyright notice,

+ * this list of conditions and the following disclaimer in the documentation

+ * and/or other materials provided with the distribution.

+ *

+ * 3. The name of ATMEL may not be used to endorse or promote products derived

+ * from this software without specific prior written permission.

+ *

+ * THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED

+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND

+ * SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT,

+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES

+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;

+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND

+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT

+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF

+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+ */

+

+

+#include <avr32/io.h>

+#include "intc.h"

+

+

+//! @{

+//! \verbatim

+

+

+  .section  .exception, "ax", @progbits

+

+

+// Start of Exception Vector Table.

+

+  // EVBA must be aligned with a power of two strictly greater than the EVBA-

+  // relative offset of the last vector.

+  .balign 0x200

+

+  // Export symbol.

+  .global _evba

+  .type _evba, @function

+_evba:

+

+        .org  0x000

+        // Unrecoverable Exception.

+_handle_Unrecoverable_Exception:

+        rjmp $

+

+        .org  0x004

+        // TLB Multiple Hit: UNUSED IN AVR32UC.

+_handle_TLB_Multiple_Hit:

+        rjmp $

+

+        .org  0x008

+        // Bus Error Data Fetch.

+_handle_Bus_Error_Data_Fetch:

+        rjmp $

+

+        .org  0x00C

+         // Bus Error Instruction Fetch.

+_handle_Bus_Error_Instruction_Fetch:

+        rjmp $

+

+        .org  0x010

+        // NMI.

+_handle_NMI:

+        rjmp $

+

+        .org  0x014

+        // Instruction Address.

+_handle_Instruction_Address:

+        rjmp $

+

+        .org  0x018

+        // ITLB Protection.

+_handle_ITLB_Protection:

+        rjmp $

+

+        .org  0x01C

+        // Breakpoint.

+_handle_Breakpoint:

+        rjmp $

+

+        .org  0x020

+        // Illegal Opcode.

+_handle_Illegal_Opcode:

+        rjmp $

+

+        .org  0x024

+        // Unimplemented Instruction.

+_handle_Unimplemented_Instruction:

+        rjmp $

+

+        .org  0x028

+        // Privilege Violation.

+_handle_Privilege_Violation:

+        rjmp $

+

+        .org  0x02C

+        // Floating-Point: UNUSED IN AVR32UC.

+_handle_Floating_Point:

+        rjmp $

+

+        .org  0x030

+        // Coprocessor Absent: UNUSED IN AVR32UC.

+_handle_Coprocessor_Absent:

+        rjmp $

+

+        .org  0x034

+        // Data Address (Read).

+_handle_Data_Address_Read:

+        rjmp $

+

+        .org  0x038

+        // Data Address (Write).

+_handle_Data_Address_Write:

+        rjmp $

+

+        .org  0x03C

+        // DTLB Protection (Read).

+_handle_DTLB_Protection_Read:

+        rjmp $

+

+        .org  0x040

+        // DTLB Protection (Write).

+_handle_DTLB_Protection_Write:

+        rjmp $

+

+        .org  0x044

+        // DTLB Modified: UNUSED IN AVR32UC.

+_handle_DTLB_Modified:

+        rjmp $

+

+        .org  0x050

+        // ITLB Miss: UNUSED IN AVR32UC.

+_handle_ITLB_Miss:

+        rjmp $

+

+        .org  0x060

+        // DTLB Miss (Read): UNUSED IN AVR32UC.

+_handle_DTLB_Miss_Read:

+        rjmp $

+

+        .org  0x070

+        // DTLB Miss (Write): UNUSED IN AVR32UC.

+_handle_DTLB_Miss_Write:

+        rjmp $

+

+        .org  0x100

+        // Supervisor Call.

+_handle_Supervisor_Call:

+        lda.w   pc, SCALLYield

+

+

+// Interrupt support.

+// The interrupt controller must provide the offset address relative to EVBA.

+// Important note:

+//   All interrupts call a C function named _get_interrupt_handler.

+//   This function will read group and interrupt line number to then return in

+//   R12 a pointer to a user-provided interrupt handler.

+

+  .balign 4

+

+_int0:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 0b110

+  brlo    _int0_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int0_normal:

+#endif

+  mov     r12, 0  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  call    _get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int1:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 0b110

+  brlo    _int1_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int1_normal:

+#endif

+  mov     r12, 1  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  call    _get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int2:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 0b110

+  brlo    _int2_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int2_normal:

+#endif

+  mov     r12, 2  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  call    _get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int3:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 0b110

+  brlo    _int3_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int3_normal:

+#endif

+  mov     r12, 3  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  call    _get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+

+// Constant data area.

+

+  .balign 4

+

+  // Values to store in the interrupt priority registers for the various interrupt priority levels.

+  // The interrupt priority registers contain the interrupt priority level and

+  // the EVBA-relative interrupt vector offset.

+  .global ipr_val

+  .type ipr_val, @object

+ipr_val:

+  .word (INT0 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int0 - _evba),\

+        (INT1 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int1 - _evba),\

+        (INT2 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int2 - _evba),\

+        (INT3 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int3 - _evba)

+

+

+//! \endverbatim

+//! @}

diff --git a/FreeRTOS/Source/portable/GCC/AVR32_UC3/port.c b/FreeRTOS/Source/portable/GCC/AVR32_UC3/port.c
new file mode 100644
index 0000000..2e9baa3
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/AVR32_UC3/port.c
@@ -0,0 +1,474 @@
+/*This file has been prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief FreeRTOS port source for AVR32 UC3.

+ *

+ * - Compiler:           GNU GCC for AVR32

+ * - Supported devices:  All AVR32 devices can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ *****************************************************************************/

+

+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/* Standard includes. */

+#include <sys/cpu.h>

+#include <sys/usart.h>

+#include <malloc.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* AVR32 UC3 includes. */

+#include <avr32/io.h>

+#include "gpio.h"

+#if( configTICK_USE_TC==1 )

+	#include "tc.h"

+#endif

+

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SR            ( ( portSTACK_TYPE ) 0x00400000 ) /* AVR32 : [M2:M0]=001 I1M=0 I0M=0, GM=0 */

+#define portINSTRUCTION_SIZE      ( ( portSTACK_TYPE ) 0 )

+

+/* Each task maintains its own critical nesting variable. */

+#define portNO_CRITICAL_NESTING   ( ( unsigned long ) 0 )

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+#if( configTICK_USE_TC==0 )

+	static void prvScheduleNextTick( void );

+#else

+	static void prvClearTcInt( void );

+#endif

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Low-level initialization routine called during startup, before the main

+ * function.

+ * This version comes in replacement to the default one provided by Newlib.

+ * Newlib's _init_startup only calls init_exceptions, but Newlib's exception

+ * vectors are not compatible with the SCALL management in the current FreeRTOS

+ * port. More low-level initializations are besides added here.

+ */

+void _init_startup(void)

+{

+	/* Import the Exception Vector Base Address. */

+	extern void _evba;

+

+	#if configHEAP_INIT

+		extern void __heap_start__;

+		extern void __heap_end__;

+		portBASE_TYPE *pxMem;

+	#endif

+

+	/* Load the Exception Vector Base Address in the corresponding system register. */

+	Set_system_register( AVR32_EVBA, ( int ) &_evba );

+

+	/* Enable exceptions. */

+	ENABLE_ALL_EXCEPTIONS();

+

+	/* Initialize interrupt handling. */

+	INTC_init_interrupts();

+

+	#if configHEAP_INIT

+

+		/* Initialize the heap used by malloc. */

+		for( pxMem = &__heap_start__; pxMem < ( portBASE_TYPE * )&__heap_end__; )

+		{

+			*pxMem++ = 0xA5A5A5A5;

+		}

+

+	#endif

+

+	/* Give the used CPU clock frequency to Newlib, so it can work properly. */

+	set_cpu_hz( configCPU_CLOCK_HZ );

+

+	/* Code section present if and only if the debug trace is activated. */

+	#if configDBG

+	{

+		static const gpio_map_t DBG_USART_GPIO_MAP =

+		{

+			{ configDBG_USART_RX_PIN, configDBG_USART_RX_FUNCTION },

+			{ configDBG_USART_TX_PIN, configDBG_USART_TX_FUNCTION }

+		};

+

+		/* Initialize the USART used for the debug trace with the configured parameters. */

+		set_usart_base( ( void * ) configDBG_USART );

+		gpio_enable_module( DBG_USART_GPIO_MAP,

+		                    sizeof( DBG_USART_GPIO_MAP ) / sizeof( DBG_USART_GPIO_MAP[0] ) );

+		usart_init( configDBG_USART_BAUDRATE );

+	}

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * malloc, realloc and free are meant to be called through respectively

+ * pvPortMalloc, pvPortRealloc and vPortFree.

+ * The latter functions call the former ones from within sections where tasks

+ * are suspended, so the latter functions are task-safe. __malloc_lock and

+ * __malloc_unlock use the same mechanism to also keep the former functions

+ * task-safe as they may be called directly from Newlib's functions.

+ * However, all these functions are interrupt-unsafe and SHALL THEREFORE NOT BE

+ * CALLED FROM WITHIN AN INTERRUPT, because __malloc_lock and __malloc_unlock do

+ * not call portENTER_CRITICAL and portEXIT_CRITICAL in order not to disable

+ * interrupts during memory allocation management as this may be a very time-

+ * consuming process.

+ */

+

+/*

+ * Lock routine called by Newlib on malloc / realloc / free entry to guarantee a

+ * safe section as memory allocation management uses global data.

+ * See the aforementioned details.

+ */

+void __malloc_lock(struct _reent *ptr)

+{

+	vTaskSuspendAll();

+}

+

+/*

+ * Unlock routine called by Newlib on malloc / realloc / free exit to guarantee

+ * a safe section as memory allocation management uses global data.

+ * See the aforementioned details.

+ */

+void __malloc_unlock(struct _reent *ptr)

+{

+	xTaskResumeAll();

+}

+/*-----------------------------------------------------------*/

+

+/* Added as there is no such function in FreeRTOS. */

+void *pvPortRealloc( void *pv, size_t xWantedSize )

+{

+void *pvReturn;

+

+	vTaskSuspendAll();

+	{

+		pvReturn = realloc( pv, xWantedSize );

+	}

+	xTaskResumeAll();

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+/* The cooperative scheduler requires a normal IRQ service routine to

+simply increment the system tick. */

+/* The preemptive scheduler is defined as "naked" as the full context is saved

+on entry as part of the context switch. */

+__attribute__((__naked__)) static void vTick( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT_OS_INT();

+

+	#if( configTICK_USE_TC==1 )

+		/* Clear the interrupt flag. */

+		prvClearTcInt();

+	#else

+		/* Schedule the COUNT&COMPARE match interrupt in (configCPU_CLOCK_HZ/configTICK_RATE_HZ)

+		clock cycles from now. */

+		prvScheduleNextTick();

+	#endif

+

+	/* Because FreeRTOS is not supposed to run with nested interrupts, put all OS

+	calls in a critical section . */

+	portENTER_CRITICAL();

+		vTaskIncrementTick();

+	portEXIT_CRITICAL();

+

+	/* Restore the context of the "elected task". */

+	portRESTORE_CONTEXT_OS_INT();

+}

+/*-----------------------------------------------------------*/

+

+__attribute__((__naked__)) void SCALLYield( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT_SCALL();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT_SCALL();

+}

+/*-----------------------------------------------------------*/

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+__attribute__((__noinline__)) void vPortEnterCritical( void )

+{

+	/* Disable interrupts */

+	portDISABLE_INTERRUPTS();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	 directly.  Increment ulCriticalNesting to keep a count of how many times

+	 portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+__attribute__((__noinline__)) void vPortExitCritical( void )

+{

+	if(ulCriticalNesting > portNO_CRITICAL_NESTING)

+	{

+		ulCriticalNesting--;

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable all interrupt/exception. */

+			portENABLE_INTERRUPTS();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* When the task starts, it will expect to find the function parameter in R12. */

+	pxTopOfStack--;

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x08080808;					/* R8 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x09090909;					/* R9 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x0A0A0A0A;					/* R10 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x0B0B0B0B;					/* R11 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) pvParameters;					/* R12 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xDEADBEEF;					/* R14/LR */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE; /* R15/PC */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) portINITIAL_SR;				/* SR */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xFF0000FF;					/* R0 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x01010101;					/* R1 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x02020202;					/* R2 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x03030303;					/* R3 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x04040404;					/* R4 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x05050505;					/* R5 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x06060606;					/* R6 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x07070707;					/* R7 */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_NESTING;			/* ulCriticalNesting */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	portRESTORE_CONTEXT();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the AVR32 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/* Schedule the COUNT&COMPARE match interrupt in (configCPU_CLOCK_HZ/configTICK_RATE_HZ)

+clock cycles from now. */

+#if( configTICK_USE_TC==0 )

+	static void prvScheduleFirstTick(void)

+	{

+		unsigned long lCycles;

+

+		lCycles = Get_system_register(AVR32_COUNT);

+		lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		// If lCycles ends up to be 0, make it 1 so that the COMPARE and exception

+		// generation feature does not get disabled.

+		if(0 == lCycles)

+		{

+			lCycles++;

+		}

+		Set_system_register(AVR32_COMPARE, lCycles);

+	}

+	

+	__attribute__((__noinline__)) static void prvScheduleNextTick(void)

+	{

+		unsigned long lCycles, lCount;

+

+		lCycles = Get_system_register(AVR32_COMPARE);

+		lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		// If lCycles ends up to be 0, make it 1 so that the COMPARE and exception

+		// generation feature does not get disabled.

+		if(0 == lCycles)

+		{

+			lCycles++;

+		}

+		lCount = Get_system_register(AVR32_COUNT);

+		if( lCycles < lCount )

+		{		// We missed a tick, recover for the next.

+			lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		}

+		Set_system_register(AVR32_COMPARE, lCycles);

+	}

+#else

+	__attribute__((__noinline__)) static void prvClearTcInt(void)

+	{

+		AVR32_TC.channel[configTICK_TC_CHANNEL].sr;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt(void)

+{

+#if( configTICK_USE_TC==1 )

+

+	volatile avr32_tc_t *tc = &AVR32_TC;

+

+	// Options for waveform genration.

+	tc_waveform_opt_t waveform_opt =

+	{

+	.channel  = configTICK_TC_CHANNEL,             /* Channel selection. */

+

+	.bswtrg   = TC_EVT_EFFECT_NOOP,                /* Software trigger effect on TIOB. */

+	.beevt    = TC_EVT_EFFECT_NOOP,                /* External event effect on TIOB. */

+	.bcpc     = TC_EVT_EFFECT_NOOP,                /* RC compare effect on TIOB. */

+	.bcpb     = TC_EVT_EFFECT_NOOP,                /* RB compare effect on TIOB. */

+

+	.aswtrg   = TC_EVT_EFFECT_NOOP,                /* Software trigger effect on TIOA. */

+	.aeevt    = TC_EVT_EFFECT_NOOP,                /* External event effect on TIOA. */

+	.acpc     = TC_EVT_EFFECT_NOOP,                /* RC compare effect on TIOA: toggle. */

+	.acpa     = TC_EVT_EFFECT_NOOP,                /* RA compare effect on TIOA: toggle (other possibilities are none, set and clear). */

+

+	.wavsel   = TC_WAVEFORM_SEL_UP_MODE_RC_TRIGGER,/* Waveform selection: Up mode without automatic trigger on RC compare. */

+	.enetrg   = FALSE,                             /* External event trigger enable. */

+	.eevt     = 0,                                 /* External event selection. */

+	.eevtedg  = TC_SEL_NO_EDGE,                    /* External event edge selection. */

+	.cpcdis   = FALSE,                             /* Counter disable when RC compare. */

+	.cpcstop  = FALSE,                             /* Counter clock stopped with RC compare. */

+

+	.burst    = FALSE,                             /* Burst signal selection. */

+	.clki     = FALSE,                             /* Clock inversion. */

+	.tcclks   = TC_CLOCK_SOURCE_TC2                /* Internal source clock 2. */

+	};

+

+	tc_interrupt_t tc_interrupt =

+	{

+		.etrgs=0,

+		.ldrbs=0,

+		.ldras=0,

+		.cpcs =1,

+		.cpbs =0,

+		.cpas =0,

+		.lovrs=0,

+		.covfs=0,

+	};

+

+#endif

+

+	/* Disable all interrupt/exception. */

+	portDISABLE_INTERRUPTS();

+

+	/* Register the compare interrupt handler to the interrupt controller and

+	enable the compare interrupt. */

+

+	#if( configTICK_USE_TC==1 )

+	{

+		INTC_register_interrupt(&vTick, configTICK_TC_IRQ, INT0);

+

+		/* Initialize the timer/counter. */

+		tc_init_waveform(tc, &waveform_opt);

+

+		/* Set the compare triggers.

+		Remember TC counter is 16-bits, so counting second is not possible!

+		That's why we configure it to count ms. */

+		tc_write_rc( tc, configTICK_TC_CHANNEL, ( configPBA_CLOCK_HZ / 4) / configTICK_RATE_HZ );

+

+		tc_configure_interrupts( tc, configTICK_TC_CHANNEL, &tc_interrupt );

+

+		/* Start the timer/counter. */

+		tc_start(tc, configTICK_TC_CHANNEL);

+	}

+	#else

+	{

+		INTC_register_interrupt(&vTick, AVR32_CORE_COMPARE_IRQ, INT0);

+		prvScheduleFirstTick();

+	}

+	#endif

+}

diff --git a/FreeRTOS/Source/portable/GCC/AVR32_UC3/portmacro.h b/FreeRTOS/Source/portable/GCC/AVR32_UC3/portmacro.h
new file mode 100644
index 0000000..6aceb4d
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/AVR32_UC3/portmacro.h
@@ -0,0 +1,702 @@
+/*This file has been prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief FreeRTOS port source for AVR32 UC3.

+ *

+ * - Compiler:           GNU GCC for AVR32

+ * - Supported devices:  All AVR32 devices can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ *****************************************************************************/

+

+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+#include <avr32/io.h>

+#include "intc.h"

+#include "compiler.h"

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+

+/* Type definitions. */

+#define portCHAR        char

+#define portFLOAT       float

+#define portDOUBLE      double

+#define portLONG        long

+#define portSHORT       short

+#define portSTACK_TYPE  unsigned portLONG

+#define portBASE_TYPE   portLONG

+

+#define TASK_DELAY_MS(x)   ( (x)        /portTICK_RATE_MS )

+#define TASK_DELAY_S(x)    ( (x)*1000   /portTICK_RATE_MS )

+#define TASK_DELAY_MIN(x)  ( (x)*60*1000/portTICK_RATE_MS )

+

+#define configTICK_TC_IRQ             ATPASTE2(AVR32_TC_IRQ, configTICK_TC_CHANNEL)

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH      ( -1 )

+#define portTICK_RATE_MS      ( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT    4

+#define portNOP()             {__asm__ __volatile__ ("nop");}

+/*-----------------------------------------------------------*/

+

+

+/*-----------------------------------------------------------*/

+

+/* INTC-specific. */

+#define DISABLE_ALL_EXCEPTIONS()    Disable_global_exception()

+#define ENABLE_ALL_EXCEPTIONS()     Enable_global_exception()

+

+#define DISABLE_ALL_INTERRUPTS()    Disable_global_interrupt()

+#define ENABLE_ALL_INTERRUPTS()     Enable_global_interrupt()

+

+#define DISABLE_INT_LEVEL(int_lev)  Disable_interrupt_level(int_lev)

+#define ENABLE_INT_LEVEL(int_lev)   Enable_interrupt_level(int_lev)

+

+

+/*

+ * Debug trace.

+ * Activated if and only if configDBG is nonzero.

+ * Prints a formatted string to stdout.

+ * The current source file name and line number are output with a colon before

+ * the formatted string.

+ * A carriage return and a linefeed are appended to the output.

+ * stdout is redirected to the USART configured by configDBG_USART.

+ * The parameters are the same as for the standard printf function.

+ * There is no return value.

+ * SHALL NOT BE CALLED FROM WITHIN AN INTERRUPT as fputs and printf use malloc,

+ * which is interrupt-unsafe with the current __malloc_lock and __malloc_unlock.

+ */

+#if configDBG

+#define portDBG_TRACE(...) \

+{\

+  fputs(__FILE__ ":" ASTRINGZ(__LINE__) ": ", stdout);\

+  printf(__VA_ARGS__);\

+  fputs("\r\n", stdout);\

+}

+#else

+#define portDBG_TRACE(...)

+#endif

+

+

+/* Critical section management. */

+#define portDISABLE_INTERRUPTS()  DISABLE_ALL_INTERRUPTS()

+#define portENABLE_INTERRUPTS()   ENABLE_ALL_INTERRUPTS()

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()      vPortEnterCritical();

+#define portEXIT_CRITICAL()       vPortExitCritical();

+

+

+/* Added as there is no such function in FreeRTOS. */

+extern void *pvPortRealloc( void *pv, size_t xSize );

+/*-----------------------------------------------------------*/

+

+

+/*=============================================================================================*/

+

+/*

+ * Restore Context for cases other than INTi.

+ */

+#define portRESTORE_CONTEXT()															\

+{																						\

+  extern volatile unsigned portLONG ulCriticalNesting;									\

+  extern volatile void *volatile pxCurrentTCB;											\

+																						\

+  __asm__ __volatile__ (																\

+    /* Set SP to point to new stack */													\

+    "mov     r8, LO(%[pxCurrentTCB])													\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])													\n\t"\

+    "ld.w    r0, r8[0]																	\n\t"\

+    "ld.w    sp, r0[0]																	\n\t"\

+																						\

+    /* Restore ulCriticalNesting variable */											\

+    "ld.w    r0, sp++																	\n\t"\

+    "mov     r8, LO(%[ulCriticalNesting])												\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])												\n\t"\

+    "st.w    r8[0], r0																	\n\t"\

+																						\

+    /* Restore R0..R7 */																\

+    "ldm     sp++, r0-r7																\n\t"\

+    /* R0-R7 should not be used below this line */										\

+    /* Skip PC and SR (will do it at the end) */										\

+    "sub     sp, -2*4																	\n\t"\

+    /* Restore R8..R12 and LR */														\

+    "ldm     sp++, r8-r12, lr															\n\t"\

+    /* Restore SR */																	\

+    "ld.w    r0, sp[-8*4]\n\t" /* R0 is modified, is restored later. */					\

+    "mtsr    %[SR], r0																	\n\t"\

+    /* Restore r0 */																	\

+    "ld.w    r0, sp[-9*4]																\n\t"\

+    /* Restore PC */																	\

+    "ld.w    pc, sp[-7*4]" /* Get PC from stack - PC is the 7th register saved */		\

+    :																					\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting),										\

+      [pxCurrentTCB] "i" (&pxCurrentTCB),												\

+      [SR] "i" (AVR32_SR)																\

+  );																					\

+}

+

+

+/*

+ * portSAVE_CONTEXT_INT() and portRESTORE_CONTEXT_INT(): for INT0..3 exceptions.

+ * portSAVE_CONTEXT_SCALL() and portRESTORE_CONTEXT_SCALL(): for the scall exception.

+ *

+ * Had to make different versions because registers saved on the system stack

+ * are not the same between INT0..3 exceptions and the scall exception.

+ */

+

+// Task context stack layout:

+  // R8  (*)

+  // R9  (*)

+  // R10 (*)

+  // R11 (*)

+  // R12 (*)

+  // R14/LR (*)

+  // R15/PC (*)

+  // SR (*)

+  // R0

+  // R1

+  // R2

+  // R3

+  // R4

+  // R5

+  // R6

+  // R7

+  // ulCriticalNesting

+// (*) automatically done for INT0..INT3, but not for SCALL

+

+/*

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+#if configUSE_PREEMPTION == 0

+

+/*

+ * portSAVE_CONTEXT_OS_INT() for OS Tick exception.

+ */

+#define portSAVE_CONTEXT_OS_INT()														\

+{																						\

+  /* Save R0..R7 */																		\

+  __asm__ __volatile__ ("stm     --sp, r0-r7");											\

+																						\

+  /* With the cooperative scheduler, as there is no context switch by interrupt, */		\

+  /* there is also no context save. */													\

+}

+

+/*

+ * portRESTORE_CONTEXT_OS_INT() for Tick exception.

+ */

+#define portRESTORE_CONTEXT_OS_INT()													\

+{																						\

+  __asm__ __volatile__ (																\

+    /* Restore R0..R7 */																\

+    "ldm     sp++, r0-r7\n\t"															\

+																						\

+    /* With the cooperative scheduler, as there is no context switch by interrupt, */	\

+    /* there is also no context restore. */												\

+    "rete"																				\

+  );																					\

+}

+

+#else

+

+/*

+ * portSAVE_CONTEXT_OS_INT() for OS Tick exception.

+ */

+#define portSAVE_CONTEXT_OS_INT()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* When we come here */																			\

+  /* Registers R8..R12, LR, PC and SR had already been pushed to system stack */					\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Save R0..R7 */																				\

+    "stm     --sp, r0-r7																			\n\t"\

+																									\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */										\

+    "mov     r8, LO(%[ulCriticalNesting])\n\t"														\

+    "orh     r8, HI(%[ulCriticalNesting])\n\t"														\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    --sp, r0																				\n\t"\

+																									\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */	\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+    /* level and allow other lower interrupt level to occur). */									\

+    /* In this case we don't want to do a task switch because we don't know what the stack */		\

+    /* currently looks like (we don't know what the interrupted interrupt handler was doing). */	\

+    /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */		\

+    /* will just be restoring the interrupt handler, no way!!! */									\

+    /* So, since we won't do a vTaskSwitchContext(), it's of no use to save SP. */					\

+    "ld.w    r0, sp[9*4]\n\t" /* Read SR in stack */												\

+    "bfextu  r0, r0, 22, 3\n\t" /* Extract the mode bits to R0. */									\

+    "cp.w    r0, 1\n\t" /* Compare the mode bits with supervisor mode(b'001) */						\

+    "brhi    LABEL_INT_SKIP_SAVE_CONTEXT_%[LINE]													\n\t"\

+																									\

+    /* Store SP in the first member of the structure pointed to by pxCurrentTCB */					\

+    /* NOTE: we don't enter a critical section here because all interrupt handlers */				\

+    /* MUST perform a SAVE_CONTEXT/RESTORE_CONTEXT in the same way as */							\

+    /* portSAVE_CONTEXT_OS_INT/port_RESTORE_CONTEXT_OS_INT if they call OS functions. */			\

+    /* => all interrupt handlers must use portENTER_SWITCHING_ISR/portEXIT_SWITCHING_ISR. */		\

+    "mov     r8, LO(%[pxCurrentTCB])\n\t"															\

+    "orh     r8, HI(%[pxCurrentTCB])\n\t"															\

+    "ld.w    r0, r8[0]\n\t"																			\

+    "st.w    r0[0], sp\n"																			\

+																									\

+    "LABEL_INT_SKIP_SAVE_CONTEXT_%[LINE]:"															\

+    :																								\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting),													\

+      [pxCurrentTCB] "i" (&pxCurrentTCB),															\

+      [LINE] "i" (__LINE__)																			\

+  );																								\

+}

+

+/*

+ * portRESTORE_CONTEXT_OS_INT() for Tick exception.

+ */

+#define portRESTORE_CONTEXT_OS_INT()																\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */		\

+  /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+  /* level and allow other lower interrupt level to occur). */										\

+  /* In this case we don't want to do a task switch because we don't know what the stack */			\

+  /* currently looks like (we don't know what the interrupted interrupt handler was doing). */		\

+  /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */			\

+  /* will just be restoring the interrupt handler, no way!!! */										\

+  __asm__ __volatile__ (																			\

+    "ld.w    r0, sp[9*4]\n\t" /* Read SR in stack */												\

+    "bfextu  r0, r0, 22, 3\n\t" /* Extract the mode bits to R0. */									\

+    "cp.w    r0, 1\n\t" /* Compare the mode bits with supervisor mode(b'001) */						\

+    "brhi    LABEL_INT_SKIP_RESTORE_CONTEXT_%[LINE]"												\

+    :																								\

+    : [LINE] "i" (__LINE__)																			\

+  );																								\

+																									\

+  /* Else */																						\

+  /* because it is here safe, always call vTaskSwitchContext() since an OS tick occurred. */		\

+  /* A critical section has to be used here because vTaskSwitchContext handles FreeRTOS linked lists. */\

+  portENTER_CRITICAL();																				\

+  vTaskSwitchContext();																				\

+  portEXIT_CRITICAL();																				\

+																									\

+  /* Restore all registers */																		\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Set SP to point to new stack */																\

+    "mov     r8, LO(%[pxCurrentTCB])																\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])																\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "ld.w    sp, r0[0]																				\n"\

+																									\

+    "LABEL_INT_SKIP_RESTORE_CONTEXT_%[LINE]:														\n\t"\

+																									\

+    /* Restore ulCriticalNesting variable */														\

+    "ld.w    r0, sp++																				\n\t"																			\

+    "mov     r8, LO(%[ulCriticalNesting])															\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])															\n\t"\

+    "st.w    r8[0], r0																				\n\t"\

+																									\

+    /* Restore R0..R7 */																			\

+    "ldm     sp++, r0-r7																			\n\t"\

+																									\

+    /* Now, the stack should be R8..R12, LR, PC and SR */											\

+    "rete"																							\

+    :																								\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting),													\

+      [pxCurrentTCB] "i" (&pxCurrentTCB),															\

+      [LINE] "i" (__LINE__)																			\

+  );																								\

+}

+

+#endif

+

+

+/*

+ * portSAVE_CONTEXT_SCALL() for SupervisorCALL exception.

+ *

+ * NOTE: taskYIELD()(== SCALL) MUST NOT be called in a mode > supervisor mode.

+ *

+ */

+#define portSAVE_CONTEXT_SCALL()															\

+{																							\

+  extern volatile unsigned portLONG ulCriticalNesting;										\

+  extern volatile void *volatile pxCurrentTCB;												\

+																							\

+  /* Warning: the stack layout after SCALL doesn't match the one after an interrupt. */		\

+  /* If SR[M2:M0] == 001 */																	\

+  /*    PC and SR are on the stack.  */														\

+  /* Else (other modes) */																	\

+  /*    Nothing on the stack. */															\

+																							\

+  /* WARNING NOTE: the else case cannot happen as it is strictly forbidden to call */		\

+  /* vTaskDelay() and vTaskDelayUntil() OS functions (that result in a taskYield()) */		\

+  /* in an interrupt|exception handler. */													\

+																							\

+  __asm__ __volatile__ (																	\

+    /* in order to save R0-R7 */															\

+    "sub     sp, 6*4																		\n\t"\

+    /* Save R0..R7 */																		\

+    "stm     --sp, r0-r7																	\n\t"\

+																							\

+    /* in order to save R8-R12 and LR */													\

+    /* do not use SP if interrupts occurs, SP must be left at bottom of stack */			\

+    "sub     r7, sp,-16*4																	\n\t"\

+    /* Copy PC and SR in other places in the stack. */										\

+    "ld.w    r0, r7[-2*4]																	\n\t" /* Read SR */\

+    "st.w    r7[-8*4], r0																	\n\t" /* Copy SR */\

+    "ld.w    r0, r7[-1*4]																	\n\t" /* Read PC */\

+    "st.w    r7[-7*4], r0																	\n\t" /* Copy PC */\

+																							\

+    /* Save R8..R12 and LR on the stack. */													\

+    "stm     --r7, r8-r12, lr																\n\t"\

+																							\

+    /* Arriving here we have the following stack organizations: */							\

+    /* R8..R12, LR, PC, SR, R0..R7. */														\

+																							\

+    /* Now we can finalize the save. */														\

+																							\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */								\

+    "mov     r8, LO(%[ulCriticalNesting])													\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])													\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "st.w    --sp, r0"																		\

+    :																						\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting)											\

+  );																						\

+																							\

+  /* Disable the its which may cause a context switch (i.e. cause a change of */			\

+  /* pxCurrentTCB). */																		\

+  /* Basically, all accesses to the pxCurrentTCB structure should be put in a */			\

+  /* critical section because it is a global structure. */									\

+  portENTER_CRITICAL();																		\

+																							\

+  /* Store SP in the first member of the structure pointed to by pxCurrentTCB */			\

+  __asm__ __volatile__ (																	\

+    "mov     r8, LO(%[pxCurrentTCB])														\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])														\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "st.w    r0[0], sp"																		\

+    :																						\

+    : [pxCurrentTCB] "i" (&pxCurrentTCB)													\

+  );																						\

+}

+

+/*

+ * portRESTORE_CONTEXT() for SupervisorCALL exception.

+ */

+#define portRESTORE_CONTEXT_SCALL()															\

+{																							\

+  extern volatile unsigned portLONG ulCriticalNesting;										\

+  extern volatile void *volatile pxCurrentTCB;												\

+																							\

+  /* Restore all registers */																\

+																							\

+  /* Set SP to point to new stack */														\

+  __asm__ __volatile__ (																	\

+    "mov     r8, LO(%[pxCurrentTCB])														\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])														\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "ld.w    sp, r0[0]"																		\

+    :																						\

+    : [pxCurrentTCB] "i" (&pxCurrentTCB)													\

+  );																						\

+																							\

+  /* Leave pxCurrentTCB variable access critical section */									\

+  portEXIT_CRITICAL();																		\

+																							\

+  __asm__ __volatile__ (																	\

+    /* Restore ulCriticalNesting variable */												\

+    "ld.w    r0, sp++																		\n\t"\

+    "mov     r8, LO(%[ulCriticalNesting])													\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])													\n\t"\

+    "st.w    r8[0], r0																		\n\t"\

+																							\

+    /* skip PC and SR */																	\

+    /* do not use SP if interrupts occurs, SP must be left at bottom of stack */			\

+    "sub     r7, sp, -10*4																	\n\t"\

+    /* Restore r8-r12 and LR */																\

+    "ldm     r7++, r8-r12, lr																\n\t"\

+																							\

+    /* RETS will take care of the extra PC and SR restore. */								\

+    /* So, we have to prepare the stack for this. */										\

+    "ld.w    r0, r7[-8*4]																	\n\t" /* Read SR */\

+    "st.w    r7[-2*4], r0																	\n\t" /* Copy SR */\

+    "ld.w    r0, r7[-7*4]																	\n\t" /* Read PC */\

+    "st.w    r7[-1*4], r0																	\n\t" /* Copy PC */\

+																							\

+    /* Restore R0..R7 */																	\

+    "ldm     sp++, r0-r7																	\n\t"\

+																							\

+    "sub     sp, -6*4																		\n\t"\

+																							\

+    "rets"																					\

+    :																						\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting)											\

+  );																						\

+}

+

+

+/*

+ * The ISR used depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+#if configUSE_PREEMPTION == 0

+

+/*

+ * ISR entry and exit macros.  These are only required if a task switch

+ * is required from the ISR.

+ */

+#define portENTER_SWITCHING_ISR()															\

+{																							\

+  /* Save R0..R7 */																			\

+  __asm__ __volatile__ ("stm     --sp, r0-r7");												\

+																							\

+  /* With the cooperative scheduler, as there is no context switch by interrupt, */			\

+  /* there is also no context save. */														\

+}

+

+/*

+ * Input parameter: in R12, boolean. Perform a vTaskSwitchContext() if 1

+ */

+#define portEXIT_SWITCHING_ISR()															\

+{																							\

+  __asm__ __volatile__ (																	\

+    /* Restore R0..R7 */																	\

+    "ldm     sp++, r0-r7																	\n\t"\

+																							\

+    /* With the cooperative scheduler, as there is no context switch by interrupt, */		\

+    /* there is also no context restore. */													\

+    "rete"																					\

+  );																						\

+}

+

+#else

+

+/*

+ * ISR entry and exit macros.  These are only required if a task switch

+ * is required from the ISR.

+ */

+#define portENTER_SWITCHING_ISR()															\

+{																							\

+  extern volatile unsigned portLONG ulCriticalNesting;										\

+  extern volatile void *volatile pxCurrentTCB;												\

+																							\

+  /* When we come here */																	\

+  /* Registers R8..R12, LR, PC and SR had already been pushed to system stack */			\

+																							\

+  __asm__ __volatile__ (																	\

+    /* Save R0..R7 */																		\

+    "stm     --sp, r0-r7																	\n\t"\

+																							\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */								\

+    "mov     r8, LO(%[ulCriticalNesting])													\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])													\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "st.w    --sp, r0																		\n\t"\

+																									\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */	\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+    /* level and allow other lower interrupt level to occur). */									\

+    /* In this case we don't want to do a task switch because we don't know what the stack */		\

+    /* currently looks like (we don't know what the interrupted interrupt handler was doing). */	\

+    /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */		\

+    /* will just be restoring the interrupt handler, no way!!! */									\

+    /* So, since we won't do a vTaskSwitchContext(), it's of no use to save SP. */					\

+    "ld.w    r0, sp[9*4]																	\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																	\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																			\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_ISR_SKIP_SAVE_CONTEXT_%[LINE]											\n\t"\

+																							\

+    /* Store SP in the first member of the structure pointed to by pxCurrentTCB */			\

+    "mov     r8, LO(%[pxCurrentTCB])														\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])														\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "st.w    r0[0], sp																		\n"\

+																							\

+    "LABEL_ISR_SKIP_SAVE_CONTEXT_%[LINE]:"													\

+    :																						\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting),											\

+      [pxCurrentTCB] "i" (&pxCurrentTCB),													\

+      [LINE] "i" (__LINE__)																	\

+  );																						\

+}

+

+/*

+ * Input parameter: in R12, boolean. Perform a vTaskSwitchContext() if 1

+ */

+#define portEXIT_SWITCHING_ISR()															\

+{																							\

+  extern volatile unsigned portLONG ulCriticalNesting;										\

+  extern volatile void *volatile pxCurrentTCB;												\

+																							\

+  __asm__ __volatile__ (																	\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */		\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */		\

+    /* level and allow other lower interrupt level to occur). */										\

+    /* In this case it's of no use to switch context and restore a new SP because we purposedly */		\

+    /* did not previously save SP in its TCB. */																				\

+    "ld.w    r0, sp[9*4]																	\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																	\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																			\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_ISR_SKIP_RESTORE_CONTEXT_%[LINE]											\n\t"\

+																							\

+    /* If a switch is required then we just need to call */									\

+    /* vTaskSwitchContext() as the context has already been */								\

+    /* saved. */																			\

+    "cp.w    r12, 1																			\n\t" /* Check if Switch context is required. */\

+    "brne    LABEL_ISR_RESTORE_CONTEXT_%[LINE]"												\

+    :																						\

+    : [LINE] "i" (__LINE__)																	\

+  );																						\

+																							\

+  /* A critical section has to be used here because vTaskSwitchContext handles FreeRTOS linked lists. */	\

+  portENTER_CRITICAL();																		\

+  vTaskSwitchContext();																		\

+  portEXIT_CRITICAL();																		\

+																							\

+  __asm__ __volatile__ (																	\

+    "LABEL_ISR_RESTORE_CONTEXT_%[LINE]:														\n\t"\

+    /* Restore the context of which ever task is now the highest */							\

+    /* priority that is ready to run. */													\

+																							\

+    /* Restore all registers */																\

+																							\

+    /* Set SP to point to new stack */														\

+    "mov     r8, LO(%[pxCurrentTCB])														\n\t"\

+    "orh     r8, HI(%[pxCurrentTCB])														\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "ld.w    sp, r0[0]																		\n"\

+																							\

+    "LABEL_ISR_SKIP_RESTORE_CONTEXT_%[LINE]:												\n\t"\

+																							\

+    /* Restore ulCriticalNesting variable */												\

+    "ld.w    r0, sp++																		\n\t"\

+    "mov     r8, LO(%[ulCriticalNesting])													\n\t"\

+    "orh     r8, HI(%[ulCriticalNesting])													\n\t"\

+    "st.w    r8[0], r0																		\n\t"\

+																							\

+    /* Restore R0..R7 */																	\

+    "ldm     sp++, r0-r7																	\n\t"\

+																							\

+    /* Now, the stack should be R8..R12, LR, PC and SR  */									\

+    "rete"																					\

+    :																						\

+    : [ulCriticalNesting] "i" (&ulCriticalNesting),											\

+      [pxCurrentTCB] "i" (&pxCurrentTCB),													\

+      [LINE] "i" (__LINE__)																	\

+  );																						\

+}

+

+#endif

+

+

+#define portYIELD()                 {__asm__ __volatile__ ("scall");}

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

diff --git a/FreeRTOS/Source/portable/GCC/CORTUS_APS3/port.c b/FreeRTOS/Source/portable/GCC/CORTUS_APS3/port.c
new file mode 100644
index 0000000..e58cfdf
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/CORTUS_APS3/port.c
@@ -0,0 +1,190 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Machine includes */

+#include <machine/counter.h>

+#include <machine/ic.h>

+/*-----------------------------------------------------------*/

+

+/* The initial PSR has the Previous Interrupt Enabled (PIEN) flag set. */

+#define portINITIAL_PSR			( 0x00020000 )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Perform any hardware configuration necessary to generate the tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Make space on the stack for the context - this leaves a couple of spaces

+	empty.  */

+	pxTopOfStack -= 20;

+

+	/* Fill the registers with known values to assist debugging. */

+	pxTopOfStack[ 16 ] = portKERNEL_INTERRUPT_PRIORITY_LEVEL;

+	pxTopOfStack[ 15 ] = portINITIAL_PSR;

+	pxTopOfStack[ 14 ] = ( unsigned long ) pxCode;

+	pxTopOfStack[ 13 ] = 0x00000000UL; /* R15. */

+	pxTopOfStack[ 12 ] = 0x00000000UL; /* R14. */

+	pxTopOfStack[ 11 ] = 0x0d0d0d0dUL;

+	pxTopOfStack[ 10 ] = 0x0c0c0c0cUL;

+	pxTopOfStack[ 9 ] = 0x0b0b0b0bUL;

+	pxTopOfStack[ 8 ] = 0x0a0a0a0aUL;

+	pxTopOfStack[ 7 ] = 0x09090909UL;

+	pxTopOfStack[ 6 ] = 0x08080808UL;

+	pxTopOfStack[ 5 ] = 0x07070707UL;

+	pxTopOfStack[ 4 ] = 0x06060606UL;

+	pxTopOfStack[ 3 ] = 0x05050505UL;

+	pxTopOfStack[ 2 ] = 0x04040404UL;

+	pxTopOfStack[ 1 ] = 0x03030303UL;

+	pxTopOfStack[ 0 ] = ( unsigned long ) pvParameters;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Set-up the timer interrupt. */

+	prvSetupTimerInterrupt();

+

+	/* Enable the TRAP yield. */

+	irq[ portIRQ_TRAP_YIELD ].ien = 1;

+	irq[ portIRQ_TRAP_YIELD ].ipl = portKERNEL_INTERRUPT_PRIORITY_LEVEL;

+

+	/* Integrated Interrupt Controller: Enable all interrupts. */

+	ic->ien = 1;

+

+	/* Restore callee saved registers. */

+	portRESTORE_CONTEXT();

+

+	/* Should not get here. */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	/* Enable timer interrupts */

+	counter1->reload = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1;

+	counter1->value = counter1->reload;

+	counter1->mask = 1;

+

+	/* Set the IRQ Handler priority and enable it. */

+	irq[ IRQ_COUNTER1 ].ien = 1;

+	irq[ IRQ_COUNTER1 ].ipl = portKERNEL_INTERRUPT_PRIORITY_LEVEL;

+}

+/*-----------------------------------------------------------*/

+

+/* Trap 31 handler. */

+void interrupt31_handler( void ) __attribute__((naked));

+void interrupt31_handler( void )

+{

+	portSAVE_CONTEXT();

+	__asm volatile ( "call vTaskSwitchContext" );

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+static void prvProcessTick( void ) __attribute__((noinline));

+static void prvProcessTick( void )

+{

+	vTaskIncrementTick();

+

+	#if configUSE_PREEMPTION == 1

+		vTaskSwitchContext();

+	#endif

+

+	/* Clear the Tick Interrupt. */

+	counter1->expired = 0;

+}

+/*-----------------------------------------------------------*/

+

+/* Timer 1 interrupt handler, used for tick interrupt. */

+void interrupt7_handler( void ) __attribute__((naked));

+void interrupt7_handler( void )

+{

+	portSAVE_CONTEXT();

+	prvProcessTick();

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Nothing to do. Unlikely to want to end. */

+}

+/*-----------------------------------------------------------*/

diff --git a/FreeRTOS/Source/portable/GCC/CORTUS_APS3/portmacro.h b/FreeRTOS/Source/portable/GCC/CORTUS_APS3/portmacro.h
new file mode 100644
index 0000000..870073d
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/CORTUS_APS3/portmacro.h
@@ -0,0 +1,189 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+#include <machine/ic.h>

+

+/*-----------------------------------------------------------

+ * 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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH							( -1 )

+#define portTICK_RATE_MS							( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT							4

+#define portNOP()									__asm__ volatile ( "mov r0, r0" )

+#define portCRITICAL_NESTING_IN_TCB					1

+#define portIRQ_TRAP_YIELD							31

+#define portKERNEL_INTERRUPT_PRIORITY_LEVEL			0

+#define portSYSTEM_INTERRUPT_PRIORITY_LEVEL			0

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+extern void vPortYield( void );

+

+/*---------------------------------------------------------------------------*/

+

+#define portYIELD()		asm __volatile__( " trap #%0 "::"i"(portIRQ_TRAP_YIELD):"memory")

+/*---------------------------------------------------------------------------*/

+

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()		vTaskEnterCritical()

+#define portEXIT_CRITICAL()			vTaskExitCritical()

+/*---------------------------------------------------------------------------*/

+

+/* Critical section management. */

+#define portDISABLE_INTERRUPTS() ic->cpl = ( portSYSTEM_INTERRUPT_PRIORITY_LEVEL + 1 )

+#define portENABLE_INTERRUPTS() ic->cpl = portKERNEL_INTERRUPT_PRIORITY_LEVEL

+

+/*---------------------------------------------------------------------------*/

+

+#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) if( xHigherPriorityTaskWoken != pdFALSE ) vTaskSwitchContext()

+

+/*---------------------------------------------------------------------------*/

+

+#define portSAVE_CONTEXT()				\

+	asm __volatile__																								\

+	(																												\

+		"sub	r1, #68					\n" /* Make space on the stack for the context. */							\

+		"std	r2, [r1] + 	0			\n"																			\

+		"stq	r4, [r1] +	8			\n"																			\

+		"stq	r8, [r1] +	24			\n"																			\

+		"stq	r12, [r1] +	40			\n"																			\

+		"mov	r6, rtt					\n"																			\

+		"mov	r7, psr					\n"																			\

+		"std	r6, [r1] +	56			\n"																			\

+		"movhi	r2, #16384				\n"	/* Set the pointer to the IC. */										\

+		"ldub	r3, [r2] + 2			\n"	/* Load the current interrupt mask. */									\

+		"st		r3, [r1]+ 64			\n"	/* Store the interrupt mask on the stack. */ 							\

+		"ld		r2, [r0]+short(pxCurrentTCB)	\n"	/* Load the pointer to the TCB. */								\

+		"st		r1, [r2]				\n"	/* Save the stack pointer into the TCB. */								\

+		"mov	r14, r1					\n"	/* Compiler expects r14 to be set to the function stack. */				\

+	);

+/*---------------------------------------------------------------------------*/

+

+#define portRESTORE_CONTEXT()																						\

+	asm __volatile__(																								\

+		"ld		r2, [r0]+short(pxCurrentTCB)	\n"	/* Load the TCB to find the stack pointer and context. */		\

+		"ld		r1, [r2]				\n"																			\

+		"movhi	r2, #16384				\n"	/* Set the pointer to the IC. */										\

+		"ld		r3, [r1] + 64			\n"	/* Load the previous interrupt mask. */									\

+		"stb	r3, [r2] + 2  			\n"	/* Set the current interrupt mask to be the previous. */				\

+		"ldd	r6, [r1] + 56			\n"	/* Restore context. */													\

+		"mov	rtt, r6					\n"																			\

+		"mov	psr, r7					\n"																			\

+		"ldd	r2, [r1] + 0			\n"																			\

+		"ldq	r4, [r1] +	8			\n"																			\

+		"ldq	r8, [r1] +	24			\n"																			\

+		"ldq	r12, [r1] +	40			\n"																			\

+		"add	r1, #68					\n"																			\

+		"rti							\n"																			\

+	 );

+

+/*---------------------------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*---------------------------------------------------------------------------*/

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

diff --git a/FreeRTOS/Source/portable/GCC/ColdFire_V2/port.c b/FreeRTOS/Source/portable/GCC/ColdFire_V2/port.c
new file mode 100644
index 0000000..6a38720
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ColdFire_V2/port.c
@@ -0,0 +1,173 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#define portINITIAL_FORMAT_VECTOR		( ( portSTACK_TYPE ) 0x4000 )

+

+/* Supervisor mode set. */

+#define portINITIAL_STATUS_REGISTER		( ( portSTACK_TYPE ) 0x2000)

+

+/* Used to keep track of the number of nested calls to taskENTER_CRITICAL().  This

+will be set to 0 prior to the first task being started. */

+static unsigned long ulCriticalNesting = 0x9999UL;

+

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) 0xDEADBEEF;

+	pxTopOfStack--;

+

+	/* Exception stack frame starts with the return address. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portINITIAL_FORMAT_VECTOR << 16UL ) | ( portINITIAL_STATUS_REGISTER );

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0; /*FP*/

+	pxTopOfStack -= 14; /* A5 to D0. */

+

+    return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	ulCriticalNesting = 0UL;

+

+	/* Configure the interrupts used by this port. */

+	vApplicationSetupInterrupts();

+

+	/* Start the first task executing. */

+	vPortStartFirstTask();

+

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	if( ulCriticalNesting == 0UL )

+	{

+		/* Guard against context switches being pended simultaneously with a

+		critical section being entered. */

+		do

+		{

+			portDISABLE_INTERRUPTS();

+			if( MCF_INTC0_INTFRCL == 0UL )

+			{

+				break;

+			}

+

+			portENABLE_INTERRUPTS();

+

+		} while( 1 );

+	}

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	ulCriticalNesting--;

+	if( ulCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldHandler( void )

+{

+unsigned long ulSavedInterruptMask;

+

+	ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();

+		/* Note this will clear all forced interrupts - this is done for speed. */

+		MCF_INTC0_INTFRCL = 0;

+		vTaskSwitchContext();

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );

+}

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/ColdFire_V2/portasm.S b/FreeRTOS/Source/portable/GCC/ColdFire_V2/portasm.S
new file mode 100644
index 0000000..72d6a7c
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ColdFire_V2/portasm.S
@@ -0,0 +1,159 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * Purpose: Lowest level routines for all ColdFire processors.

+ *

+ * Notes:

+ * 

+ * ulPortSetIPL() and mcf5xxx_wr_cacr() copied with permission from FreeScale

+ * supplied source files.

+ */

+

+    .global ulPortSetIPL

+    .global mcf5xxx_wr_cacr

+    .global __cs3_isr_interrupt_80

+    .global vPortStartFirstTask

+

+    .text

+

+.macro portSAVE_CONTEXT

+

+	lea.l		(-60, %sp), %sp

+	movem.l		%d0-%fp, (%sp)

+	move.l		pxCurrentTCB, %a0

+	move.l		%sp, (%a0)

+

+	.endm

+

+.macro portRESTORE_CONTEXT

+

+	move.l		pxCurrentTCB, %a0

+	move.l		(%a0), %sp

+	movem.l		(%sp), %d0-%fp

+	lea.l		%sp@(60), %sp

+	rte

+

+	.endm

+

+/********************************************************************/

+/*

+ * This routines changes the IPL to the value passed into the routine.

+ * It also returns the old IPL value back.

+ * Calling convention from C:

+ *   old_ipl = asm_set_ipl(new_ipl);

+ * For the Diab Data C compiler, it passes return value thru D0.

+ * Note that only the least significant three bits of the passed

+ * value are used.

+ */

+

+ulPortSetIPL:

+    link    A6,#-8

+    movem.l D6-D7,(SP)

+

+    move.w  SR,D7       /* current sr    */

+

+    move.l  D7,D0       /* prepare return value  */

+    andi.l  #0x0700,D0  /* mask out IPL  */

+    lsr.l   #8,D0       /* IPL   */

+

+    move.l  8(A6),D6    /* get argument  */

+    andi.l  #0x07,D6    /* least significant three bits  */

+    lsl.l   #8,D6       /* move over to make mask    */

+

+    andi.l  #0x0000F8FF,D7  /* zero out current IPL  */

+    or.l    D6,D7           /* place new IPL in sr   */

+    move.w  D7,SR

+

+    movem.l (SP),D6-D7

+    lea     8(SP),SP

+    unlk    A6

+    rts

+/********************************************************************/

+

+mcf5xxx_wr_cacr:

+    move.l  4(sp),d0

+    .long   0x4e7b0002  /* movec d0,cacr   */

+    nop

+    rts

+

+/********************************************************************/

+

+/* Yield interrupt. */

+__cs3_isr_interrupt_80:

+	portSAVE_CONTEXT

+	jsr vPortYieldHandler

+	portRESTORE_CONTEXT

+

+/********************************************************************/

+

+

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+    .end

+

+

diff --git a/FreeRTOS/Source/portable/GCC/ColdFire_V2/portmacro.h b/FreeRTOS/Source/portable/GCC/ColdFire_V2/portmacro.h
new file mode 100644
index 0000000..4638d3a
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/ColdFire_V2/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			4

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+/*-----------------------------------------------------------*/

+unsigned portLONG ulPortSetIPL( unsigned portLONG );

+#define portDISABLE_INTERRUPTS()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portENABLE_INTERRUPTS()		ulPortSetIPL( 0 )

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+extern unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR( void );

+extern void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE );

+#define portSET_INTERRUPT_MASK_FROM_ISR()	ulPortSetIPL( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusRegister ) ulPortSetIPL( uxSavedStatusRegister )

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+#define portNOP()	asm volatile ( 	"nop" )

+

+/* Note this will overwrite all other bits in the force register, it is done this way for speed. */

+#define portYIELD()			MCF_INTC0_INTFRCL = ( 1UL << configYIELD_INTERRUPT_VECTOR ); portNOP(); portNOP()

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters ) __attribute__((noreturn))

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+#define portEND_SWITCHING_ISR( xSwitchRequired )	if( xSwitchRequired != pdFALSE )	\

+													{									\

+														portYIELD();					\

+													}

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/H8S2329/port.c b/FreeRTOS/Source/portable/GCC/H8S2329/port.c
new file mode 100644
index 0000000..d5c69db
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/H8S2329/port.c
@@ -0,0 +1,340 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the H8S port.

+ *----------------------------------------------------------*/

+

+

+/*-----------------------------------------------------------*/

+

+/* When the task starts interrupts should be enabled. */

+#define portINITIAL_CCR			( ( portSTACK_TYPE ) 0x00 )

+

+/* Hardware specific constants used to generate the RTOS tick from the TPU. */

+#define portCLEAR_ON_TGRA_COMPARE_MATCH ( ( unsigned char ) 0x20 )

+#define portCLOCK_DIV_64				( ( unsigned char ) 0x03 )

+#define portCLOCK_DIV					( ( unsigned long ) 64 )

+#define portTGRA_INTERRUPT_ENABLE		( ( unsigned char ) 0x01 )

+#define portTIMER_CHANNEL				( ( unsigned char ) 0x02 )

+#define portMSTP13						( ( unsigned short ) 0x2000 )

+

+/*

+ * Setup TPU channel one for the RTOS tick at the requested frequency.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * The ISR used by portYIELD(). This is installed as a trap handler.

+ */

+void vPortYield( void ) __attribute__ ( ( saveall, interrupt_handler ) );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long ulValue;

+

+	/* This requires an even address. */

+	ulValue = ( unsigned long ) pxTopOfStack;

+	if( ulValue & 1UL )

+	{

+		pxTopOfStack = pxTopOfStack - 1;

+	}

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0xaa;

+	pxTopOfStack--;

+	*pxTopOfStack = 0xbb;

+	pxTopOfStack--;

+	*pxTopOfStack = 0xcc;

+	pxTopOfStack--;

+	*pxTopOfStack = 0xdd;

+

+	/* The initial stack mimics an interrupt stack.  First there is the program

+	counter (24 bits). */

+	ulValue = ( unsigned long ) pxCode;

+

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	pxTopOfStack--;

+	ulValue >>= 8UL;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	pxTopOfStack--;

+	ulValue >>= 8UL;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+

+	/* Followed by the CCR. */	

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_CCR;

+

+	/* Next all the general purpose registers - with the parameters being passed

+	in ER0.  The parameter order must match that used by the compiler when the

+	"saveall" function attribute is used. */

+

+	/* ER6 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x66;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x66;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x66;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x66;

+	

+	/* ER0 */

+	ulValue = ( unsigned long ) pvParameters;

+

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	pxTopOfStack--;

+	ulValue >>= 8UL;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	pxTopOfStack--;

+	ulValue >>= 8UL;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	pxTopOfStack--;

+	ulValue >>= 8UL;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulValue & 0xff );

+	

+	/* ER1 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x11;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x11;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x11;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x11;

+

+	/* ER2 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+

+	/* ER3 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+

+	/* ER4 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x44;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x44;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x44;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x44;

+

+	/* ER5 */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x55;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x55;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x55;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x55;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void * pxCurrentTCB;

+

+	/* Setup the hardware to generate the tick. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run.  This

+	mirrors the function epilogue code generated by the compiler when the

+	"saveall" function attribute is used. */

+	asm volatile ( 

+					"MOV.L		@_pxCurrentTCB, ER6			\n\t"

+					"MOV.L		@ER6, ER7					\n\t"

+					"LDM.L     	@SP+, (ER4-ER5)				\n\t"

+					"LDM.L     	@SP+, (ER0-ER3)				\n\t"

+					"MOV.L     	@ER7+, ER6					\n\t"

+					"RTE									\n\t"

+				);

+

+	( void ) pxCurrentTCB;

+

+	/* Should not get here. */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the h8 port will get stopped. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch.  This is a trap handler.  The "saveall" function

+ * attribute is used so the context is saved by the compiler prologue.  All

+ * we have to do is save the stack pointer.

+ */

+void vPortYield( void )

+{

+	portSAVE_STACK_POINTER();

+		vTaskSwitchContext();

+	portRESTORE_STACK_POINTER();

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The interrupt handler installed for the RTOS tick depends on whether the 

+ * preemptive or cooperative scheduler is being used. 

+ */

+#if( configUSE_PREEMPTION == 1 )

+

+	/* 

+	 * The preemptive scheduler is used so the ISR calls vTaskSwitchContext().

+	 * The function prologue saves the context so all we have to do is save

+	 * the stack pointer.

+	 */

+	void vTickISR( void ) __attribute__ ( ( saveall, interrupt_handler ) );

+	void vTickISR( void )

+	{

+		portSAVE_STACK_POINTER();

+		

+		vTaskIncrementTick();

+		vTaskSwitchContext();

+

+		/* Clear the interrupt. */

+		TSR1 &= ~0x01;

+

+		portRESTORE_STACK_POINTER();

+	}

+

+#else

+

+	/*

+	 * The cooperative scheduler is being used so all we have to do is 

+	 * periodically increment the tick.  This can just be a normal ISR and

+	 * the "saveall" attribute is not required.

+	 */

+	void vTickISR( void ) __attribute__ ( ( interrupt_handler ) );

+	void vTickISR( void )

+	{

+		vTaskIncrementTick();

+

+		/* Clear the interrupt. */

+		TSR1 &= ~0x01;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup timer 1 compare match to generate a tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulCompareMatch = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) / portCLOCK_DIV;

+

+	/* Turn the module on. */

+	MSTPCR &= ~portMSTP13;

+

+	/* Configure timer 1. */

+	TCR1 = portCLEAR_ON_TGRA_COMPARE_MATCH | portCLOCK_DIV_64;

+

+	/* Configure the compare match value for a tick of configTICK_RATE_HZ. */

+	TGR1A = ulCompareMatch;

+

+	/* Start the timer and enable the interrupt - we can do this here as 

+	interrupts are globally disabled when this function is called. */

+	TIER1 |= portTGRA_INTERRUPT_ENABLE;

+	TSTR |= portTIMER_CHANNEL;

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/H8S2329/portmacro.h b/FreeRTOS/Source/portable/GCC/H8S2329/portmacro.h
new file mode 100644
index 0000000..225f345
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/H8S2329/portmacro.h
@@ -0,0 +1,173 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portCHAR

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portYIELD()					asm volatile( "TRAPA #0" )

+#define portNOP()					asm volatile( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENABLE_INTERRUPTS()		asm volatile( "ANDC	#0x7F, CCR" );

+#define portDISABLE_INTERRUPTS()	asm volatile( "ORC  #0x80, CCR" );

+

+/* Push the CCR then disable interrupts. */

+#define portENTER_CRITICAL()  		asm volatile( "STC	CCR, @-ER7" ); \

+                               		portDISABLE_INTERRUPTS();

+

+/* Pop the CCR to set the interrupt masking back to its previous state. */

+#define  portEXIT_CRITICAL()    	asm volatile( "LDC  @ER7+, CCR" );

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/* Context switch macros.  These macros are very simple as the context 

+is saved simply by selecting the saveall attribute of the context switch 

+interrupt service routines.  These macros save and restore the stack

+pointer to the TCB. */

+

+#define portSAVE_STACK_POINTER()								\

+extern void* pxCurrentTCB;										\

+																\

+	asm volatile(												\

+					"MOV.L	@_pxCurrentTCB, ER5			\n\t" 	\

+					"MOV.L	ER7, @ER5					\n\t"	\

+				);												\

+	( void ) pxCurrentTCB;

+

+

+#define	portRESTORE_STACK_POINTER()								\

+extern void* pxCurrentTCB;										\

+																\

+	asm volatile(												\

+					"MOV.L	@_pxCurrentTCB, ER5			\n\t"	\

+					"MOV.L	@ER5, ER7					\n\t"	\

+				);												\

+	( void ) pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+/* Macros to allow a context switch from within an application ISR. */

+

+#define portENTER_SWITCHING_ISR() portSAVE_STACK_POINTER(); {

+

+#define portEXIT_SWITCHING_ISR( x )							\

+	if( x )													\

+	{														\

+		extern void vTaskSwitchContext( void );				\

+		vTaskSwitchContext();								\

+	}														\

+	} portRESTORE_STACK_POINTER();

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/HCS12/port.c b/FreeRTOS/Source/portable/GCC/HCS12/port.c
new file mode 100644
index 0000000..3aa8b9f
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/HCS12/port.c
@@ -0,0 +1,276 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* GCC/HCS12 port by Jefferson L Smith, 2005 */

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Port includes */

+#include <sys/ports_def.h>

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the HCS12 port.

+ *----------------------------------------------------------*/

+

+

+/*

+ * Configure a timer to generate the RTOS tick at the frequency specified 

+ * within FreeRTOSConfig.h.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/* NOTE: Interrupt service routines must be in non-banked memory - as does the

+scheduler startup function. */

+#define ATTR_NEAR	__attribute__((near))

+

+/* Manual context switch function.  This is the SWI ISR. */

+// __attribute__((interrupt))

+void ATTR_NEAR vPortYield( void );

+

+/* Tick context switch function.  This is the timer ISR. */

+// __attribute__((interrupt))

+void ATTR_NEAR vPortTickInterrupt( void );

+

+/* Function in non-banked memory which actually switches to first task. */

+portBASE_TYPE ATTR_NEAR xStartSchedulerNear( void );

+

+/* Calls to portENTER_CRITICAL() can be nested.  When they are nested the 

+critical section should not be left (i.e. interrupts should not be re-enabled)

+until the nesting depth reaches 0.  This variable simply tracks the nesting 

+depth.  Each task maintains it's own critical nesting depth variable so 

+uxCriticalNesting is saved and restored from the task stack during a context

+switch. */

+volatile unsigned portBASE_TYPE uxCriticalNesting = 0x80;  // un-initialized

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro.  In this case the stack as

+	expected by the HCS12 RTI instruction. */

+

+

+	/* The address of the task function is placed in the stack byte at a time. */

+	*pxTopOfStack   = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pxCode) ) + 1 );

+	*--pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pxCode) ) + 0 );

+

+	/* Next are all the registers that form part of the task context. */

+

+	/* Y register */

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0xff;

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0xee;

+

+	/* X register */

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0xdd;

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0xcc;

+ 

+	/* A register contains parameter high byte. */

+	*--pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pvParameters) ) + 0 );

+

+	/* B register contains parameter low byte. */

+	*--pxTopOfStack = ( portSTACK_TYPE ) *( ((portSTACK_TYPE *) (&pvParameters) ) + 1 );

+

+	/* CCR: Note that when the task starts interrupts will be enabled since

+	"I" bit of CCR is cleared */

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0x80;		// keeps Stop disabled (MCU default)

+	

+	/* tmp softregs used by GCC. Values right now don't	matter. */

+	__asm("\n\

+		movw _.frame, 2,-%0							\n\

+		movw _.tmp, 2,-%0							\n\

+		movw _.z, 2,-%0								\n\

+		movw _.xy, 2,-%0							\n\

+		;movw _.d2, 2,-%0							\n\

+		;movw _.d1, 2,-%0							\n\

+	": "=A"(pxTopOfStack) : "0"(pxTopOfStack) );

+

+	#ifdef BANKED_MODEL

+		/* The page of the task. */

+		*--pxTopOfStack = 0x30;      // can only directly start in PPAGE 0x30

+	#endif

+	

+	/* The critical nesting depth is initialised with 0 (meaning not in

+	a critical section). */

+	*--pxTopOfStack = ( portSTACK_TYPE ) 0x00;

+

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the HCS12 port will get stopped. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	/* Enable hardware RTI timer */

+	/* Ignores configTICK_RATE_HZ */

+	RTICTL = 0x50;			// 16 MHz xtal: 976.56 Hz, 1024mS 

+	CRGINT |= 0x80;			// RTIE

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* xPortStartScheduler() does not start the scheduler directly because 

+	the header file containing the xPortStartScheduler() prototype is part 

+	of the common kernel code, and therefore cannot use the CODE_SEG pragma. 

+	Instead it simply calls the locally defined xNearStartScheduler() - 

+	which does use the CODE_SEG pragma. */

+

+	short register d;

+	__asm ("jmp  xStartSchedulerNear		; will never return": "=d"(d));

+	return d;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xStartSchedulerNear( void )

+{

+	/* Configure the timer that will generate the RTOS tick.  Interrupts are

+	disabled when this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task. */

+	portRESTORE_CONTEXT();

+

+	portISR_TAIL();

+

+	/* Should not get here! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Context switch functions.  These are interrupt service routines.

+ */

+

+/*

+ * Manual context switch forced by calling portYIELD().  This is the SWI

+ * handler.

+ */

+void vPortYield( void )

+{

+	portISR_HEAD();

+	/* NOTE: This is the trap routine (swi) although not defined as a trap.

+	   It will fill the stack the same way as an ISR in order to mix preemtion

+	   and cooperative yield. */

+

+	portSAVE_CONTEXT();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT();

+

+	portISR_TAIL();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * RTOS tick interrupt service routine.  If the cooperative scheduler is 

+ * being used then this simply increments the tick count.  If the 

+ * preemptive scheduler is being used a context switch can occur.

+ */

+void vPortTickInterrupt( void )

+{

+	portISR_HEAD();

+

+	/* Clear tick timer flag */

+	CRGFLG = 0x80;

+

+	#if configUSE_PREEMPTION == 1

+	{

+		/* A context switch might happen so save the context. */

+		portSAVE_CONTEXT();

+

+		/* Increment the tick ... */

+		vTaskIncrementTick();

+

+		/* ... then see if the new tick value has necessitated a

+		context switch. */

+		vTaskSwitchContext();

+

+		/* Restore the context of a task - which may be a different task

+		to that interrupted. */

+		portRESTORE_CONTEXT();

+	}

+	#else

+	{

+		vTaskIncrementTick();

+	}

+	#endif

+

+	portISR_TAIL();

+}

+

diff --git a/FreeRTOS/Source/portable/GCC/HCS12/portmacro.h b/FreeRTOS/Source/portable/GCC/HCS12/portmacro.h
new file mode 100644
index 0000000..f182556
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/HCS12/portmacro.h
@@ -0,0 +1,280 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portCHAR

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			1

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portYIELD()					__asm( "swi" );

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENABLE_INTERRUPTS()				__asm( "cli" )	

+#define portDISABLE_INTERRUPTS()			__asm( "sei" )

+

+/*

+ * Disable interrupts before incrementing the count of critical section nesting.

+ * The nesting count is maintained so we know when interrupts should be

+ * re-enabled.  Once interrupts are disabled the nesting count can be accessed

+ * directly.  Each task maintains its own nesting count.

+ */

+#define portENTER_CRITICAL()  									\

+{																\

+	extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																\

+	portDISABLE_INTERRUPTS();									\

+	uxCriticalNesting++;										\

+}

+

+/*

+ * Interrupts are disabled so we can access the nesting count directly.  If the

+ * nesting is found to be 0 (no nesting) then we are leaving the critical 

+ * section and interrupts can be re-enabled.

+ */

+#define  portEXIT_CRITICAL()									\

+{																\

+	extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+																\

+	uxCriticalNesting--;										\

+	if( uxCriticalNesting == 0 )								\

+	{															\

+		portENABLE_INTERRUPTS();								\

+	}															\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/* 

+ * These macros are very simple as the processor automatically saves and 

+ * restores its registers as interrupts are entered and exited.  In

+ * addition to the (automatically stacked) registers we also stack the 

+ * critical nesting count.  Each task maintains its own critical nesting

+ * count as it is legitimate for a task to yield from within a critical

+ * section.  If the banked memory model is being used then the PPAGE

+ * register is also stored as part of the tasks context.

+ */

+

+#ifdef BANKED_MODEL

+	/* 

+	 * Load the stack pointer for the task, then pull the critical nesting

+	 * count and PPAGE register from the stack.  The remains of the 

+	 * context are restored by the RTI instruction.

+	 */

+	#define portRESTORE_CONTEXT()							\

+	{										\

+		__asm( "								\n\

+		.globl pxCurrentTCB			; void *			\n\

+		.globl uxCriticalNesting		; char				\n\

+											\n\

+		ldx  pxCurrentTCB							\n\

+		lds  0,x				; Stack				\n\

+											\n\

+		movb 1,sp+,uxCriticalNesting						\n\

+		movb 1,sp+,0x30				; PPAGE				\n\

+		" );									\

+	}

+

+	/* 

+	 * By the time this macro is called the processor has already stacked the

+	 * registers.  Simply stack the nesting count and PPAGE value, then save 

+	 * the task stack pointer.

+	 */

+	#define portSAVE_CONTEXT()							\

+	{										\

+		__asm( "								\n\

+		.globl pxCurrentTCB			; void *			\n\

+		.globl uxCriticalNesting		; char				\n\

+											\n\

+		movb 0x30, 1,-sp			; PPAGE				\n\

+		movb uxCriticalNesting, 1,-sp						\n\

+											\n\

+		ldx  pxCurrentTCB							\n\

+		sts  0,x				; Stack				\n\

+		" );									\

+	}

+#else

+

+	/* 

+	 * These macros are as per the BANKED versions above, but without saving

+	 * and restoring the PPAGE register.

+	 */

+

+	#define portRESTORE_CONTEXT()							\

+	{										\

+		__asm( "								\n\

+		.globl pxCurrentTCB			; void *			\n\

+		.globl uxCriticalNesting		; char				\n\

+											\n\

+		ldx  pxCurrentTCB							\n\

+		lds  0,x				; Stack				\n\

+											\n\

+		movb 1,sp+,uxCriticalNesting						\n\

+		" );									\

+	}

+

+	#define portSAVE_CONTEXT()							\

+	{										\

+		__asm( "								\n\

+		.globl pxCurrentTCB			; void *			\n\

+		.globl uxCriticalNesting		; char				\n\

+											\n\

+		movb uxCriticalNesting, 1,-sp						\n\

+											\n\

+		ldx  pxCurrentTCB							\n\

+		sts  0,x				; Stack				\n\

+		" );									\

+	}

+#endif

+

+/*

+ * Utility macros to save/restore correct software registers for GCC. This is

+ * useful when GCC does not generate appropriate ISR head/tail code.

+ */

+#define portISR_HEAD()									\

+{											\

+		__asm("									\n\

+		movw _.frame, 2,-sp							\n\

+		movw _.tmp, 2,-sp							\n\

+		movw _.z, 2,-sp								\n\

+		movw _.xy, 2,-sp							\n\

+		;movw _.d2, 2,-sp							\n\

+		;movw _.d1, 2,-sp							\n\

+		");									\

+}

+

+#define portISR_TAIL()									\

+{											\

+		__asm("									\n\

+		movw 2,sp+, _.xy							\n\

+		movw 2,sp+, _.z								\n\

+		movw 2,sp+, _.tmp							\n\

+		movw 2,sp+, _.frame							\n\

+		;movw 2,sp+, _.d1							\n\

+		;movw 2,sp+, _.d2							\n\

+		rti									\n\

+		");									\

+}

+

+/*

+ * Utility macro to call macros above in correct order in order to perform a

+ * task switch from within a standard ISR.  This macro can only be used if

+ * the ISR does not use any local (stack) variables.  If the ISR uses stack

+ * variables portYIELD() should be used in it's place.

+ */

+

+#define portTASK_SWITCH_FROM_ISR()								\

+	portSAVE_CONTEXT();											\

+	vTaskSwitchContext();										\

+	portRESTORE_CONTEXT();

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/MCF5235/port.c b/FreeRTOS/Source/portable/GCC/MCF5235/port.c
new file mode 100644
index 0000000..837ad44
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MCF5235/port.c
@@ -0,0 +1,283 @@
+/*

+    FreeRTOS V4.1.1 - Copyright (C) 2003-2006 Richard Barry.

+    MCF5235 Port - Copyright (C) 2006 Christian Walter.

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify

+    it under the terms of the GNU General Public License** as published by

+    the Free Software Foundation; either version 2 of the License, or

+    (at your option) any later version.

+

+    FreeRTOS is distributed in the hope that it will be useful,

+    but WITHOUT ANY WARRANTY; without even the implied warranty of

+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the

+    GNU General Public License for more details.

+

+    You should have received a copy of the GNU General Public License

+    along with FreeRTOS; if not, write to the Free Software

+    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

+

+    A special exception to the GPL can be applied should you wish to distribute

+    a combined work that includes FreeRTOS, without being obliged to provide

+    the source code for any proprietary components.  See the licensing section

+    of http://www.FreeRTOS.org for full details of how and when the exception

+    can be applied.

+

+    ***************************************************************************

+    ***************************************************************************

+    *                                                                         *

+    * Get the FreeRTOS eBook!  See http://www.FreeRTOS.org/Documentation      *

+	*                                                                         *

+	* This is a concise, step by step, 'hands on' guide that describes both   *

+	* general multitasking concepts and FreeRTOS specifics. It presents and   *

+	* explains numerous examples that are written using the FreeRTOS API.     *

+	* Full source code for all the examples is provided in an accompanying    *

+	* .zip file.                                                              *

+    *                                                                         *

+    ***************************************************************************

+    ***************************************************************************

+

+	Please ensure to read the configuration and relevant port sections of the

+	online documentation.

+

+	http://www.FreeRTOS.org - Documentation, latest information, license and 

+	contact details.

+

+	http://www.SafeRTOS.com - A version that is certified for use in safety 

+	critical systems.

+

+	http://www.OpenRTOS.com - Commercial support, development, porting, 

+	licensing and training services.

+*/

+

+#include <stdlib.h>

+

+#include "FreeRTOS.h"

+#include "FreeRTOSConfig.h"

+#include "task.h"

+

+/* ------------------------ Types ----------------------------------------- */

+typedef volatile unsigned long vuint32;

+typedef volatile unsigned short vuint16;

+typedef volatile unsigned char vuint8;

+

+/* ------------------------ Defines --------------------------------------- */

+#define portVECTOR_TABLE                __RAMVEC

+#define portVECTOR_SYSCALL              ( 32 + portTRAP_YIELD )

+#define portVECTOR_TIMER                ( 64 + 36 )

+

+#define MCF_PIT_PRESCALER               512UL

+#define MCF_PIT_TIMER_TICKS             ( FSYS_2 / MCF_PIT_PRESCALER )

+#define MCF_PIT_MODULUS_REGISTER(freq)  ( MCF_PIT_TIMER_TICKS / ( freq ) - 1UL)

+

+#define MCF_PIT_PMR0                    ( *( vuint16 * )( void * )( &__IPSBAR[ 0x150002 ] ) )

+#define MCF_PIT_PCSR0                   ( *( vuint16 * )( void * )( &__IPSBAR[ 0x150000 ] ) )

+#define MCF_PIT_PCSR_PRE(x)             ( ( ( x ) & 0x000F ) << 8 )

+#define MCF_PIT_PCSR_EN                 ( 0x0001 )

+#define MCF_PIT_PCSR_RLD                ( 0x0002 )

+#define MCF_PIT_PCSR_PIF                ( 0x0004 )

+#define MCF_PIT_PCSR_PIE                ( 0x0008 )

+#define MCF_PIT_PCSR_OVW                ( 0x0010 )

+#define MCF_INTC0_ICR36                 ( *( vuint8 * )( void * )( &__IPSBAR[ 0x000C64 ] ) )

+#define MCF_INTC0_IMRH                  ( *( vuint32 * )( void * )( &__IPSBAR[ 0x000C08 ] ) )

+#define MCF_INTC0_IMRH_INT_MASK36       ( 0x00000010 )

+#define MCF_INTC0_IMRH_MASKALL          ( 0x00000001 )

+#define MCF_INTC0_ICRn_IP(x)            ( ( ( x ) & 0x07 ) << 0 )

+#define MCF_INTC0_ICRn_IL(x)            ( ( ( x ) & 0x07 ) << 3 )

+

+#define portNO_CRITICAL_NESTING         ( ( unsigned long ) 0 )

+#define portINITIAL_CRITICAL_NESTING    ( ( unsigned long ) 10 )

+

+/* ------------------------ Static variables ------------------------------ */

+volatile unsigned long              ulCriticalNesting = portINITIAL_CRITICAL_NESTING;

+

+/* ------------------------ Static functions ------------------------------ */

+#if configUSE_PREEMPTION == 0

+static void prvPortPreemptiveTick ( void ) __attribute__ ((interrupt_handler));

+#else

+static void prvPortPreemptiveTick ( void );

+#endif

+

+/* ------------------------ Start implementation -------------------------- */

+

+portSTACK_TYPE *

+pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode,

+                       void *pvParameters )

+{

+    /* Place the parameter on the stack in the expected location. */

+    *pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+    pxTopOfStack--;

+

+    /* Place dummy return address on stack. Tasks should never terminate so

+     * we can set this to anything. */

+    *pxTopOfStack = ( portSTACK_TYPE ) 0;

+    pxTopOfStack--;

+

+    /* Create a Motorola Coldfire exception stack frame. First comes the return

+     * address. */

+    *pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+    pxTopOfStack--;

+

+    /* Format, fault-status, vector number for exception stack frame. Task

+     * run in supervisor mode. */

+    *pxTopOfStack = 0x40002000UL | ( portVECTOR_SYSCALL + 32 ) << 18;

+    pxTopOfStack--;

+

+    /* Set the initial critical section nesting counter to zero. This value

+     * is used to restore the value of ulCriticalNesting. */

+    *pxTopOfStack = 0;

+    *pxTopOfStack--;

+

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA6;    /* A6 / FP */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA5;    /* A5 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA4;    /* A4 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA3;    /* A3 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA2;    /* A2 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA1;    /* A1 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xA0;    /* A0 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD7;    /* D7 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD6;    /* D6 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD5;    /* D5 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD4;    /* D4 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD3;    /* D3 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD2;    /* D2 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD1;    /* D1 */

+    pxTopOfStack--;

+    *pxTopOfStack = ( portSTACK_TYPE ) 0xD0;    /* D0 */

+

+    return pxTopOfStack;

+}

+

+/*

+ * Called by portYIELD() or taskYIELD() to manually force a context switch.

+ */

+static void

+prvPortYield( void )

+{

+    asm volatile ( "move.w  #0x2700, %sr\n\t" );

+#if _GCC_USES_FP == 1

+    asm volatile ( "unlk %fp\n\t" );

+#endif

+     /* Perform the context switch.  First save the context of the current task. */

+    portSAVE_CONTEXT(  );

+

+    /* Find the highest priority task that is ready to run. */

+    vTaskSwitchContext(  );

+

+    /* Restore the context of the new task. */

+    portRESTORE_CONTEXT(  );

+}

+

+#if configUSE_PREEMPTION == 0

+/*

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+static void

+prvPortPreemptiveTick ( void )

+{

+    /* The cooperative scheduler requires a normal IRQ service routine to

+     * simply increment the system tick.

+     */

+

+    vTaskIncrementTick(  );

+    MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIF;

+}

+

+#else

+

+static void

+prvPortPreemptiveTick( void )

+{

+    asm volatile ( "move.w  #0x2700, %sr\n\t" );

+#if _GCC_USES_FP == 1

+    asm volatile ( "unlk %fp\n\t" );

+#endif

+    portSAVE_CONTEXT(  );

+    MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIF;

+    vTaskIncrementTick(  );

+    vTaskSwitchContext(  );

+    portRESTORE_CONTEXT(  );

+}

+#endif

+

+void

+vPortEnterCritical()

+{

+    /* FIXME: We should store the old IPL here - How are we supposed to do

+     * this.

+     */

+    ( void )portSET_IPL( portIPL_MAX );

+

+    /* Now interrupts are disabled ulCriticalNesting can be accessed

+     * directly.  Increment ulCriticalNesting to keep a count of how many times

+     * portENTER_CRITICAL() has been called. */

+    ulCriticalNesting++;

+}

+

+void

+vPortExitCritical()

+{

+    if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+    {

+        /* Decrement the nesting count as we are leaving a critical section. */

+        ulCriticalNesting--;

+

+        /* If the nesting level has reached zero then interrupts should be

+        re-enabled. */

+        if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+        {

+            ( void )portSET_IPL( 0 );

+        }

+    }

+}

+

+portBASE_TYPE

+xPortStartScheduler( void )

+{

+    extern void     ( *portVECTOR_TABLE[  ] ) (  );

+

+    /* Add entry in vector table for yield system call. */

+    portVECTOR_TABLE[ portVECTOR_SYSCALL ] = prvPortYield;

+    /* Add entry in vector table for periodic timer. */

+    portVECTOR_TABLE[ portVECTOR_TIMER ] = prvPortPreemptiveTick;

+

+    /* Configure the timer for the system clock. */

+    if ( configTICK_RATE_HZ > 0)

+    {

+        /* Configure prescaler */

+        MCF_PIT_PCSR0 = MCF_PIT_PCSR_PRE( 0x9 ) | MCF_PIT_PCSR_RLD | MCF_PIT_PCSR_OVW;

+        /* Initialize the periodic timer interrupt. */

+        MCF_PIT_PMR0 = MCF_PIT_MODULUS_REGISTER( configTICK_RATE_HZ );

+        /* Configure interrupt priority and level and unmask interrupt. */

+        MCF_INTC0_ICR36 = MCF_INTC0_ICRn_IL( 0x1 ) | MCF_INTC0_ICRn_IP( 0x1 );

+        MCF_INTC0_IMRH &= ~( MCF_INTC0_IMRH_INT_MASK36 | MCF_INTC0_IMRH_MASKALL );

+        /* Enable interrupts */

+        MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIE | MCF_PIT_PCSR_EN | MCF_PIT_PCSR_PIF;

+    }

+

+    /* Restore the context of the first task that is going to run. */

+    portRESTORE_CONTEXT(  );

+

+    /* Should not get here. */

+    return pdTRUE;

+}

+

+void

+vPortEndScheduler( void )

+{

+}

diff --git a/FreeRTOS/Source/portable/GCC/MCF5235/portmacro.h b/FreeRTOS/Source/portable/GCC/MCF5235/portmacro.h
new file mode 100644
index 0000000..90ecf78
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MCF5235/portmacro.h
@@ -0,0 +1,178 @@
+/*

+    FreeRTOS V4.1.1 - Copyright (C) 2003-2006 Richard Barry.

+    MCF5235 Port - Copyright (C) 2006 Christian Walter.

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify

+    it under the terms of the GNU General Public License** as published by

+    the Free Software Foundation; either version 2 of the License, or

+    (at your option) any later version.

+

+    FreeRTOS is distributed in the hope that it will be useful,

+    but WITHOUT ANY WARRANTY; without even the implied warranty of

+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the

+    GNU General Public License for more details.

+

+    You should have received a copy of the GNU General Public License

+    along with FreeRTOS; if not, write to the Free Software

+    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

+

+    A special exception to the GPL can be applied should you wish to distribute

+    a combined work that includes FreeRTOS, without being obliged to provide

+    the source code for any proprietary components.  See the licensing section

+    of http://www.FreeRTOS.org for full details of how and when the exception

+    can be applied.

+

+    ***************************************************************************

+    ***************************************************************************

+    *                                                                         *

+    * Get the FreeRTOS eBook!  See http://www.FreeRTOS.org/Documentation      *

+	*                                                                         *

+	* This is a concise, step by step, 'hands on' guide that describes both   *

+	* general multitasking concepts and FreeRTOS specifics. It presents and   *

+	* explains numerous examples that are written using the FreeRTOS API.     *

+	* Full source code for all the examples is provided in an accompanying    *

+	* .zip file.                                                              *

+    *                                                                         *

+    ***************************************************************************

+    ***************************************************************************

+

+	Please ensure to read the configuration and relevant port sections of the

+	online documentation.

+

+	http://www.FreeRTOS.org - Documentation, latest information, license and 

+	contact details.

+

+	http://www.SafeRTOS.com - A version that is certified for use in safety 

+	critical systems.

+

+	http://www.OpenRTOS.com - Commercial support, development, porting, 

+	licensing and training services.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* ------------------------ Data types for Coldfire ----------------------- */

+#define portCHAR        char

+#define portFLOAT       float

+#define portDOUBLE      double

+#define portLONG        long

+#define portSHORT       short

+#define portSTACK_TYPE  unsigned int

+#define portBASE_TYPE   int

+

+#if( configUSE_16_BIT_TICKS == 1 )

+    typedef unsigned portSHORT portTickType;

+    #define portMAX_DELAY ( portTickType ) 0xffff

+#else

+    typedef unsigned portLONG portTickType;

+    #define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/* ------------------------ Architecture specifics ------------------------ */

+#define portSTACK_GROWTH                ( -1 )

+#define portTICK_RATE_MS                ( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT              4

+

+#define portTRAP_YIELD                  0   /* Trap 0 */

+#define portIPL_MAX                     7   /* Only NMI interrupt 7 allowed. */

+

+/* ------------------------ FreeRTOS macros for port ---------------------- */

+

+/*

+ * This function must be called when the current state of the active task

+ * should be stored. It must be called immediately after exception

+ * processing from the CPU, i.e. there exists a Coldfire exception frame at

+ * the current position in the stack. The function reserves space on

+ * the stack for the CPU registers and other task dependent values (e.g

+ * ulCriticalNesting) and updates the top of the stack in the TCB.

+ */

+#define portSAVE_CONTEXT()                                                   \

+    asm volatile ( /* reserve space for task state. */                       \

+                   "lea.l   (-64, %sp), %sp\n\t"                             \

+                   /* push data register %d0-%d7/%a0-%a6 on stack. */        \

+                   "movem.l %d0-%d7/%a0-%a6, (%sp)\n\t"                      \

+                   /* push ulCriticalNesting counter on stack. */            \

+                   "lea.l  (60, %sp), %a0\n\t"                               \

+                   "move.l  ulCriticalNesting, (%a0)\n\t"                    \

+                   /* set the new top of the stack in the TCB. */            \

+                   "move.l  pxCurrentTCB, %a0\n\t"                           \

+                   "move.l  %sp, (%a0)");

+

+/*.

+ * This function restores the current active and continues its execution.

+ * It loads the current TCB and restores the processor registers, the

+ * task dependent values (e.g ulCriticalNesting). Finally execution

+ * is continued by executing an rte instruction.

+ */

+#define portRESTORE_CONTEXT()                                                \

+    asm volatile ( "move.l  pxCurrentTCB, %sp\n\t"                           \

+                   "move.l  (%sp), %sp\n\t"                                  \

+                   /* stack pointer now points to the saved registers. */    \

+                   "movem.l (%sp), %d0-%d7/%a0-%a6\n\t"                      \

+                   /* restore ulCriticalNesting counter from stack. */       \

+                   "lea.l   (%sp, 60), %sp\n\t"                              \

+                   "move.l  (%sp)+, ulCriticalNesting\n\t"                   \

+                   /* stack pointer now points to exception frame. */        \

+                   "rte\n\t" );

+

+#define portENTER_CRITICAL()                                                 \

+    vPortEnterCritical();

+

+#define portEXIT_CRITICAL()                                                  \

+    vPortExitCritical();

+

+#define portSET_IPL( xIPL )                                                  \

+    asm_set_ipl( xIPL )

+

+#define portDISABLE_INTERRUPTS() \

+    do { ( void )portSET_IPL( portIPL_MAX ); } while( 0 )

+#define portENABLE_INTERRUPTS() \

+    do { ( void )portSET_IPL( 0 ); } while( 0 )

+

+#define portYIELD()                                                          \

+    asm volatile ( " trap   %0\n\t" : : "i"(portTRAP_YIELD) )

+

+#define portNOP()                                                            \

+    asm volatile ( "nop\n\t" )

+

+#define portENTER_SWITCHING_ISR()                                            \

+    asm volatile ( "move.w  #0x2700, %sr" );                                 \

+    /* Save the context of the interrupted task. */                          \

+    portSAVE_CONTEXT(  );                                                    \

+    {

+

+#define portEXIT_SWITCHING_ISR( SwitchRequired )                             \

+        /* If a switch is required we call vTaskSwitchContext(). */          \

+        if( SwitchRequired )                                                 \

+        {                                                                    \

+            vTaskSwitchContext(  );                                          \

+        }                                                                    \

+    }                                                                        \

+    portRESTORE_CONTEXT(  );

+

+/* ------------------------ Function prototypes --------------------------- */

+void vPortEnterCritical( void );

+void vPortExitCritical( void );

+int asm_set_ipl( unsigned long int uiNewIPL );

+

+/* ------------------------ Compiler specifics ---------------------------- */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters )                   \

+    void vFunction( void *pvParameters )

+

+#define portTASK_FUNCTION( vFunction, pvParameters )                         \

+    void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/MSP430F449/port.c b/FreeRTOS/Source/portable/GCC/MSP430F449/port.c
new file mode 100644
index 0000000..1233531
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MSP430F449/port.c
@@ -0,0 +1,365 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+	Changes from V2.5.2

+		

+	+ usCriticalNesting now has a volatile qualifier.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+#include <signal.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MSP430 port.

+ *----------------------------------------------------------*/

+

+/* Constants required for hardware setup.  The tick ISR runs off the ACLK, 

+not the MCLK. */

+#define portACLK_FREQUENCY_HZ			( ( portTickType ) 32768 )

+#define portINITIAL_CRITICAL_NESTING	( ( unsigned short ) 10 )

+#define portFLAGS_INT_ENABLED	( ( portSTACK_TYPE ) 0x08 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Most ports implement critical sections by placing the interrupt flags on

+the stack before disabling interrupts.  Exiting the critical section is then

+simply a case of popping the flags from the stack.  As mspgcc does not use

+a frame pointer this cannot be done as modifying the stack will clobber all

+the stack variables.  Instead each task maintains a count of the critical

+section nesting depth.  Each time a critical section is entered the count is

+incremented.  Each time a critical section is left the count is decremented -

+with interrupts only being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+/* 

+ * Macro to save a task context to the task stack.  This simply pushes all the 

+ * general purpose msp430 registers onto the stack, followed by the 

+ * usCriticalNesting value used by the task.  Finally the resultant stack 

+ * pointer value is saved into the task control block so it can be retrieved 

+ * the next time the task executes.

+ */

+#define portSAVE_CONTEXT()									\

+	asm volatile (	"push	r4						\n\t"	\

+					"push	r5						\n\t"	\

+					"push	r6						\n\t"	\

+					"push	r7						\n\t"	\

+					"push	r8						\n\t"	\

+					"push	r9						\n\t"	\

+					"push	r10						\n\t"	\

+					"push	r11						\n\t"	\

+					"push	r12						\n\t"	\

+					"push	r13						\n\t"	\

+					"push	r14						\n\t"	\

+					"push	r15						\n\t"	\

+					"mov.w	usCriticalNesting, r14	\n\t"	\

+					"push	r14						\n\t"	\

+					"mov.w	pxCurrentTCB, r12		\n\t"	\

+					"mov.w	r1, @r12				\n\t"	\

+				);

+

+/* 

+ * Macro to restore a task context from the task stack.  This is effectively

+ * the reverse of portSAVE_CONTEXT().  First the stack pointer value is

+ * loaded from the task control block.  Next the value for usCriticalNesting

+ * used by the task is retrieved from the stack - followed by the value of all

+ * the general purpose msp430 registers.

+ *

+ * The bic instruction ensures there are no low power bits set in the status

+ * register that is about to be popped from the stack.

+ */

+#define portRESTORE_CONTEXT()								\

+	asm volatile (	"mov.w	pxCurrentTCB, r12		\n\t"	\

+					"mov.w	@r12, r1				\n\t"	\

+					"pop	r15						\n\t"	\

+					"mov.w	r15, usCriticalNesting	\n\t"	\

+					"pop	r15						\n\t"	\

+					"pop	r14						\n\t"	\

+					"pop	r13						\n\t"	\

+					"pop	r12						\n\t"	\

+					"pop	r11						\n\t"	\

+					"pop	r10						\n\t"	\

+					"pop	r9						\n\t"	\

+					"pop	r8						\n\t"	\

+					"pop	r7						\n\t"	\

+					"pop	r6						\n\t"	\

+					"pop	r5						\n\t"	\

+					"pop	r4						\n\t"	\

+					"bic	#(0xf0),0(r1)			\n\t"	\

+					"reti							\n\t"	\

+				);

+/*-----------------------------------------------------------*/

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* 

+		Place a few bytes of known values on the bottom of the stack. 

+		This is just useful for debugging and can be included if required.

+

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;

+		pxTopOfStack--; 

+	*/

+

+	/* The msp430 automatically pushes the PC then SR onto the stack before 

+	executing an ISR.  We want the stack to look just as if this has happened

+	so place a pointer to the start of the task on the stack first - followed

+	by the flags we want the task to use when it starts up. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+	*pxTopOfStack = portFLAGS_INT_ENABLED;

+	pxTopOfStack--;

+

+	/* Next the general purpose registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x7777;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaa;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xbbbb;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xcccc;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xdddd;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xeeee;

+	pxTopOfStack--;

+

+	/* When the task starts is will expect to find the function parameter in

+	R15. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	/* The code generated by the mspgcc compiler does not maintain separate

+	stack and frame pointers. The portENTER_CRITICAL macro cannot therefore

+	use the stack as per other ports.  Instead a variable is used to keep

+	track of the critical section nesting.  This variable has to be stored

+	as part of the task context and is initially set to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	portRESTORE_CONTEXT();

+

+	/* Should not get here as the tasks are now running! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the MSP430 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.  

+ *

+ * The first thing we do is save the registers so we can use a naked attribute.

+ */

+void vPortYield( void ) __attribute__ ( ( naked ) );

+void vPortYield( void )

+{

+	/* We want the stack of the task being saved to look exactly as if the task

+	was saved during a pre-emptive RTOS tick ISR.  Before calling an ISR the 

+	msp430 places the status register onto the stack.  As this is a function 

+	call and not an ISR we have to do this manually. */

+	asm volatile ( "push	r2" );

+	_DINT();

+

+	/* Save the context of the current task. */

+	portSAVE_CONTEXT();

+

+	/* Switch to the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.  This uses timer 0

+ * but could alternatively use the watchdog timer or timer 1. 

+ */

+static void prvSetupTimerInterrupt( void )

+{

+	/* Ensure the timer is stopped. */

+	TACTL = 0;

+

+	/* Run the timer of the ACLK. */

+	TACTL = TASSEL_1;

+

+	/* Clear everything to start with. */

+	TACTL |= TACLR;

+

+	/* Set the compare match value according to the tick rate we want. */

+	TACCR0 = portACLK_FREQUENCY_HZ / configTICK_RATE_HZ;

+

+	/* Enable the interrupts. */

+	TACCTL0 = CCIE;

+

+	/* Start up clean. */

+	TACTL |= TACLR;

+

+	/* Up mode. */

+	TACTL |= MC_1;

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * The interrupt service routine used depends on whether the pre-emptive

+ * scheduler is being used or not.

+ */

+

+#if configUSE_PREEMPTION == 1

+

+	/*

+	 * Tick ISR for preemptive scheduler.  We can use a naked attribute as

+	 * the context is saved at the start of vPortYieldFromTick().  The tick

+	 * count is incremented after the context is saved.

+	 */

+	interrupt (TIMERA0_VECTOR) prvTickISR( void ) __attribute__ ( ( naked ) );

+	interrupt (TIMERA0_VECTOR) prvTickISR( void )

+	{

+		/* Save the context of the interrupted task. */

+		portSAVE_CONTEXT();

+

+		/* Increment the tick count then switch to the highest priority task

+		that is ready to run. */

+		vTaskIncrementTick();

+		vTaskSwitchContext();

+

+		/* Restore the context of the new task. */

+		portRESTORE_CONTEXT();

+	}

+

+#else

+

+	/*

+	 * Tick ISR for the cooperative scheduler.  All this does is increment the

+	 * tick count.  We don't need to switch context, this can only be done by

+	 * manual calls to taskYIELD();

+	 */

+	interrupt (TIMERA0_VECTOR) prvTickISR( void );

+	interrupt (TIMERA0_VECTOR) prvTickISR( void )

+	{

+		vTaskIncrementTick();

+	}

+#endif

+

+

+	

diff --git a/FreeRTOS/Source/portable/GCC/MSP430F449/portmacro.h b/FreeRTOS/Source/portable/GCC/MSP430F449/portmacro.h
new file mode 100644
index 0000000..176c4c4
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MSP430F449/portmacro.h
@@ -0,0 +1,162 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()	asm volatile ( "DINT" ); asm volatile ( "NOP" )

+#define portENABLE_INTERRUPTS()		asm volatile ( "EINT" )

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled ulCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+extern void vPortYield( void ) __attribute__ ( ( naked ) );

+#define portYIELD()			vPortYield()

+#define portNOP()			asm volatile ( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Hardwware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlaze/port.c b/FreeRTOS/Source/portable/GCC/MicroBlaze/port.c
new file mode 100644
index 0000000..10e750c
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlaze/port.c
@@ -0,0 +1,371 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MicroBlaze port.

+ *----------------------------------------------------------*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Standard includes. */

+#include <string.h>

+

+/* Hardware includes. */

+#include <xintc.h>

+#include <xintc_i.h>

+#include <xtmrctr.h>

+

+/* Tasks are started with interrupts enabled. */

+#define portINITIAL_MSR_STATE		( ( portSTACK_TYPE ) 0x02 )

+

+/* Tasks are started with a critical section nesting of 0 - however prior

+to the scheduler being commenced we don't want the critical nesting level

+to reach zero, so it is initialised to a high value. */

+#define portINITIAL_NESTING_VALUE	( 0xff )

+

+/* Our hardware setup only uses one counter. */

+#define portCOUNTER_0 				0

+

+/* The stack used by the ISR is filled with a known value to assist in

+debugging. */

+#define portISR_STACK_FILL_VALUE	0x55555555

+

+/* Counts the nesting depth of calls to portENTER_CRITICAL().  Each task 

+maintains it's own count, so this variable is saved as part of the task

+context. */

+volatile unsigned portBASE_TYPE uxCriticalNesting = portINITIAL_NESTING_VALUE;

+

+/* To limit the amount of stack required by each task, this port uses a

+separate stack for interrupts. */

+unsigned long *pulISRStack;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been made.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+extern void *_SDA2_BASE_, *_SDA_BASE_;

+const unsigned long ulR2 = ( unsigned long ) &_SDA2_BASE_;

+const unsigned long ulR13 = ( unsigned long ) &_SDA_BASE_;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is essential for the Microblaze port and these lines must

+	not be omitted.  The parameter value will overwrite the 

+	0x22222222 value during the function prologue. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22222222;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x33333333;

+	pxTopOfStack--; 

+

+	/* First stack an initial value for the critical section nesting.  This

+	is initialised to zero as tasks are started with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;	/* R0. */

+

+	/* Place an initial value for all the general purpose registers. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulR2;	/* R2 - small data area. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03;	/* R3. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04;	/* R4. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;/* R5 contains the function call parameters. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06;	/* R6. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07;	/* R7. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08;	/* R8. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09;	/* R9. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0a;	/* R10. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0b;	/* R11. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0c;	/* R12. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulR13;	/* R13 - small data read write area. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* R14. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0f;	/* R15. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10;	/* R16. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11;	/* R17. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12;	/* R18. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x13;	/* R19. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x14;	/* R20. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x15;	/* R21. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x16;	/* R22. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x17;	/* R23. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x18;	/* R24. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x19;	/* R25. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1a;	/* R26. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1b;	/* R27. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1c;	/* R28. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1d;	/* R29. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1e;	/* R30. */

+	pxTopOfStack--;

+

+	/* The MSR is stacked between R30 and R31. */

+	*pxTopOfStack = portINITIAL_MSR_STATE;

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1f;	/* R31. */

+	pxTopOfStack--;

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void ( __FreeRTOS_interrupt_Handler )( void );

+extern void ( vStartFirstTask )( void );

+

+

+	/* Setup the FreeRTOS interrupt handler.  Code copied from crt0.s. */

+	asm volatile ( 	"la	r6, r0, __FreeRTOS_interrupt_handler		\n\t" \

+					"sw	r6, r1, r0									\n\t" \

+					"lhu r7, r1, r0									\n\t" \

+					"shi r7, r0, 0x12								\n\t" \

+					"shi r6, r0, 0x16 " );

+

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Allocate the stack to be used by the interrupt handler. */

+	pulISRStack = ( unsigned long * ) pvPortMalloc( configMINIMAL_STACK_SIZE * sizeof( portSTACK_TYPE ) );

+

+	/* Restore the context of the first task that is going to run. */

+	if( pulISRStack != NULL )

+	{

+		/* Fill the ISR stack with a known value to facilitate debugging. */

+		memset( pulISRStack, portISR_STACK_FILL_VALUE, configMINIMAL_STACK_SIZE * sizeof( portSTACK_TYPE ) );

+		pulISRStack += ( configMINIMAL_STACK_SIZE - 1 );

+

+		/* Kick off the first task. */

+		vStartFirstTask();

+	}

+

+	/* Should not get here as the tasks are now running! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.  

+ */

+void vPortYield( void )

+{

+extern void VPortYieldASM( void );

+

+	/* Perform the context switch in a critical section to assure it is

+	not interrupted by the tick ISR.  It is not a problem to do this as

+	each task maintains it's own interrupt status. */

+	portENTER_CRITICAL();

+		/* Jump directly to the yield function to ensure there is no

+		compiler generated prologue code. */

+		asm volatile (	"bralid r14, VPortYieldASM		\n\t" \

+						"or r0, r0, r0					\n\t" );

+	portEXIT_CRITICAL();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.   

+ */

+static void prvSetupTimerInterrupt( void )

+{

+XTmrCtr xTimer;

+const unsigned long ulCounterValue = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+unsigned portBASE_TYPE uxMask;

+

+	/* The OPB timer1 is used to generate the tick.  Use the provided library

+	functions to enable the timer and set the tick frequency. */

+	XTmrCtr_mDisable( XPAR_OPB_TIMER_1_BASEADDR, XPAR_OPB_TIMER_1_DEVICE_ID );

+	XTmrCtr_Initialize( &xTimer, XPAR_OPB_TIMER_1_DEVICE_ID );

+   	XTmrCtr_mSetLoadReg( XPAR_OPB_TIMER_1_BASEADDR, portCOUNTER_0, ulCounterValue );

+	XTmrCtr_mSetControlStatusReg( XPAR_OPB_TIMER_1_BASEADDR, portCOUNTER_0, XTC_CSR_LOAD_MASK | XTC_CSR_INT_OCCURED_MASK );

+

+	/* Set the timer interrupt enable bit while maintaining the other bit 

+	states. */

+	uxMask = XIntc_In32( ( XPAR_OPB_INTC_0_BASEADDR + XIN_IER_OFFSET ) );

+	uxMask |= XPAR_OPB_TIMER_1_INTERRUPT_MASK;

+	XIntc_Out32( ( XPAR_OPB_INTC_0_BASEADDR + XIN_IER_OFFSET ), ( uxMask ) );	

+	

+	XTmrCtr_Start( &xTimer, XPAR_OPB_TIMER_1_DEVICE_ID );

+	XTmrCtr_mSetControlStatusReg(XPAR_OPB_TIMER_1_BASEADDR, portCOUNTER_0, XTC_CSR_ENABLE_TMR_MASK | XTC_CSR_ENABLE_INT_MASK | XTC_CSR_AUTO_RELOAD_MASK | XTC_CSR_DOWN_COUNT_MASK | XTC_CSR_INT_OCCURED_MASK );

+	XIntc_mAckIntr( XPAR_INTC_SINGLE_BASEADDR, 1 );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt handler placed in the interrupt vector when the scheduler is

+ * started.  The task context has already been saved when this is called.

+ * This handler determines the interrupt source and calls the relevant 

+ * peripheral handler.

+ */

+void vTaskISRHandler( void )

+{

+static unsigned long ulPending;    

+

+	/* Which interrupts are pending? */

+	ulPending = XIntc_In32( ( XPAR_INTC_SINGLE_BASEADDR + XIN_IVR_OFFSET ) );

+

+	if( ulPending < XPAR_INTC_MAX_NUM_INTR_INPUTS )

+	{

+		static XIntc_VectorTableEntry *pxTablePtr;

+		static XIntc_Config *pxConfig;

+		static unsigned long ulInterruptMask;

+

+		ulInterruptMask = ( unsigned long ) 1 << ulPending;

+

+		/* Get the configuration data using the device ID */

+		pxConfig = &XIntc_ConfigTable[ ( unsigned long ) XPAR_INTC_SINGLE_DEVICE_ID ];

+

+		pxTablePtr = &( pxConfig->HandlerTable[ ulPending ] );

+		if( pxConfig->AckBeforeService & ( ulInterruptMask  ) )

+		{

+			XIntc_mAckIntr( pxConfig->BaseAddress, ulInterruptMask );

+			pxTablePtr->Handler( pxTablePtr->CallBackRef );

+		}

+		else

+		{

+			pxTablePtr->Handler( pxTablePtr->CallBackRef );

+			XIntc_mAckIntr( pxConfig->BaseAddress, ulInterruptMask );

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * Handler for the timer interrupt.

+ */

+void vTickISR( void *pvBaseAddress )

+{

+unsigned long ulCSR;

+

+	/* Increment the RTOS tick - this might cause a task to unblock. */

+	vTaskIncrementTick();

+

+	/* Clear the timer interrupt */

+	ulCSR = XTmrCtr_mGetControlStatusReg(XPAR_OPB_TIMER_1_BASEADDR, 0);	

+	XTmrCtr_mSetControlStatusReg( XPAR_OPB_TIMER_1_BASEADDR, portCOUNTER_0, ulCSR );

+

+	/* If we are using the preemptive scheduler then we also need to determine

+	if this tick should cause a context switch. */

+	#if configUSE_PREEMPTION == 1

+		vTaskSwitchContext();

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlaze/portasm.s b/FreeRTOS/Source/portable/GCC/MicroBlaze/portasm.s
new file mode 100644
index 0000000..c62bab7
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlaze/portasm.s
@@ -0,0 +1,236 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+	.extern pxCurrentTCB

+	.extern vTaskISRHandler

+	.extern vTaskSwitchContext

+	.extern uxCriticalNesting

+	.extern pulISRStack

+

+	.global __FreeRTOS_interrupt_handler

+	.global VPortYieldASM

+	.global vStartFirstTask

+

+

+.macro portSAVE_CONTEXT

+	/* Make room for the context on the stack. */

+	addik r1, r1, -132

+	/* Save r31 so it can then be used. */

+	swi r31, r1, 4

+	/* Copy the msr into r31 - this is stacked later. */

+	mfs r31, rmsr

+	/* Stack general registers. */

+	swi r30, r1, 12

+	swi r29, r1, 16

+	swi r28, r1, 20

+	swi r27, r1, 24

+	swi r26, r1, 28

+	swi r25, r1, 32

+	swi r24, r1, 36

+	swi r23, r1, 40

+	swi r22, r1, 44

+	swi r21, r1, 48

+	swi r20, r1, 52

+	swi r19, r1, 56

+	swi r18, r1, 60

+	swi r17, r1, 64

+	swi r16, r1, 68

+	swi r15, r1, 72

+	swi r13, r1, 80

+	swi r12, r1, 84

+	swi r11, r1, 88

+	swi r10, r1, 92

+	swi r9, r1, 96

+	swi r8, r1, 100

+	swi r7, r1, 104

+	swi r6, r1, 108

+	swi r5, r1, 112

+	swi r4, r1, 116

+	swi r3, r1, 120

+	swi r2, r1, 124

+	/* Stack the critical section nesting value. */

+	lwi r3, r0, uxCriticalNesting

+	swi r3, r1, 128

+	/* Save the top of stack value to the TCB. */

+	lwi r3, r0, pxCurrentTCB

+	sw	r1, r0, r3

+	

+	.endm

+

+.macro portRESTORE_CONTEXT

+	/* Load the top of stack value from the TCB. */

+	lwi r3, r0, pxCurrentTCB

+	lw	r1, r0, r3	

+	/* Restore the general registers. */

+	lwi r31, r1, 4		

+	lwi r30, r1, 12		

+	lwi r29, r1, 16	

+	lwi r28, r1, 20	

+	lwi r27, r1, 24	

+	lwi r26, r1, 28	

+	lwi r25, r1, 32	

+	lwi r24, r1, 36	

+	lwi r23, r1, 40	

+	lwi r22, r1, 44	

+	lwi r21, r1, 48	

+	lwi r20, r1, 52	

+	lwi r19, r1, 56	

+	lwi r18, r1, 60	

+	lwi r17, r1, 64	

+	lwi r16, r1, 68	

+	lwi r15, r1, 72	

+	lwi r14, r1, 76	

+	lwi r13, r1, 80	

+	lwi r12, r1, 84	

+	lwi r11, r1, 88	

+	lwi r10, r1, 92	

+	lwi r9, r1, 96	

+	lwi r8, r1, 100	

+	lwi r7, r1, 104

+	lwi r6, r1, 108

+	lwi r5, r1, 112

+	lwi r4, r1, 116

+	lwi r2, r1, 124

+

+	/* Load the critical nesting value. */

+	lwi r3, r1, 128

+	swi r3, r0, uxCriticalNesting

+

+	/* Obtain the MSR value from the stack. */

+	lwi r3, r1, 8

+

+	/* Are interrupts enabled in the MSR?  If so return using an return from 

+	interrupt instruction to ensure interrupts are enabled only once the task

+	is running again. */

+	andi r3, r3, 2

+	beqid r3, 36

+	or r0, r0, r0

+

+	/* Reload the rmsr from the stack, clear the enable interrupt bit in the

+	value before saving back to rmsr register, then return enabling interrupts

+	as we return. */

+	lwi r3, r1, 8

+	andi r3, r3, ~2

+	mts rmsr, r3

+	lwi r3, r1, 120

+	addik r1, r1, 132

+	rtid r14, 0

+	or r0, r0, r0

+

+	/* Reload the rmsr from the stack, place it in the rmsr register, and

+	return without enabling interrupts. */

+	lwi r3, r1, 8

+	mts rmsr, r3

+	lwi r3, r1, 120

+	addik r1, r1, 132

+	rtsd r14, 0

+	or r0, r0, r0

+

+	.endm

+

+	.text

+	.align  2

+

+

+__FreeRTOS_interrupt_handler:

+	portSAVE_CONTEXT

+	/* Entered via an interrupt so interrupts must be enabled in msr. */

+	ori r31, r31, 2

+	/* Stack msr. */

+	swi r31, r1, 8

+	/* Stack the return address.  As we entered via an interrupt we do

+	not need to modify the return address prior to stacking. */

+	swi r14, r1, 76

+	/* Now switch to use the ISR stack. */

+	lwi r3, r0, pulISRStack

+	add r1, r3, r0

+	bralid r15, vTaskISRHandler

+	or r0, r0, r0

+	portRESTORE_CONTEXT

+

+

+VPortYieldASM:

+	portSAVE_CONTEXT

+	/* Stack msr. */

+	swi r31, r1, 8

+	/* Modify the return address so we return to the instruction after the

+	exception. */

+	addi r14, r14, 8

+	swi r14, r1, 76

+	/* Now switch to use the ISR stack. */

+	lwi r3, r0, pulISRStack

+	add r1, r3, r0

+	bralid r15, vTaskSwitchContext

+	or r0, r0, r0

+	portRESTORE_CONTEXT

+

+vStartFirstTask:

+	portRESTORE_CONTEXT

+	

+	

+

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlaze/portmacro.h b/FreeRTOS/Source/portable/GCC/MicroBlaze/portmacro.h
new file mode 100644
index 0000000..8d359fb
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlaze/portmacro.h
@@ -0,0 +1,157 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+void microblaze_disable_interrupts( void );

+void microblaze_enable_interrupts( void );

+#define portDISABLE_INTERRUPTS()	microblaze_disable_interrupts()

+#define portENABLE_INTERRUPTS()		microblaze_enable_interrupts()

+/*-----------------------------------------------------------*/

+

+/* Critical section macros. */

+void vPortEnterCritical( void );

+void vPortExitCritical( void );

+#define portENTER_CRITICAL()		{														\

+										extern unsigned portBASE_TYPE uxCriticalNesting;	\

+										microblaze_disable_interrupts();					\

+										uxCriticalNesting++;								\

+									}

+									

+#define portEXIT_CRITICAL()			{														\

+										extern unsigned portBASE_TYPE uxCriticalNesting;	\

+										/* Interrupts are disabled, so we can */			\

+										/* access the variable directly. */					\

+										uxCriticalNesting--;								\

+										if( uxCriticalNesting == 0 )			\

+										{													\

+											/* The nesting has unwound and we 				\

+											can enable interrupts again. */					\

+											portENABLE_INTERRUPTS();						\

+										}													\

+									}

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+void vPortYield( void );

+#define portYIELD() vPortYield()

+

+void vTaskSwitchContext();

+#define portYIELD_FROM_ISR() vTaskSwitchContext()

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			4

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()					asm volatile ( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port.c b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port.c
new file mode 100644
index 0000000..99fad3a
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port.c
@@ -0,0 +1,483 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MicroBlaze port.

+ *----------------------------------------------------------*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Standard includes. */

+#include <string.h>

+

+/* Hardware includes. */

+#include <xintc_i.h>

+#include <xil_exception.h>

+#include <microblaze_exceptions_g.h>

+

+/* Tasks are started with a critical section nesting of 0 - however, prior to 

+the scheduler being commenced interrupts should not be enabled, so the critical 

+nesting variable is initialised to a non-zero value. */

+#define portINITIAL_NESTING_VALUE	( 0xff )

+

+/* The bit within the MSR register that enabled/disables interrupts. */

+#define portMSR_IE					( 0x02U )

+

+/* If the floating point unit is included in the MicroBlaze build, then the

+FSR register is saved as part of the task context.  portINITIAL_FSR is the value

+given to the FSR register when the initial context is set up for a task being

+created. */

+#define portINITIAL_FSR				( 0U )

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the interrupt controller instance.

+ */

+static long prvInitialiseInterruptController( void );

+

+/* Ensure the interrupt controller instance variable is initialised before it is 

+ * used, and that the initialisation only happens once. 

+ */

+static long prvEnsureInterruptControllerIsInitialised( void );

+

+/*-----------------------------------------------------------*/

+

+/* Counts the nesting depth of calls to portENTER_CRITICAL().  Each task 

+maintains its own count, so this variable is saved as part of the task

+context. */

+volatile unsigned portBASE_TYPE uxCriticalNesting = portINITIAL_NESTING_VALUE;

+

+/* This port uses a separate stack for interrupts.  This prevents the stack of

+every task needing to be large enough to hold an entire interrupt stack on top

+of the task stack. */

+unsigned long *pulISRStack;

+

+/* If an interrupt requests a context switch, then ulTaskSwitchRequested will

+get set to 1.  ulTaskSwitchRequested is inspected just before the main interrupt

+handler exits.  If, at that time, ulTaskSwitchRequested is set to 1, the kernel

+will call vTaskSwitchContext() to ensure the task that runs immediately after

+the interrupt exists is the highest priority task that is able to run.  This is 

+an unusual mechanism, but is used for this port because a single interrupt can 

+cause the servicing of multiple peripherals - and it is inefficient to call

+vTaskSwitchContext() multiple times as each peripheral is serviced. */

+volatile unsigned long ulTaskSwitchRequested = 0UL;

+

+/* The instance of the interrupt controller used by this port.  This is required

+by the Xilinx library API functions. */

+static XIntc xInterruptControllerInstance;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been made.

+ * 

+ * See the portable.h header file.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+extern void *_SDA2_BASE_, *_SDA_BASE_;

+const unsigned long ulR2 = ( unsigned long ) &_SDA2_BASE_;

+const unsigned long ulR13 = ( unsigned long ) &_SDA_BASE_;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is essential for the Microblaze port and these lines must

+	not be omitted. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;

+	pxTopOfStack--;

+

+	#if XPAR_MICROBLAZE_0_USE_FPU == 1

+		/* The FSR value placed in the initial task context is just 0. */

+		*pxTopOfStack = portINITIAL_FSR;

+		pxTopOfStack--;

+	#endif

+

+	/* The MSR value placed in the initial task context should have interrupts

+	disabled.  Each task will enable interrupts automatically when it enters

+	the running state for the first time. */

+	*pxTopOfStack = mfmsr() & ~portMSR_IE;

+	pxTopOfStack--;

+

+	/* First stack an initial value for the critical section nesting.  This

+	is initialised to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;

+	

+	/* R0 is always zero. */

+	/* R1 is the SP. */

+

+	/* Place an initial value for all the general purpose registers. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulR2;	/* R2 - read only small data area. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03;	/* R3 - return values and temporaries. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04;	/* R4 - return values and temporaries. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;/* R5 contains the function call parameters. */

+

+	#ifdef portPRE_LOAD_STACK_FOR_DEBUGGING

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x06;	/* R6 - other parameters and temporaries.  Used as the return address from vPortTaskEntryPoint. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x07;	/* R7 - other parameters and temporaries. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x08;	/* R8 - other parameters and temporaries. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x09;	/* R9 - other parameters and temporaries. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x0a;	/* R10 - other parameters and temporaries. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x0b;	/* R11 - temporaries. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x0c;	/* R12 - temporaries. */

+		pxTopOfStack--;

+	#else

+		pxTopOfStack-= 8;

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) ulR13;	/* R13 - read/write small data area. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* R14 - return address for interrupt. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) NULL;	/* R15 - return address for subroutine. */

+	

+	#ifdef portPRE_LOAD_STACK_FOR_DEBUGGING

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x10;	/* R16 - return address for trap (debugger). */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x11;	/* R17 - return address for exceptions, if configured. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x12;	/* R18 - reserved for assembler and compiler temporaries. */

+		pxTopOfStack--;

+	#else

+		pxTopOfStack -= 4;

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;	/* R19 - must be saved across function calls. Callee-save.  Seems to be interpreted as the frame pointer. */

+	

+	#ifdef portPRE_LOAD_STACK_FOR_DEBUGGING	

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x14;	/* R20 - reserved for storing a pointer to the Global Offset Table (GOT) in Position Independent Code (PIC). Non-volatile in non-PIC code. Must be saved across function calls. Callee-save.  Not used by FreeRTOS. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x15;	/* R21 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x16;	/* R22 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x17;	/* R23 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x18;	/* R24 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x19;	/* R25 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1a;	/* R26 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1b;	/* R27 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1c;	/* R28 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1d;	/* R29 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1e;	/* R30 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1f;	/* R31 - must be saved across function calls. Callee-save. */

+		pxTopOfStack--;

+	#else

+		pxTopOfStack -= 13;

+	#endif

+

+	/* Return a pointer to the top of the stack that has been generated so this 

+	can	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void ( vPortStartFirstTask )( void );

+extern unsigned long _stack[];

+

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called.  

+	

+	This port uses an application defined callback function to install the tick

+	interrupt handler because the kernel will run on lots of different 

+	MicroBlaze and FPGA configurations - not all of	which will have the same 

+	timer peripherals defined or available.  An example definition of

+	vApplicationSetupTimerInterrupt() is provided in the official demo

+	application that accompanies this port. */

+	vApplicationSetupTimerInterrupt();

+

+	/* Reuse the stack from main() as the stack for the interrupts/exceptions. */

+	pulISRStack = ( unsigned long * ) _stack;

+

+	/* Ensure there is enough space for the functions called from the interrupt

+	service routines to write back into the stack frame of the caller. */

+	pulISRStack -= 2;

+

+	/* Restore the context of the first task that is going to run.  From here

+	on, the created tasks will be executing. */

+	vPortStartFirstTask();

+

+	/* Should not get here as the tasks are now running! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.  

+ */

+void vPortYield( void )

+{

+extern void VPortYieldASM( void );

+

+	/* Perform the context switch in a critical section to assure it is

+	not interrupted by the tick ISR.  It is not a problem to do this as

+	each task maintains its own interrupt status. */

+	portENTER_CRITICAL();

+	{

+		/* Jump directly to the yield function to ensure there is no

+		compiler generated prologue code. */

+		asm volatile (	"bralid r14, VPortYieldASM		\n\t" \

+						"or r0, r0, r0					\n\t" );

+	}

+	portEXIT_CRITICAL();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnableInterrupt( unsigned char ucInterruptID )

+{

+long lReturn;

+

+	/* An API function is provided to enable an interrupt in the interrupt

+	controller because the interrupt controller instance variable is private

+	to this file. */

+	lReturn = prvEnsureInterruptControllerIsInitialised();

+	if( lReturn == pdPASS )

+	{

+		XIntc_Enable( &xInterruptControllerInstance, ucInterruptID );

+	}

+	

+	configASSERT( lReturn );

+}

+/*-----------------------------------------------------------*/

+

+void vPortDisableInterrupt( unsigned char ucInterruptID )

+{

+long lReturn;

+

+	/* An API function is provided to disable an interrupt in the interrupt

+	controller because the interrupt controller instance variable is private

+	to this file. */

+	lReturn = prvEnsureInterruptControllerIsInitialised();

+	

+	if( lReturn == pdPASS )

+	{

+		XIntc_Disable( &xInterruptControllerInstance, ucInterruptID );

+	}

+	

+	configASSERT( lReturn );

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortInstallInterruptHandler( unsigned char ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef )

+{

+long lReturn;

+

+	/* An API function is provided to install an interrupt handler because the 

+	interrupt controller instance variable is private to this file. */

+

+	lReturn = prvEnsureInterruptControllerIsInitialised();

+	

+	if( lReturn == pdPASS )

+	{

+		lReturn = XIntc_Connect( &xInterruptControllerInstance, ucInterruptID, pxHandler, pvCallBackRef );

+	}

+

+	if( lReturn == XST_SUCCESS )

+	{

+		lReturn = pdPASS;

+	}

+	

+	configASSERT( lReturn == pdPASS );

+

+	return lReturn;

+}

+/*-----------------------------------------------------------*/

+

+static long prvEnsureInterruptControllerIsInitialised( void )

+{

+static long lInterruptControllerInitialised = pdFALSE;

+long lReturn;

+

+	/* Ensure the interrupt controller instance variable is initialised before

+	it is used, and that the initialisation only happens once. */

+	if( lInterruptControllerInitialised != pdTRUE )

+	{

+		lReturn = prvInitialiseInterruptController();

+		

+		if( lReturn == pdPASS )

+		{

+			lInterruptControllerInitialised = pdTRUE;

+		}

+	}

+	else

+	{

+		lReturn = pdPASS;

+	}

+

+	return lReturn;

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * Handler for the timer interrupt.  This is the handler that the application

+ * defined callback function vApplicationSetupTimerInterrupt() should install.

+ */

+void vPortTickISR( void *pvUnused )

+{

+extern void vApplicationClearTimerInterrupt( void );

+

+	/* Ensure the unused parameter does not generate a compiler warning. */

+	( void ) pvUnused;

+

+	/* This port uses an application defined callback function to clear the tick

+	interrupt because the kernel will run on lots of different MicroBlaze and 

+	FPGA configurations - not all of which will have the same timer peripherals 

+	defined or available.  An example definition of

+	vApplicationClearTimerInterrupt() is provided in the official demo

+	application that accompanies this port. */	

+	vApplicationClearTimerInterrupt();

+

+	/* Increment the RTOS tick - this might cause a task to unblock. */

+	vTaskIncrementTick();

+

+	/* If the preemptive scheduler is being used then a context switch should be

+	requested in case incrementing the tick unblocked a task, or a time slice

+	should cause another task to enter the Running state. */

+	#if configUSE_PREEMPTION == 1

+		/* Force vTaskSwitchContext() to be called as the interrupt exits. */

+		ulTaskSwitchRequested = 1;

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+static long prvInitialiseInterruptController( void )

+{

+long lStatus;

+

+	lStatus = XIntc_Initialize( &xInterruptControllerInstance, configINTERRUPT_CONTROLLER_TO_USE );

+

+	if( lStatus == XST_SUCCESS )

+	{

+		/* Initialise the exception table. */

+		Xil_ExceptionInit();

+

+	    /* Service all pending interrupts each time the handler is entered. */

+	    XIntc_SetIntrSvcOption( xInterruptControllerInstance.BaseAddress, XIN_SVC_ALL_ISRS_OPTION );

+

+	    /* Install exception handlers if the MicroBlaze is configured to handle

+	    exceptions, and the application defined constant

+	    configINSTALL_EXCEPTION_HANDLERS is set to 1. */

+		#if ( MICROBLAZE_EXCEPTIONS_ENABLED == 1 ) && ( configINSTALL_EXCEPTION_HANDLERS == 1 )

+	    {

+	    	vPortExceptionsInstallHandlers();

+	    }

+		#endif /* MICROBLAZE_EXCEPTIONS_ENABLED */

+

+		/* Start the interrupt controller.  Interrupts are enabled when the

+		scheduler starts. */

+		lStatus = XIntc_Start( &xInterruptControllerInstance, XIN_REAL_MODE );

+

+		if( lStatus == XST_SUCCESS )

+		{

+			lStatus = pdPASS;

+		}

+		else

+		{

+			lStatus = pdFAIL;

+		}

+	}

+

+	configASSERT( lStatus == pdPASS );

+

+	return lStatus;

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port_exceptions.c b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port_exceptions.c
new file mode 100644
index 0000000..65ca5aa
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/port_exceptions.c
@@ -0,0 +1,319 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Hardware includes. */

+#include <microblaze_exceptions_i.h>

+#include <microblaze_exceptions_g.h>

+

+/* The Xilinx library defined exception entry point stacks a number of

+registers.  These definitions are offsets from the stack pointer to the various

+stacked register values. */

+#define portexR3_STACK_OFFSET	4

+#define portexR4_STACK_OFFSET	5

+#define portexR5_STACK_OFFSET	6

+#define portexR6_STACK_OFFSET	7

+#define portexR7_STACK_OFFSET	8

+#define portexR8_STACK_OFFSET	9

+#define portexR9_STACK_OFFSET	10

+#define portexR10_STACK_OFFSET	11

+#define portexR11_STACK_OFFSET	12

+#define portexR12_STACK_OFFSET	13

+#define portexR15_STACK_OFFSET	16

+#define portexR18_STACK_OFFSET  19

+#define portexMSR_STACK_OFFSET	20

+#define portexR19_STACK_OFFSET  -1

+

+/* This is defined to equal the size, in bytes, of the stack frame generated by

+the Xilinx standard library exception entry point.  It is required to determine

+the stack pointer value prior to the exception being entered. */

+#define portexASM_HANDLER_STACK_FRAME_SIZE 84UL

+

+/* The number of bytes a MicroBlaze instruction consumes. */

+#define portexINSTRUCTION_SIZE	4

+

+/* Exclude this entire file if the MicroBlaze is not configured to handle

+exceptions, or the application defined configuration constant

+configINSTALL_EXCEPTION_HANDLERS is not set to 1. */

+#if ( MICROBLAZE_EXCEPTIONS_ENABLED == 1 ) && ( configINSTALL_EXCEPTION_HANDLERS == 1 )

+

+/* This variable is set in the exception entry code, before

+vPortExceptionHandler is called. */

+unsigned long *pulStackPointerOnFunctionEntry = NULL;

+

+/* This is the structure that is filled with the MicroBlaze context as it

+existed immediately prior to the exception occurrence.  A pointer to this

+structure is passed into the vApplicationExceptionRegisterDump() callback

+function, if one is defined. */

+static xPortRegisterDump xRegisterDump;

+

+/* This is the FreeRTOS exception handler that is installed for all exception

+types.  It is called from vPortExceptionHanlderEntry() - which is itself defined

+in portasm.S. */

+void vPortExceptionHandler( void *pvExceptionID );

+extern void vPortExceptionHandlerEntry( void *pvExceptionID );

+

+/*-----------------------------------------------------------*/

+

+/* vApplicationExceptionRegisterDump() is a callback function that the 

+application can optionally define to receive a populated xPortRegisterDump

+structure.  If the application chooses not to define a version of 

+vApplicationExceptionRegisterDump() then this weekly defined default 

+implementation will be called instead. */

+extern void vApplicationExceptionRegisterDump( xPortRegisterDump *xRegisterDump ) __attribute__((weak));

+void vApplicationExceptionRegisterDump( xPortRegisterDump *xRegisterDump )

+{

+	( void ) xRegisterDump;

+

+	for( ;; )

+	{

+		portNOP();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortExceptionHandler( void *pvExceptionID )

+{

+extern void *pxCurrentTCB;

+

+	/* Fill an xPortRegisterDump structure with the MicroBlaze context as it

+	was immediately before the exception occurrence. */

+	

+	/* First fill in the name and handle of the task that was in the Running 

+	state when the exception occurred. */

+	xRegisterDump.xCurrentTaskHandle = pxCurrentTCB;

+	xRegisterDump.pcCurrentTaskName = pcTaskGetTaskName( NULL );

+

+	configASSERT( pulStackPointerOnFunctionEntry );

+

+	/* Obtain the values of registers that were stacked prior to this function

+	being called, and may have changed since they were stacked. */

+	xRegisterDump.ulR3 = pulStackPointerOnFunctionEntry[ portexR3_STACK_OFFSET ];

+	xRegisterDump.ulR4 = pulStackPointerOnFunctionEntry[ portexR4_STACK_OFFSET ];

+	xRegisterDump.ulR5 = pulStackPointerOnFunctionEntry[ portexR5_STACK_OFFSET ];

+	xRegisterDump.ulR6 = pulStackPointerOnFunctionEntry[ portexR6_STACK_OFFSET ];

+	xRegisterDump.ulR7 = pulStackPointerOnFunctionEntry[ portexR7_STACK_OFFSET ];

+	xRegisterDump.ulR8 = pulStackPointerOnFunctionEntry[ portexR8_STACK_OFFSET ];

+	xRegisterDump.ulR9 = pulStackPointerOnFunctionEntry[ portexR9_STACK_OFFSET ];

+	xRegisterDump.ulR10 = pulStackPointerOnFunctionEntry[ portexR10_STACK_OFFSET ];

+	xRegisterDump.ulR11 = pulStackPointerOnFunctionEntry[ portexR11_STACK_OFFSET ];

+	xRegisterDump.ulR12 = pulStackPointerOnFunctionEntry[ portexR12_STACK_OFFSET ];

+	xRegisterDump.ulR15_return_address_from_subroutine = pulStackPointerOnFunctionEntry[ portexR15_STACK_OFFSET ];

+	xRegisterDump.ulR18 = pulStackPointerOnFunctionEntry[ portexR18_STACK_OFFSET ];

+	xRegisterDump.ulR19 = pulStackPointerOnFunctionEntry[ portexR19_STACK_OFFSET ];

+	xRegisterDump.ulMSR = pulStackPointerOnFunctionEntry[ portexMSR_STACK_OFFSET ];

+	

+	/* Obtain the value of all other registers. */

+	xRegisterDump.ulR2_small_data_area = mfgpr( R2 );

+	xRegisterDump.ulR13_read_write_small_data_area = mfgpr( R13 );

+	xRegisterDump.ulR14_return_address_from_interrupt = mfgpr( R14 );

+	xRegisterDump.ulR16_return_address_from_trap = mfgpr( R16 );

+	xRegisterDump.ulR17_return_address_from_exceptions = mfgpr( R17 );

+	xRegisterDump.ulR20 = mfgpr( R20 );

+	xRegisterDump.ulR21 = mfgpr( R21 );

+	xRegisterDump.ulR22 = mfgpr( R22 );

+	xRegisterDump.ulR23 = mfgpr( R23 );

+	xRegisterDump.ulR24 = mfgpr( R24 );

+	xRegisterDump.ulR25 = mfgpr( R25 );

+	xRegisterDump.ulR26 = mfgpr( R26 );

+	xRegisterDump.ulR27 = mfgpr( R27 );

+	xRegisterDump.ulR28 = mfgpr( R28 );

+	xRegisterDump.ulR29 = mfgpr( R29 );

+	xRegisterDump.ulR30 = mfgpr( R30 );

+	xRegisterDump.ulR31 = mfgpr( R31 );

+	xRegisterDump.ulR1_SP = ( ( unsigned long ) pulStackPointerOnFunctionEntry ) + portexASM_HANDLER_STACK_FRAME_SIZE;

+	xRegisterDump.ulEAR = mfear();

+	xRegisterDump.ulESR = mfesr();

+	xRegisterDump.ulEDR = mfedr();

+	

+	/* Move the saved program counter back to the instruction that was executed

+	when the exception occurred.  This is only valid for certain types of

+	exception. */

+	xRegisterDump.ulPC = xRegisterDump.ulR17_return_address_from_exceptions - portexINSTRUCTION_SIZE;

+

+	#if XPAR_MICROBLAZE_0_USE_FPU == 1

+	{

+		xRegisterDump.ulFSR = mffsr();

+	}

+	#else

+	{

+		xRegisterDump.ulFSR = 0UL;

+	}

+	#endif

+

+	/* Also fill in a string that describes what type of exception this is.

+	The string uses the same ID names as defined in the MicroBlaze standard

+	library exception header files. */

+	switch( ( unsigned long ) pvExceptionID )

+	{

+		case XEXC_ID_FSL :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_FSL";

+				break;

+

+		case XEXC_ID_UNALIGNED_ACCESS :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_UNALIGNED_ACCESS";

+				break;

+

+		case XEXC_ID_ILLEGAL_OPCODE :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_ILLEGAL_OPCODE";

+				break;

+

+		case XEXC_ID_M_AXI_I_EXCEPTION :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_M_AXI_I_EXCEPTION or XEXC_ID_IPLB_EXCEPTION";

+				break;

+

+		case XEXC_ID_M_AXI_D_EXCEPTION :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_M_AXI_D_EXCEPTION or XEXC_ID_DPLB_EXCEPTION";

+				break;

+

+		case XEXC_ID_DIV_BY_ZERO :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_DIV_BY_ZERO";

+				break;

+

+		case XEXC_ID_STACK_VIOLATION :

+				xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_STACK_VIOLATION or XEXC_ID_MMU";

+				break;

+

+		#if XPAR_MICROBLAZE_0_USE_FPU == 1

+

+			case XEXC_ID_FPU :

+						xRegisterDump.pcExceptionCause = ( signed char * const ) "XEXC_ID_FPU see ulFSR value";

+						break;

+

+		#endif /* XPAR_MICROBLAZE_0_USE_FPU */

+	}

+

+	/* vApplicationExceptionRegisterDump() is a callback function that the 

+	application can optionally define to receive the populated xPortRegisterDump

+	structure.  If the application chooses not to define a version of 

+	vApplicationExceptionRegisterDump() then the weekly defined default 

+	implementation within this file will be called instead. */

+	vApplicationExceptionRegisterDump( &xRegisterDump );

+

+	/* Must not attempt to leave this function! */

+	for( ;; )

+	{

+		portNOP();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortExceptionsInstallHandlers( void )

+{

+static unsigned long ulHandlersAlreadyInstalled = pdFALSE;

+

+	if( ulHandlersAlreadyInstalled == pdFALSE )

+	{

+		ulHandlersAlreadyInstalled = pdTRUE;

+

+		#if XPAR_MICROBLAZE_0_UNALIGNED_EXCEPTIONS == 1

+			microblaze_register_exception_handler( XEXC_ID_UNALIGNED_ACCESS, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_UNALIGNED_ACCESS );

+		#endif /* XPAR_MICROBLAZE_0_UNALIGNED_EXCEPTIONS*/

+

+		#if XPAR_MICROBLAZE_0_ILL_OPCODE_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_ILLEGAL_OPCODE, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_ILLEGAL_OPCODE );

+		#endif /* XPAR_MICROBLAZE_0_ILL_OPCODE_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_M_AXI_I_BUS_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_M_AXI_I_EXCEPTION, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_M_AXI_I_EXCEPTION );

+		#endif /* XPAR_MICROBLAZE_0_M_AXI_I_BUS_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_M_AXI_D_BUS_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_M_AXI_D_EXCEPTION, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_M_AXI_D_EXCEPTION );

+		#endif /* XPAR_MICROBLAZE_0_M_AXI_D_BUS_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_IPLB_BUS_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_IPLB_EXCEPTION, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_IPLB_EXCEPTION );

+		#endif /* XPAR_MICROBLAZE_0_IPLB_BUS_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_DPLB_BUS_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_DPLB_EXCEPTION, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_DPLB_EXCEPTION );

+		#endif /* XPAR_MICROBLAZE_0_DPLB_BUS_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_DIV_ZERO_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_DIV_BY_ZERO, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_DIV_BY_ZERO );

+		#endif /* XPAR_MICROBLAZE_0_DIV_ZERO_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_FPU_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_FPU, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_FPU );

+		#endif /* XPAR_MICROBLAZE_0_FPU_EXCEPTION*/

+

+		#if XPAR_MICROBLAZE_0_FSL_EXCEPTION == 1

+			microblaze_register_exception_handler( XEXC_ID_FSL, vPortExceptionHandlerEntry, ( void * ) XEXC_ID_FSL );

+		#endif /* XPAR_MICROBLAZE_0_FSL_EXCEPTION*/

+	}

+}

+

+/* Exclude the entire file if the MicroBlaze is not configured to handle

+exceptions, or the application defined configuration item 

+configINSTALL_EXCEPTION_HANDLERS is not set to 1. */

+#endif /* ( MICROBLAZE_EXCEPTIONS_ENABLED == 1 ) && ( configINSTALL_EXCEPTION_HANDLERS == 1 ) */

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portasm.S b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portasm.S
new file mode 100644
index 0000000..f2886a7
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portasm.S
@@ -0,0 +1,367 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* FreeRTOS includes. */

+#include "FreeRTOSConfig.h"

+

+/* Xilinx library includes. */

+#include "microblaze_exceptions_g.h"

+#include "xparameters.h"

+

+/* The context is oversized to allow functions called from the ISR to write

+back into the caller stack. */

+#if XPAR_MICROBLAZE_0_USE_FPU == 1

+	#define portCONTEXT_SIZE 136

+	#define portMINUS_CONTEXT_SIZE -136

+#else

+	#define portCONTEXT_SIZE 132

+	#define portMINUS_CONTEXT_SIZE -132

+#endif

+

+/* Offsets from the stack pointer at which saved registers are placed. */

+#define portR31_OFFSET	4

+#define portR30_OFFSET	8

+#define portR29_OFFSET	12

+#define portR28_OFFSET	16

+#define portR27_OFFSET	20

+#define portR26_OFFSET	24

+#define portR25_OFFSET	28

+#define portR24_OFFSET	32

+#define portR23_OFFSET	36

+#define portR22_OFFSET	40

+#define portR21_OFFSET	44

+#define portR20_OFFSET	48

+#define portR19_OFFSET	52

+#define portR18_OFFSET	56

+#define portR17_OFFSET	60

+#define portR16_OFFSET	64

+#define portR15_OFFSET	68

+#define portR14_OFFSET	72

+#define portR13_OFFSET	76

+#define portR12_OFFSET	80

+#define portR11_OFFSET	84

+#define portR10_OFFSET	88

+#define portR9_OFFSET	92

+#define portR8_OFFSET	96

+#define portR7_OFFSET	100

+#define portR6_OFFSET	104

+#define portR5_OFFSET	108

+#define portR4_OFFSET	112

+#define portR3_OFFSET	116

+#define portR2_OFFSET	120

+#define portCRITICAL_NESTING_OFFSET 124

+#define portMSR_OFFSET 128

+#define portFSR_OFFSET 132

+

+	.extern pxCurrentTCB

+	.extern XIntc_DeviceInterruptHandler

+	.extern vTaskSwitchContext

+	.extern uxCriticalNesting

+	.extern pulISRStack

+	.extern ulTaskSwitchRequested

+	.extern vPortExceptionHandler

+	.extern pulStackPointerOnFunctionEntry

+

+	.global _interrupt_handler

+	.global VPortYieldASM

+	.global vPortStartFirstTask

+	.global vPortExceptionHandlerEntry

+

+

+.macro portSAVE_CONTEXT

+

+	/* Make room for the context on the stack. */

+	addik r1, r1, portMINUS_CONTEXT_SIZE

+

+	/* Stack general registers. */

+	swi r31, r1, portR31_OFFSET

+	swi r30, r1, portR30_OFFSET

+	swi r29, r1, portR29_OFFSET

+	swi r28, r1, portR28_OFFSET

+	swi r27, r1, portR27_OFFSET

+	swi r26, r1, portR26_OFFSET

+	swi r25, r1, portR25_OFFSET

+	swi r24, r1, portR24_OFFSET

+	swi r23, r1, portR23_OFFSET

+	swi r22, r1, portR22_OFFSET

+	swi r21, r1, portR21_OFFSET

+	swi r20, r1, portR20_OFFSET

+	swi r19, r1, portR19_OFFSET

+	swi r18, r1, portR18_OFFSET

+	swi r17, r1, portR17_OFFSET

+	swi r16, r1, portR16_OFFSET

+	swi r15, r1, portR15_OFFSET

+	/* R14 is saved later as it needs adjustment if a yield is performed. */

+	swi r13, r1, portR13_OFFSET

+	swi r12, r1, portR12_OFFSET

+	swi r11, r1, portR11_OFFSET

+	swi r10, r1, portR10_OFFSET

+	swi r9, r1, portR9_OFFSET

+	swi r8, r1, portR8_OFFSET

+	swi r7, r1, portR7_OFFSET

+	swi r6, r1, portR6_OFFSET

+	swi r5, r1, portR5_OFFSET

+	swi r4, r1, portR4_OFFSET

+	swi r3, r1, portR3_OFFSET

+	swi r2, r1, portR2_OFFSET

+

+	/* Stack the critical section nesting value. */

+	lwi r18, r0, uxCriticalNesting

+	swi r18, r1, portCRITICAL_NESTING_OFFSET

+

+	/* Stack MSR. */

+	mfs r18, rmsr

+	swi r18, r1, portMSR_OFFSET

+

+	#if XPAR_MICROBLAZE_0_USE_FPU == 1

+		/* Stack FSR. */

+		mfs r18, rfsr

+		swi r18, r1, portFSR_OFFSET

+	#endif

+

+	/* Save the top of stack value to the TCB. */

+	lwi r3, r0, pxCurrentTCB

+	sw	r1, r0, r3

+	

+	.endm

+

+.macro portRESTORE_CONTEXT

+

+	/* Load the top of stack value from the TCB. */

+	lwi r18, r0, pxCurrentTCB

+	lw	r1, r0, r18

+

+	/* Restore the general registers. */

+	lwi r31, r1, portR31_OFFSET

+	lwi r30, r1, portR30_OFFSET

+	lwi r29, r1, portR29_OFFSET

+	lwi r28, r1, portR28_OFFSET

+	lwi r27, r1, portR27_OFFSET

+	lwi r26, r1, portR26_OFFSET

+	lwi r25, r1, portR25_OFFSET

+	lwi r24, r1, portR24_OFFSET

+	lwi r23, r1, portR23_OFFSET

+	lwi r22, r1, portR22_OFFSET

+	lwi r21, r1, portR21_OFFSET

+	lwi r20, r1, portR20_OFFSET

+	lwi r19, r1, portR19_OFFSET

+	lwi r17, r1, portR17_OFFSET

+	lwi r16, r1, portR16_OFFSET

+	lwi r15, r1, portR15_OFFSET

+	lwi r14, r1, portR14_OFFSET

+	lwi r13, r1, portR13_OFFSET

+	lwi r12, r1, portR12_OFFSET

+	lwi r11, r1, portR11_OFFSET

+	lwi r10, r1, portR10_OFFSET

+	lwi r9, r1, portR9_OFFSET

+	lwi r8, r1, portR8_OFFSET

+	lwi r7, r1, portR7_OFFSET

+	lwi r6, r1, portR6_OFFSET

+	lwi r5, r1, portR5_OFFSET

+	lwi r4, r1, portR4_OFFSET

+	lwi r3, r1, portR3_OFFSET

+	lwi r2, r1, portR2_OFFSET

+

+	/* Reload the rmsr from the stack. */

+	lwi r18, r1, portMSR_OFFSET

+	mts rmsr, r18

+

+	#if XPAR_MICROBLAZE_0_USE_FPU == 1

+		/* Reload the FSR from the stack. */

+		lwi r18, r1, portFSR_OFFSET

+		mts rfsr, r18

+	#endif

+

+	/* Load the critical nesting value. */

+	lwi r18, r1, portCRITICAL_NESTING_OFFSET

+	swi r18, r0, uxCriticalNesting

+

+	/* Test the critical nesting value.  If it is non zero then the task last

+	exited the running state using a yield.  If it is zero, then the task

+	last exited the running state through an interrupt. */

+	xori r18, r18, 0

+	bnei r18, exit_from_yield

+

+	/* r18 was being used as a temporary.  Now restore its true value from the

+	stack. */

+	lwi r18, r1, portR18_OFFSET

+

+	/* Remove the stack frame. */

+	addik r1, r1, portCONTEXT_SIZE

+

+	/* Return using rtid so interrupts are re-enabled as this function is

+	exited. */

+	rtid r14, 0

+	or r0, r0, r0

+

+	.endm

+

+/* This function is used to exit portRESTORE_CONTEXT() if the task being

+returned to last left the Running state by calling taskYIELD() (rather than

+being preempted by an interrupt). */

+	.text

+	.align  2

+exit_from_yield:

+

+	/* r18 was being used as a temporary.  Now restore its true value from the

+	stack. */

+	lwi r18, r1, portR18_OFFSET

+

+	/* Remove the stack frame. */

+	addik r1, r1, portCONTEXT_SIZE

+

+	/* Return to the task. */

+	rtsd r14, 0

+	or r0, r0, r0

+

+

+	.text

+	.align  2

+_interrupt_handler:

+

+	portSAVE_CONTEXT

+

+	/* Stack the return address. */

+	swi r14, r1, portR14_OFFSET

+

+	/* Switch to the ISR stack. */

+	lwi r1, r0, pulISRStack

+

+	/* The parameter to the interrupt handler. */

+	ori r5, r0, configINTERRUPT_CONTROLLER_TO_USE

+

+	/* Execute any pending interrupts. */

+	bralid r15, XIntc_DeviceInterruptHandler

+	or r0, r0, r0

+

+	/* See if a new task should be selected to execute. */

+	lwi r18, r0, ulTaskSwitchRequested

+	or r18, r18, r0

+

+	/* If ulTaskSwitchRequested is already zero, then jump straight to

+	restoring the task that is already in the Running state. */

+	beqi r18, task_switch_not_requested

+

+	/* Set ulTaskSwitchRequested back to zero as a task switch is about to be

+	performed. */

+	swi r0, r0, ulTaskSwitchRequested

+

+	/* ulTaskSwitchRequested was not 0 when tested.  Select the next task to

+	execute. */

+	bralid r15, vTaskSwitchContext

+	or r0, r0, r0

+

+task_switch_not_requested:

+

+	/* Restore the context of the next task scheduled to execute. */

+	portRESTORE_CONTEXT

+

+

+	.text

+	.align  2

+VPortYieldASM:

+

+	portSAVE_CONTEXT

+

+	/* Modify the return address so a return is done to the instruction after

+	the call to VPortYieldASM. */

+	addi r14, r14, 8

+	swi r14, r1, portR14_OFFSET

+

+	/* Switch to use the ISR stack. */

+	lwi r1, r0, pulISRStack

+

+	/* Select the next task to execute. */

+	bralid r15, vTaskSwitchContext

+	or r0, r0, r0

+

+	/* Restore the context of the next task scheduled to execute. */

+	portRESTORE_CONTEXT

+

+	.text

+	.align  2

+vPortStartFirstTask:

+

+	portRESTORE_CONTEXT

+	

+

+

+#if MICROBLAZE_EXCEPTIONS_ENABLED == 1

+	

+	.text

+	.align 2

+vPortExceptionHandlerEntry:

+

+	/* Take a copy of the stack pointer before vPortExecptionHandler is called,

+	storing its value prior to the function stack frame being created. */

+	swi r1, r0, pulStackPointerOnFunctionEntry

+	bralid r15, vPortExceptionHandler

+	or r0, r0, r0

+

+#endif /* MICROBLAZE_EXCEPTIONS_ENABLED */

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portmacro.h b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portmacro.h
new file mode 100644
index 0000000..f997f2e
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/MicroBlazeV8/portmacro.h
@@ -0,0 +1,374 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* BSP includes. */

+#include <mb_interface.h>

+#include <xparameters.h>

+

+/*-----------------------------------------------------------

+ * 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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros and functions. */

+void microblaze_disable_interrupts( void );

+void microblaze_enable_interrupts( void );

+#define portDISABLE_INTERRUPTS()	microblaze_disable_interrupts()

+#define portENABLE_INTERRUPTS()		microblaze_enable_interrupts()

+

+/*-----------------------------------------------------------*/

+

+/* Critical section macros. */

+void vPortEnterCritical( void );

+void vPortExitCritical( void );

+#define portENTER_CRITICAL()		{																\

+										extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+										microblaze_disable_interrupts();							\

+										uxCriticalNesting++;										\

+									}

+

+#define portEXIT_CRITICAL()			{																\

+										extern volatile unsigned portBASE_TYPE uxCriticalNesting;	\

+										/* Interrupts are disabled, so we can */					\

+										/* access the variable directly. */							\

+										uxCriticalNesting--;										\

+										if( uxCriticalNesting == 0 )								\

+										{															\

+											/* The nesting has unwound and we 						\

+											can enable interrupts again. */							\

+											portENABLE_INTERRUPTS();								\

+										}															\

+									}

+

+/*-----------------------------------------------------------*/

+

+/* The yield macro maps directly to the vPortYield() function. */

+void vPortYield( void );

+#define portYIELD() vPortYield()

+

+/* portYIELD_FROM_ISR() does not directly call vTaskSwitchContext(), but instead

+sets a flag to say that a yield has been requested.  The interrupt exit code

+then checks this flag, and calls vTaskSwitchContext() before restoring a task

+context, if the flag is not false.  This is done to prevent multiple calls to

+vTaskSwitchContext() being made from a single interrupt, as a single interrupt

+can result in multiple peripherals being serviced. */

+extern volatile unsigned long ulTaskSwitchRequested;

+#define portYIELD_FROM_ISR( x ) if( x != pdFALSE ) ulTaskSwitchRequested = 1

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			4

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portNOP()					asm volatile ( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+/* The following structure is used by the FreeRTOS exception handler.  It is

+filled with the MicroBlaze context as it was at the time the exception occurred.

+This is done as an aid to debugging exception occurrences. */

+typedef struct PORT_REGISTER_DUMP

+{

+	/* The following structure members hold the values of the MicroBlaze

+	registers at the time the exception was raised. */

+	unsigned long ulR1_SP;

+	unsigned long ulR2_small_data_area;

+	unsigned long ulR3;

+	unsigned long ulR4;

+	unsigned long ulR5;

+	unsigned long ulR6;

+	unsigned long ulR7;

+	unsigned long ulR8;

+	unsigned long ulR9;

+	unsigned long ulR10;

+	unsigned long ulR11;

+	unsigned long ulR12;

+	unsigned long ulR13_read_write_small_data_area;

+	unsigned long ulR14_return_address_from_interrupt;

+	unsigned long ulR15_return_address_from_subroutine;

+	unsigned long ulR16_return_address_from_trap;

+	unsigned long ulR17_return_address_from_exceptions; /* The exception entry code will copy the BTR into R17 if the exception occurred in the delay slot of a branch instruction. */

+	unsigned long ulR18;

+	unsigned long ulR19;

+	unsigned long ulR20;

+	unsigned long ulR21;

+	unsigned long ulR22;

+	unsigned long ulR23;

+	unsigned long ulR24;

+	unsigned long ulR25;

+	unsigned long ulR26;

+	unsigned long ulR27;

+	unsigned long ulR28;

+	unsigned long ulR29;

+	unsigned long ulR30;

+	unsigned long ulR31;

+	unsigned long ulPC;

+	unsigned long ulESR;

+	unsigned long ulMSR;

+	unsigned long ulEAR;

+	unsigned long ulFSR;

+	unsigned long ulEDR;

+

+	/* A human readable description of the exception cause.  The strings used

+	are the same as the #define constant names found in the

+	microblaze_exceptions_i.h header file */

+	signed char *pcExceptionCause;

+

+	/* The human readable name of the task that was running at the time the

+	exception occurred.  This is the name that was given to the task when the

+	task was created using the FreeRTOS xTaskCreate() API function. */

+	signed char *pcCurrentTaskName;

+

+	/* The handle of the task that was running a the time the exception

+	occurred. */

+	void * xCurrentTaskHandle;

+

+} xPortRegisterDump;

+

+

+/*

+ * Installs pxHandler as the interrupt handler for the peripheral specified by 

+ * the ucInterruptID parameter.

+ *

+ * ucInterruptID:

+ * 

+ * The ID of the peripheral that will have pxHandler assigned as its interrupt

+ * handler.  Peripheral IDs are defined in the xparameters.h header file, which 

+ * is itself part of the BSP project.  For example, in the official demo 

+ * application for this port, xparameters.h defines the following IDs for the 

+ * four possible interrupt sources:

+ *

+ * XPAR_INTC_0_UARTLITE_1_VEC_ID  -  for the UARTlite peripheral.

+ * XPAR_INTC_0_TMRCTR_0_VEC_ID    -  for the AXI Timer 0 peripheral.

+ * XPAR_INTC_0_EMACLITE_0_VEC_ID  -  for the Ethernet lite peripheral.

+ * XPAR_INTC_0_GPIO_1_VEC_ID      -  for the button inputs.

+ *

+ *

+ * pxHandler:

+ * 

+ * A pointer to the interrupt handler function itself.  This must be a void

+ * function that takes a (void *) parameter.

+ *

+ *

+ * pvCallBackRef:

+ *

+ * The parameter passed into the handler function.  In many cases this will not

+ * be used and can be NULL.  Some times it is used to pass in a reference to

+ * the peripheral instance variable, so it can be accessed from inside the

+ * handler function.

+ *

+ * 

+ * pdPASS is returned if the function executes successfully.  Any other value

+ * being returned indicates that the function did not execute correctly.

+ */

+portBASE_TYPE xPortInstallInterruptHandler( unsigned char ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef );

+

+

+/*

+ * Enables the interrupt, within the interrupt controller, for the peripheral 

+ * specified by the ucInterruptID parameter.

+ *

+ * ucInterruptID:

+ * 

+ * The ID of the peripheral that will have its interrupt enabled in the

+ * interrupt controller.  Peripheral IDs are defined in the xparameters.h header 

+ * file, which is itself part of the BSP project.  For example, in the official 

+ * demo application for this port, xparameters.h defines the following IDs for 

+ * the four possible interrupt sources:

+ *

+ * XPAR_INTC_0_UARTLITE_1_VEC_ID  -  for the UARTlite peripheral.

+ * XPAR_INTC_0_TMRCTR_0_VEC_ID    -  for the AXI Timer 0 peripheral.

+ * XPAR_INTC_0_EMACLITE_0_VEC_ID  -  for the Ethernet lite peripheral.

+ * XPAR_INTC_0_GPIO_1_VEC_ID      -  for the button inputs.

+ *

+ */

+void vPortEnableInterrupt( unsigned char ucInterruptID );

+

+/*

+ * Disables the interrupt, within the interrupt controller, for the peripheral 

+ * specified by the ucInterruptID parameter.

+ *

+ * ucInterruptID:

+ * 

+ * The ID of the peripheral that will have its interrupt disabled in the

+ * interrupt controller.  Peripheral IDs are defined in the xparameters.h header 

+ * file, which is itself part of the BSP project.  For example, in the official 

+ * demo application for this port, xparameters.h defines the following IDs for 

+ * the four possible interrupt sources:

+ *

+ * XPAR_INTC_0_UARTLITE_1_VEC_ID  -  for the UARTlite peripheral.

+ * XPAR_INTC_0_TMRCTR_0_VEC_ID    -  for the AXI Timer 0 peripheral.

+ * XPAR_INTC_0_EMACLITE_0_VEC_ID  -  for the Ethernet lite peripheral.

+ * XPAR_INTC_0_GPIO_1_VEC_ID      -  for the button inputs.

+ *

+ */

+void vPortDisableInterrupt( unsigned char ucInterruptID );

+

+/*

+ * This is an application defined callback function used to install the tick

+ * interrupt handler.  It is provided as an application callback because the 

+ * kernel will run on lots of different MicroBlaze and FPGA configurations - not 

+ * all of which will have the same timer peripherals defined or available.  This 

+ * example uses the AXI Timer 0.  If that is available on your hardware platform 

+ * then this example callback implementation should not require modification.  

+ * The name of the interrupt handler that should be installed is vPortTickISR(), 

+ * which the function below declares as an extern.

+ */ 

+void vApplicationSetupTimerInterrupt( void );

+

+/* 

+ * This is an application defined callback function used to clear whichever

+ * interrupt was installed by the the vApplicationSetupTimerInterrupt() callback

+ * function - in this case the interrupt generated by the AXI timer.  It is 

+ * provided as an application callback because the kernel will run on lots of 

+ * different MicroBlaze and FPGA configurations - not all of which will have the 

+ * same timer peripherals defined or available.  This example uses the AXI Timer 0.  

+ * If that is available on your hardware platform then this example callback 

+ * implementation should not require modification provided the example definition

+ * of vApplicationSetupTimerInterrupt() is also not modified. 

+ */

+void vApplicationClearTimerInterrupt( void );

+

+/*

+ * vPortExceptionsInstallHandlers() is only available when the MicroBlaze

+ * is configured to include exception functionality, and 

+ * configINSTALL_EXCEPTION_HANDLERS is set to 1 in FreeRTOSConfig.h.

+ *

+ * vPortExceptionsInstallHandlers() installs the FreeRTOS exception handler

+ * for every possible exception cause.  

+ *

+ * vPortExceptionsInstallHandlers() can be called explicitly from application

+ * code.  After that is done, the default FreeRTOS exception handler that will

+ * have been installed can be replaced for any specific exception cause by using 

+ * the standard Xilinx library function microblaze_register_exception_handler().

+ *

+ * If vPortExceptionsInstallHandlers() is not called explicitly by the 

+ * application, it will be called automatically by the kernel the first time

+ * xPortInstallInterruptHandler() is called.  At that time, any exception 

+ * handlers that may have already been installed will be replaced.

+ *

+ * See the description of vApplicationExceptionRegisterDump() for information

+ * on the processing performed by the FreeRTOS exception handler.

+ */

+void vPortExceptionsInstallHandlers( void );

+

+/*

+ * The FreeRTOS exception handler fills an xPortRegisterDump structure (defined 

+ * in portmacro.h) with the MicroBlaze context, as it was at the time the 

+ * exception occurred.  The exception handler then calls

+ * vApplicationExceptionRegisterDump(), passing in the completed

+ * xPortRegisterDump structure as its parameter.

+ *

+ * The FreeRTOS kernel provides its own implementation of

+ * vApplicationExceptionRegisterDump(), but the kernel provided implementation 

+ * is declared as being 'weak'.  The weak definition allows the application 

+ * writer to provide their own implementation, should they wish to use the 

+ * register dump information.  For example, an implementation could be provided

+ * that wrote the register dump data to a display, or a UART port.

+ */

+void vApplicationExceptionRegisterDump( xPortRegisterDump *xRegisterDump );

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/NiosII/port.c b/FreeRTOS/Source/portable/GCC/NiosII/port.c
new file mode 100644
index 0000000..d134993
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/NiosII/port.c
@@ -0,0 +1,244 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the NIOS2 port.

+ *----------------------------------------------------------*/

+

+/* Standard Includes. */

+#include <string.h>

+#include <errno.h>

+

+/* Altera includes. */

+#include "sys/alt_irq.h"

+#include "altera_avalon_timer_regs.h"

+#include "priv/alt_irq_table.h"

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Interrupts are enabled. */

+#define portINITIAL_ESTATUS     ( portSTACK_TYPE ) 0x01 

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Call back for the alarm function.

+ */

+void vPortSysTickHandler( void * context, alt_u32 id );

+

+/*-----------------------------------------------------------*/

+

+static void prvReadGp( unsigned long *ulValue )

+{

+	asm( "stw gp, (%0)" :: "r"(ulValue) );

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{    

+portSTACK_TYPE *pxFramePointer = pxTopOfStack - 1;

+portSTACK_TYPE xGlobalPointer;

+

+    prvReadGp( &xGlobalPointer ); 

+

+    /* End of stack marker. */

+    *pxTopOfStack = 0xdeadbeef;

+    pxTopOfStack--;

+    

+    *pxTopOfStack = ( portSTACK_TYPE ) pxFramePointer; 

+    pxTopOfStack--;

+    

+    *pxTopOfStack = xGlobalPointer; 

+    

+    /* Space for R23 to R16. */

+    pxTopOfStack -= 9;

+

+    *pxTopOfStack = ( portSTACK_TYPE ) pxCode; 

+    pxTopOfStack--;

+

+    *pxTopOfStack = portINITIAL_ESTATUS; 

+

+    /* Space for R15 to R5. */    

+    pxTopOfStack -= 12;

+    

+    *pxTopOfStack = ( portSTACK_TYPE ) pvParameters; 

+

+    /* Space for R3 to R1, muldiv and RA. */

+    pxTopOfStack -= 5;

+    

+    return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Start the first task. */

+    asm volatile (  " movia r2, restore_sp_from_pxCurrentTCB        \n"

+                    " jmp r2                                          " );

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the NIOS2 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Try to register the interrupt handler. */

+	if ( -EINVAL == alt_irq_register( SYS_CLK_IRQ, 0x0, vPortSysTickHandler ) )

+	{ 

+		/* Failed to install the Interrupt Handler. */

+		asm( "break" );

+	}

+	else

+	{

+		/* Configure SysTick to interrupt at the requested rate. */

+		IOWR_ALTERA_AVALON_TIMER_CONTROL( SYS_CLK_BASE, ALTERA_AVALON_TIMER_CONTROL_STOP_MSK );

+		IOWR_ALTERA_AVALON_TIMER_PERIODL( SYS_CLK_BASE, ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) & 0xFFFF );

+		IOWR_ALTERA_AVALON_TIMER_PERIODH( SYS_CLK_BASE, ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) >> 16 );

+		IOWR_ALTERA_AVALON_TIMER_CONTROL( SYS_CLK_BASE, ALTERA_AVALON_TIMER_CONTROL_CONT_MSK | ALTERA_AVALON_TIMER_CONTROL_START_MSK | ALTERA_AVALON_TIMER_CONTROL_ITO_MSK );	

+	} 

+

+	/* Clear any already pending interrupts generated by the Timer. */

+	IOWR_ALTERA_AVALON_TIMER_STATUS( SYS_CLK_BASE, ~ALTERA_AVALON_TIMER_STATUS_TO_MSK );

+}

+/*-----------------------------------------------------------*/

+

+void vPortSysTickHandler( void * context, alt_u32 id )

+{

+	/* Increment the Kernel Tick. */

+	vTaskIncrementTick();

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+        vTaskSwitchContext();

+	#endif

+

+	/* Clear the interrupt. */

+	IOWR_ALTERA_AVALON_TIMER_STATUS( SYS_CLK_BASE, ~ALTERA_AVALON_TIMER_STATUS_TO_MSK );

+}

+/*-----------------------------------------------------------*/

+

+/** This function is a re-implementation of the Altera provided function.

+ * The function is re-implemented to prevent it from enabling an interrupt

+ * when it is registered. Interrupts should only be enabled after the FreeRTOS.org

+ * kernel has its scheduler started so that contexts are saved and switched 

+ * correctly.

+ */

+int alt_irq_register( alt_u32 id, void* context, void (*handler)(void*, alt_u32) )

+{

+	int rc = -EINVAL;  

+	alt_irq_context status;

+

+	if (id < ALT_NIRQ)

+	{

+		/* 

+		 * interrupts are disabled while the handler tables are updated to ensure

+		 * that an interrupt doesn't occur while the tables are in an inconsistent

+		 * state.

+		 */

+	

+		status = alt_irq_disable_all ();

+	

+		alt_irq[id].handler = handler;

+		alt_irq[id].context = context;

+	

+		rc = (handler) ? alt_irq_enable (id): alt_irq_disable (id);

+	

+		/* alt_irq_enable_all(status); This line is removed to prevent the interrupt from being immediately enabled. */

+	}

+    

+	return rc; 

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/GCC/NiosII/port_asm.S b/FreeRTOS/Source/portable/GCC/NiosII/port_asm.S
new file mode 100644
index 0000000..b385f02
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/NiosII/port_asm.S
@@ -0,0 +1,188 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+.extern		vTaskSwitchContext

+	

+.set noat

+

+# Exported to start the first task.

+.globl restore_sp_from_pxCurrentTCB		

+	

+# Entry point for exceptions.

+.section .exceptions.entry, "xa"		

+

+# Save the entire context of a task.

+save_context:

+	addi	ea, ea, -4			# Point to the next instruction.

+	addi	sp,	sp, -116		# Create space on the stack.

+	stw		ra, 0(sp)

+								# Leave a gap for muldiv 0

+	stw		at, 8(sp)		 

+	stw		r2, 12(sp)

+	stw		r3, 16(sp)

+	stw		r4, 20(sp)

+	stw		r5, 24(sp) 

+	stw		r6, 28(sp) 

+	stw		r7, 32(sp) 

+	stw		r8, 36(sp) 

+	stw		r9, 40(sp) 

+	stw		r10, 44(sp)

+	stw		r11, 48(sp)

+	stw		r12, 52(sp)

+	stw		r13, 56(sp)

+	stw		r14, 60(sp)

+	stw		r15, 64(sp)

+	rdctl	r5, estatus 		# Save the eStatus

+	stw		r5, 68(sp)

+	stw		ea, 72(sp)			# Save the PC

+	stw		r16, 76(sp)			# Save the remaining registers

+	stw		r17, 80(sp)

+	stw		r18, 84(sp)

+	stw		r19, 88(sp)

+	stw		r20, 92(sp)

+	stw		r21, 96(sp)

+	stw		r22, 100(sp)

+	stw		r23, 104(sp)

+	stw		gp, 108(sp)

+	stw		fp, 112(sp)

+

+save_sp_to_pxCurrentTCB:

+	movia	et, pxCurrentTCB	# Load the address of the pxCurrentTCB pointer

+	ldw		et, (et)			# Load the value of the pxCurrentTCB pointer

+	stw		sp, (et)			# Store the stack pointer into the top of the TCB

+	

+	.section .exceptions.irqtest, "xa"	

+hw_irq_test:

+	/*

+     * Test to see if the exception was a software exception or caused 

+     * by an external interrupt, and vector accordingly.

+     */

+    rdctl	r4, ipending		# Load the Pending Interrupts indication

+	rdctl	r5, estatus 		# Load the eStatus (enabled interrupts).

+    andi	r2, r5, 1			# Are interrupts enabled globally.

+    beq		r2, zero, soft_exceptions		# Interrupts are not enabled.

+    beq		r4, zero, soft_exceptions		# There are no interrupts triggered.

+

+	.section .exceptions.irqhandler, "xa"

+hw_irq_handler:

+	call	alt_irq_handler					# Call the alt_irq_handler to deliver to the registered interrupt handler.

+

+    .section .exceptions.irqreturn, "xa"

+restore_sp_from_pxCurrentTCB:

+	movia	et, pxCurrentTCB		# Load the address of the pxCurrentTCB pointer

+	ldw		et, (et)				# Load the value of the pxCurrentTCB pointer

+	ldw		sp, (et)				# Load the stack pointer with the top value of the TCB

+

+restore_context:

+	ldw		ra, 0(sp)		# Restore the registers.

+							# Leave a gap for muldiv 0.

+	ldw		at, 8(sp)

+	ldw		r2, 12(sp)

+	ldw		r3, 16(sp)

+	ldw		r4, 20(sp)

+	ldw		r5, 24(sp) 

+	ldw		r6, 28(sp) 

+	ldw		r7, 32(sp) 

+	ldw		r8, 36(sp) 

+	ldw		r9, 40(sp) 

+	ldw		r10, 44(sp)

+	ldw		r11, 48(sp)

+	ldw		r12, 52(sp)

+	ldw		r13, 56(sp)

+	ldw		r14, 60(sp)

+	ldw		r15, 64(sp)

+	ldw		et, 68(sp)		# Load the eStatus

+	wrctl	estatus, et 	# Write the eStatus

+	ldw		ea, 72(sp)		# Load the Program Counter

+	ldw		r16, 76(sp)

+	ldw		r17, 80(sp)

+	ldw		r18, 84(sp)

+	ldw		r19, 88(sp)

+	ldw		r20, 92(sp)

+	ldw		r21, 96(sp)

+	ldw		r22, 100(sp)

+	ldw		r23, 104(sp)

+	ldw		gp, 108(sp)

+	ldw		fp, 112(sp)

+	addi	sp,	sp, 116		# Release stack space

+

+    eret					# Return to address ea, loading eStatus into Status.

+   

+	.section .exceptions.soft, "xa"

+soft_exceptions:

+	ldw		et, 0(ea)				# Load the instruction where the interrupt occured.

+	movhi	at, %hi(0x003B683A)		# Load the registers with the trap instruction code

+	ori		at, at, %lo(0x003B683A)

+   	cmpne	et, et, at				# Compare the trap instruction code to the last excuted instruction

+  	beq		et, r0, call_scheduler	# its a trap so switchcontext

+  	break							# This is an un-implemented instruction or muldiv problem.

+  	br		restore_context			# its something else

+

+call_scheduler:

+	addi	ea, ea, 4						# A trap was called, increment the program counter so it is not called again.

+	stw		ea, 72(sp)						# Save the new program counter to the context.

+	call	vTaskSwitchContext				# Pick the next context.

+	br		restore_sp_from_pxCurrentTCB	# Switch in the task context and restore. 

diff --git a/FreeRTOS/Source/portable/GCC/NiosII/portmacro.h b/FreeRTOS/Source/portable/GCC/NiosII/portmacro.h
new file mode 100644
index 0000000..2d82ab6
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/NiosII/portmacro.h
@@ -0,0 +1,140 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+#include "sys/alt_irq.h"

+

+/*-----------------------------------------------------------

+ * 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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH				( -1 )

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT				4

+#define portNOP()                   	asm volatile ( "NOP" )

+#define portCRITICAL_NESTING_IN_TCB		1

+/*-----------------------------------------------------------*/	

+

+extern void vTaskSwitchContext( void );

+#define portYIELD()									asm volatile ( "trap" );

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	if( xSwitchRequired ) 	vTaskSwitchContext()

+

+

+/* Include the port_asm.S file where the Context saving/restoring is defined. */

+__asm__( "\n\t.globl	save_context" );

+

+/*-----------------------------------------------------------*/

+

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	alt_irq_disable_all()

+#define portENABLE_INTERRUPTS()		alt_irq_enable_all( 0x01 );

+#define portENTER_CRITICAL()        vTaskEnterCritical()

+#define portEXIT_CRITICAL()         vTaskExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/FPU_Macros.h b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/FPU_Macros.h
new file mode 100644
index 0000000..fb529f2
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/FPU_Macros.h
@@ -0,0 +1,84 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* When switching out a task, if the task tag contains a buffer address then

+save the flop context into the buffer. */

+#define traceTASK_SWITCHED_OUT()											\

+	if( pxCurrentTCB->pxTaskTag != NULL )									\

+	{																		\

+		extern void vPortSaveFPURegisters( void * );						\

+		vPortSaveFPURegisters( ( void * ) ( pxCurrentTCB->pxTaskTag ) );	\

+	}

+

+/* When switching in a task, if the task tag contains a buffer address then

+load the flop context from the buffer. */

+#define traceTASK_SWITCHED_IN()												\

+	if( pxCurrentTCB->pxTaskTag != NULL )									\

+	{																		\

+		extern void vPortRestoreFPURegisters( void * );						\

+		vPortRestoreFPURegisters( ( void * ) ( pxCurrentTCB->pxTaskTag ) );	\

+	}

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/port.c b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/port.c
new file mode 100644
index 0000000..c8dd1b3
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/port.c
@@ -0,0 +1,299 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the PPC405 port.

+ *----------------------------------------------------------*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "xtime_l.h"

+#include "xintc.h"

+#include "xintc_i.h"

+

+/*-----------------------------------------------------------*/

+

+/* Definitions to set the initial MSR of each task. */

+#define portCRITICAL_INTERRUPT_ENABLE	( 1UL << 17UL )

+#define portEXTERNAL_INTERRUPT_ENABLE	( 1UL << 15UL )

+#define portMACHINE_CHECK_ENABLE		( 1UL << 12UL )

+

+#if configUSE_FPU == 1

+	#define portAPU_PRESENT				( 1UL << 25UL )

+	#define portFCM_FPU_PRESENT			( 1UL << 13UL )

+#else

+	#define portAPU_PRESENT				( 0UL )

+	#define portFCM_FPU_PRESENT			( 0UL )

+#endif

+

+#define portINITIAL_MSR		( portCRITICAL_INTERRUPT_ENABLE | portEXTERNAL_INTERRUPT_ENABLE | portMACHINE_CHECK_ENABLE | portAPU_PRESENT | portFCM_FPU_PRESENT )

+

+

+extern const unsigned _SDA_BASE_;

+extern const unsigned _SDA2_BASE_;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the system timer to generate the tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * The handler for the tick interrupt - defined in portasm.s.

+ */

+extern void vPortTickISR( void );

+

+/*

+ * The handler for the yield function - defined in portasm.s.

+ */

+extern void vPortYield( void );

+

+/*

+ * Function to start the scheduler running by starting the highest

+ * priority task that has thus far been created.

+ */

+extern void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* Structure used to hold the state of the interrupt controller. */

+static XIntc xInterruptController;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if the task had been

+ * interrupted.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Place a known value at the bottom of the stack for debugging. */

+	*pxTopOfStack = 0xDEADBEEF;

+	pxTopOfStack--;

+

+	/* EABI stack frame. */

+	pxTopOfStack -= 20;	/* Previous backchain and LR, R31 to R4 inclusive. */

+

+	/* Parameters in R13. */

+	*pxTopOfStack = ( portSTACK_TYPE ) &_SDA_BASE_; /* address of the first small data area */

+	pxTopOfStack -= 10;

+

+	/* Parameters in R3. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	/* Parameters in R2. */

+	*pxTopOfStack = ( portSTACK_TYPE ) &_SDA2_BASE_;	/* address of the second small data area */

+	pxTopOfStack--;

+

+	/* R1 is the stack pointer so is omitted. */

+

+	*pxTopOfStack = 0x10000001UL;;	/* R0. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* USPRG0. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* CR. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* XER. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* CTR. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) vPortEndScheduler;	/* LR. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode; /* SRR0. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_MSR;/* SRR1. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) vPortEndScheduler;/* Next LR. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;/* Backchain. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	prvSetupTimerInterrupt();

+	XExc_RegisterHandler( XEXC_ID_SYSTEM_CALL, ( XExceptionHandler ) vPortYield, ( void * ) 0 );

+	vPortStartFirstTask();

+

+	/* Should not get here as the tasks are now running! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+	for( ;; );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.   

+ */

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulInterval = ( ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL );

+

+	XTime_PITClearInterrupt();

+	XTime_FITClearInterrupt();

+	XTime_WDTClearInterrupt();

+	XTime_WDTDisableInterrupt();

+	XTime_FITDisableInterrupt();

+

+	XExc_RegisterHandler( XEXC_ID_PIT_INT, ( XExceptionHandler ) vPortTickISR, ( void * ) 0 );

+

+	XTime_PITEnableAutoReload();

+	XTime_PITSetInterval( ulInterval );

+	XTime_PITEnableInterrupt();

+}

+/*-----------------------------------------------------------*/

+

+void vPortISRHandler( void *pvNullDoNotUse )

+{

+unsigned long ulInterruptStatus, ulInterruptMask = 1UL;

+portBASE_TYPE xInterruptNumber;

+XIntc_Config *pxInterruptController;

+XIntc_VectorTableEntry *pxTable;

+

+	/* Just to remove compiler warning. */

+	( void ) pvNullDoNotUse;	

+

+	/* Get the configuration by using the device ID - in this case it is

+	assumed that only one interrupt controller is being used. */

+	pxInterruptController = &XIntc_ConfigTable[ XPAR_XPS_INTC_0_DEVICE_ID ];

+  

+	/* Which interrupts are pending? */

+	ulInterruptStatus = XIntc_mGetIntrStatus( pxInterruptController->BaseAddress );

+  

+	for( xInterruptNumber = 0; xInterruptNumber < XPAR_INTC_MAX_NUM_INTR_INPUTS; xInterruptNumber++ )

+	{

+		if( ulInterruptStatus & 0x01UL )

+		{

+			/* Clear the pending interrupt. */

+			XIntc_mAckIntr( pxInterruptController->BaseAddress, ulInterruptMask );

+

+			/* Call the registered handler. */

+			pxTable = &( pxInterruptController->HandlerTable[ xInterruptNumber ] );

+			pxTable->Handler( pxTable->CallBackRef );

+		}

+        

+		/* Check the next interrupt. */

+		ulInterruptMask <<= 0x01UL;

+		ulInterruptStatus >>= 0x01UL;

+

+		/* Have we serviced all interrupts? */

+		if( ulInterruptStatus == 0UL )

+		{

+			break;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortSetupInterruptController( void )

+{

+extern void vPortISRWrapper( void );

+

+	/* Perform all library calls necessary to initialise the exception table

+	and interrupt controller.  This assumes only one interrupt controller is in

+	use. */

+	XExc_mDisableExceptions( XEXC_NON_CRITICAL );

+	XExc_Init();

+

+	/* The library functions save the context - we then jump to a wrapper to

+	save the stack into the TCB.  The wrapper then calls the handler defined

+	above. */

+	XExc_RegisterHandler( XEXC_ID_NON_CRITICAL_INT, ( XExceptionHandler ) vPortISRWrapper, NULL );

+	XIntc_Initialize( &xInterruptController, XPAR_XPS_INTC_0_DEVICE_ID );

+	XIntc_Start( &xInterruptController, XIN_REAL_MODE );

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortInstallInterruptHandler( unsigned char ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef )

+{

+portBASE_TYPE xReturn = pdFAIL;

+

+	/* This function is defined here so the scope of xInterruptController can

+	remain within this file. */

+

+	if( XST_SUCCESS == XIntc_Connect( &xInterruptController, ucInterruptID, pxHandler, pvCallBackRef ) )

+	{

+		XIntc_Enable( &xInterruptController, ucInterruptID );

+		xReturn = pdPASS;

+	}

+

+	return xReturn;		

+}

diff --git a/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portasm.S b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portasm.S
new file mode 100644
index 0000000..4abff80
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portasm.S
@@ -0,0 +1,421 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOSConfig.h"

+

+	.extern pxCurrentTCB

+	.extern vTaskSwitchContext

+	.extern vTaskIncrementTick

+	.extern vPortISRHandler

+

+	.global vPortStartFirstTask

+	.global vPortYield

+	.global vPortTickISR

+	.global vPortISRWrapper

+	.global vPortSaveFPURegisters

+	.global vPortRestoreFPURegisters

+

+.set	BChainField, 0

+.set	NextLRField, BChainField + 4

+.set	MSRField,    NextLRField + 4

+.set	PCField,     MSRField    + 4

+.set	LRField,     PCField     + 4

+.set	CTRField,    LRField     + 4

+.set	XERField,    CTRField    + 4

+.set	CRField,     XERField    + 4

+.set	USPRG0Field, CRField     + 4

+.set	r0Field,     USPRG0Field + 4

+.set	r2Field,     r0Field     + 4

+.set	r3r31Field,  r2Field     + 4

+.set	IFrameSize,  r3r31Field  + ( ( 31 - 3 ) + 1 ) * 4

+

+

+.macro portSAVE_STACK_POINTER_AND_LR

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+	addis	R2, R0, pxCurrentTCB@ha

+	lwz		R2,	pxCurrentTCB@l( R2 )

+

+	/* Store the stack pointer into the TCB */

+	stw		SP,	0( R2 )

+

+	/* Save the link register */

+	stwu	R1, -24( R1 )

+	mflr	R0

+	stw		R31, 20( R1 )

+	stw		R0, 28( R1 )

+	mr		R31, r1

+

+.endm

+

+.macro portRESTORE_STACK_POINTER_AND_LR

+

+	/* Restore the link register */

+	lwz		R11, 0( R1 )

+	lwz		R0, 4( R11 )

+	mtlr	R0

+	lwz		R31, -4( R11 )

+	mr		R1, R11

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+	addis   SP, R0, pxCurrentTCB@ha

+	lwz		SP,	pxCurrentTCB@l( R1 )

+

+	/* Get the task stack pointer from the TCB. */

+	lwz		SP, 0( SP )

+

+.endm

+

+

+vPortStartFirstTask:

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+    addis   SP, R0, pxCurrentTCB@ha

+    lwz		SP,	pxCurrentTCB@l( SP )

+

+	/* Get the task stack pointer from the TCB. */

+	lwz		SP, 0( SP )

+	

+	/* Restore MSR register to SRR1. */

+	lwz		R0, MSRField(R1)

+	mtsrr1	R0

+	

+	/* Restore current PC location to SRR0. */

+	lwz		R0, PCField(R1)

+	mtsrr0	R0

+

+	/* Save  USPRG0 register */

+	lwz		R0, USPRG0Field(R1)

+	mtspr	0x100,R0

+	

+	/* Restore Condition register */

+	lwz		R0, CRField(R1)

+	mtcr	R0

+	

+	/* Restore Fixed Point Exception register */

+	lwz		R0, XERField(R1)

+	mtxer	R0

+	

+	/* Restore Counter register */

+	lwz		R0, CTRField(R1)

+	mtctr	R0

+	

+	/* Restore Link register */

+	lwz		R0, LRField(R1)

+	mtlr	R0

+	

+	/* Restore remaining GPR registers. */

+	lmw	R3,r3r31Field(R1)

+	

+	/* Restore r0 and r2. */

+	lwz		R0, r0Field(R1)

+	lwz		R2, r2Field(R1)

+	

+	/* Remove frame from stack */

+	addi	R1,R1,IFrameSize

+

+	/* Return into the first task */

+	rfi

+

+

+

+vPortYield:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vTaskSwitchContext

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+vPortTickISR:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vTaskIncrementTick

+	

+	#if configUSE_PREEMPTION == 1

+		bl vTaskSwitchContext

+	#endif

+

+	/* Clear the interrupt */

+	lis		R0, 2048

+	mttsr	R0

+

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+vPortISRWrapper:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vPortISRHandler

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+#if configUSE_FPU == 1

+

+vPortSaveFPURegisters:

+

+	/* Enable APU and mark FPU as present. */

+	mfmsr	r0

+	xor		r30, r30, r30

+	oris	r30, r30, 512

+	ori		r30, r30, 8192

+	or		r0, r0, r30

+	mtmsr	r0

+

+#ifdef USE_DP_FPU

+

+	/* Buffer address is in r3.  Save each flop register into an offset from

+	this buffer address. */

+	stfd	f0, 0(r3)

+	stfd	f1, 8(r3)

+	stfd	f2, 16(r3)

+	stfd	f3, 24(r3)

+	stfd	f4, 32(r3)

+	stfd	f5, 40(r3)

+	stfd	f6, 48(r3)

+	stfd	f7, 56(r3)

+	stfd	f8, 64(r3)

+	stfd	f9, 72(r3)

+	stfd	f10, 80(r3)

+	stfd	f11, 88(r3)

+	stfd	f12, 96(r3)

+	stfd	f13, 104(r3)

+	stfd	f14, 112(r3)

+	stfd	f15, 120(r3)

+	stfd	f16, 128(r3)

+	stfd	f17, 136(r3)

+	stfd	f18, 144(r3)

+	stfd	f19, 152(r3)

+	stfd	f20, 160(r3)

+	stfd	f21, 168(r3)

+	stfd	f22, 176(r3)

+	stfd	f23, 184(r3)

+	stfd	f24, 192(r3)

+	stfd	f25, 200(r3)

+	stfd	f26, 208(r3)

+	stfd	f27, 216(r3)

+	stfd	f28, 224(r3)

+	stfd	f29, 232(r3)

+	stfd	f30, 240(r3)

+	stfd	f31, 248(r3)	

+	

+	/* Also save the FPSCR. */

+	mffs	f31

+	stfs	f31, 256(r3)

+

+#else

+

+	/* Buffer address is in r3.  Save each flop register into an offset from

+	this buffer address. */

+	stfs	f0, 0(r3)

+	stfs	f1, 4(r3)

+	stfs	f2, 8(r3)

+	stfs	f3, 12(r3)

+	stfs	f4, 16(r3)

+	stfs	f5, 20(r3)

+	stfs	f6, 24(r3)

+	stfs	f7, 28(r3)

+	stfs	f8, 32(r3)

+	stfs	f9, 36(r3)

+	stfs	f10, 40(r3)

+	stfs	f11, 44(r3)

+	stfs	f12, 48(r3)

+	stfs	f13, 52(r3)

+	stfs	f14, 56(r3)

+	stfs	f15, 60(r3)

+	stfs	f16, 64(r3)

+	stfs	f17, 68(r3)

+	stfs	f18, 72(r3)

+	stfs	f19, 76(r3)

+	stfs	f20, 80(r3)

+	stfs	f21, 84(r3)

+	stfs	f22, 88(r3)

+	stfs	f23, 92(r3)

+	stfs	f24, 96(r3)

+	stfs	f25, 100(r3)

+	stfs	f26, 104(r3)

+	stfs	f27, 108(r3)

+	stfs	f28, 112(r3)

+	stfs	f29, 116(r3)

+	stfs	f30, 120(r3)

+	stfs	f31, 124(r3)

+	

+	/* Also save the FPSCR. */

+	mffs	f31

+	stfs	f31, 128(r3)

+	

+#endif

+

+	blr

+

+#endif /* configUSE_FPU. */

+

+

+#if configUSE_FPU == 1

+

+vPortRestoreFPURegisters:

+

+	/* Enable APU and mark FPU as present. */

+	mfmsr	r0

+	xor		r30, r30, r30

+	oris	r30, r30, 512

+	ori		r30, r30, 8192

+	or		r0, r0, r30

+	mtmsr	r0

+

+#ifdef USE_DP_FPU

+

+	/* Buffer address is in r3.  Restore each flop register from an offset

+	into this buffer. 

+	

+	First the FPSCR. */

+	lfs		f31, 256(r3)

+	mtfsf	f31, 7

+

+	lfd		f0, 0(r3)

+	lfd	    f1, 8(r3)

+	lfd		f2, 16(r3)

+	lfd		f3, 24(r3)

+	lfd		f4, 32(r3)

+	lfd		f5, 40(r3)

+	lfd		f6, 48(r3)

+	lfd		f7, 56(r3)

+	lfd		f8, 64(r3)

+	lfd		f9, 72(r3)

+	lfd		f10, 80(r3)

+	lfd		f11, 88(r3)

+	lfd		f12, 96(r3)

+	lfd		f13, 104(r3)

+	lfd		f14, 112(r3)

+	lfd		f15, 120(r3)

+	lfd		f16, 128(r3)

+	lfd		f17, 136(r3)

+	lfd		f18, 144(r3)

+	lfd		f19, 152(r3)

+	lfd		f20, 160(r3)

+	lfd		f21, 168(r3)

+	lfd		f22, 176(r3)

+	lfd		f23, 184(r3)

+	lfd		f24, 192(r3)

+	lfd		f25, 200(r3)

+	lfd		f26, 208(r3)

+	lfd		f27, 216(r3)

+	lfd		f28, 224(r3)

+	lfd		f29, 232(r3)

+	lfd		f30, 240(r3)

+	lfd		f31, 248(r3)

+

+#else

+

+	/* Buffer address is in r3.  Restore each flop register from an offset

+	into this buffer. 

+	

+	First the FPSCR. */

+	lfs		f31, 128(r3)

+	mtfsf	f31, 7

+

+	lfs		f0, 0(r3)

+	lfs		f1, 4(r3)

+	lfs		f2, 8(r3)

+	lfs		f3, 12(r3)

+	lfs		f4, 16(r3)

+	lfs		f5, 20(r3)

+	lfs		f6, 24(r3)

+	lfs		f7, 28(r3)

+	lfs		f8, 32(r3)

+	lfs		f9, 36(r3)

+	lfs		f10, 40(r3)

+	lfs		f11, 44(r3)

+	lfs		f12, 48(r3)

+	lfs		f13, 52(r3)

+	lfs		f14, 56(r3)

+	lfs		f15, 60(r3)

+	lfs		f16, 64(r3)

+	lfs		f17, 68(r3)

+	lfs		f18, 72(r3)

+	lfs		f19, 76(r3)

+	lfs		f20, 80(r3)

+	lfs		f21, 84(r3)

+	lfs		f22, 88(r3)

+	lfs		f23, 92(r3)

+	lfs		f24, 96(r3)

+	lfs		f25, 100(r3)

+	lfs		f26, 104(r3)

+	lfs		f27, 108(r3)

+	lfs		f28, 112(r3)

+	lfs		f29, 116(r3)

+	lfs		f30, 120(r3)

+	lfs		f31, 124(r3)

+

+#endif

+

+	blr

+

+#endif /* configUSE_FPU. */

+

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portmacro.h b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portmacro.h
new file mode 100644
index 0000000..c1d36ad
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC405_Xilinx/portmacro.h
@@ -0,0 +1,153 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include "xexception_l.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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* This port uses the critical nesting count from the TCB rather than

+maintaining a separate value and then saving this value in the task stack. */

+#define portCRITICAL_NESTING_IN_TCB		1

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()		XExc_mDisableExceptions( XEXC_NON_CRITICAL );

+#define portENABLE_INTERRUPTS()			XExc_mEnableExceptions( XEXC_NON_CRITICAL );

+

+/*-----------------------------------------------------------*/

+

+/* Critical section macros. */

+void vTaskEnterCritical( void );

+void vTaskExitCritical( void );

+#define portENTER_CRITICAL()			vTaskEnterCritical()

+#define portEXIT_CRITICAL()				vTaskExitCritical()

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+void vPortYield( void );

+#define portYIELD() asm volatile ( "SC \n\t NOP" )

+#define portYIELD_FROM_ISR() vTaskSwitchContext()

+

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			8

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()					asm volatile ( "NOP" )

+

+/* There are 32 * 32bit floating point regieters, plus the FPSCR to save. */

+#define portNO_FLOP_REGISTERS_TO_SAVE  ( 32 + 1 )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+/* Port specific interrupt handling functions. */

+void vPortSetupInterruptController( void );

+portBASE_TYPE xPortInstallInterruptHandler( unsigned portCHAR ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef );

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/FPU_Macros.h b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/FPU_Macros.h
new file mode 100644
index 0000000..fb529f2
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/FPU_Macros.h
@@ -0,0 +1,84 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* When switching out a task, if the task tag contains a buffer address then

+save the flop context into the buffer. */

+#define traceTASK_SWITCHED_OUT()											\

+	if( pxCurrentTCB->pxTaskTag != NULL )									\

+	{																		\

+		extern void vPortSaveFPURegisters( void * );						\

+		vPortSaveFPURegisters( ( void * ) ( pxCurrentTCB->pxTaskTag ) );	\

+	}

+

+/* When switching in a task, if the task tag contains a buffer address then

+load the flop context from the buffer. */

+#define traceTASK_SWITCHED_IN()												\

+	if( pxCurrentTCB->pxTaskTag != NULL )									\

+	{																		\

+		extern void vPortRestoreFPURegisters( void * );						\

+		vPortRestoreFPURegisters( ( void * ) ( pxCurrentTCB->pxTaskTag ) );	\

+	}

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/port.c b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/port.c
new file mode 100644
index 0000000..53edd81
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/port.c
@@ -0,0 +1,299 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the PPC440 port.

+ *----------------------------------------------------------*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "xtime_l.h"

+#include "xintc.h"

+#include "xintc_i.h"

+

+/*-----------------------------------------------------------*/

+

+/* Definitions to set the initial MSR of each task. */

+#define portCRITICAL_INTERRUPT_ENABLE	( 1UL << 17UL )

+#define portEXTERNAL_INTERRUPT_ENABLE	( 1UL << 15UL )

+#define portMACHINE_CHECK_ENABLE		( 1UL << 12UL )

+

+#if configUSE_FPU == 1

+	#define portAPU_PRESENT				( 1UL << 25UL )

+	#define portFCM_FPU_PRESENT			( 1UL << 13UL )

+#else

+	#define portAPU_PRESENT				( 0UL )

+	#define portFCM_FPU_PRESENT			( 0UL )

+#endif

+

+#define portINITIAL_MSR		( portCRITICAL_INTERRUPT_ENABLE | portEXTERNAL_INTERRUPT_ENABLE | portMACHINE_CHECK_ENABLE | portAPU_PRESENT | portFCM_FPU_PRESENT )

+

+

+extern const unsigned _SDA_BASE_;

+extern const unsigned _SDA2_BASE_;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the system timer to generate the tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * The handler for the tick interrupt - defined in portasm.s.

+ */

+extern void vPortTickISR( void );

+

+/*

+ * The handler for the yield function - defined in portasm.s.

+ */

+extern void vPortYield( void );

+

+/*

+ * Function to start the scheduler running by starting the highest

+ * priority task that has thus far been created.

+ */

+extern void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* Structure used to hold the state of the interrupt controller. */

+static XIntc xInterruptController;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if the task had been

+ * interrupted.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Place a known value at the bottom of the stack for debugging. */

+	*pxTopOfStack = 0xDEADBEEF;

+	pxTopOfStack--;

+

+	/* EABI stack frame. */

+	pxTopOfStack -= 20;	/* Previous backchain and LR, R31 to R4 inclusive. */

+

+	/* Parameters in R13. */

+	*pxTopOfStack = ( portSTACK_TYPE ) &_SDA_BASE_; /* address of the first small data area */

+	pxTopOfStack -= 10;

+

+	/* Parameters in R3. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	/* Parameters in R2. */

+	*pxTopOfStack = ( portSTACK_TYPE ) &_SDA2_BASE_;	/* address of the second small data area */

+	pxTopOfStack--;

+

+	/* R1 is the stack pointer so is omitted. */

+

+	*pxTopOfStack = 0x10000001UL;;	/* R0. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* USPRG0. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* CR. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* XER. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;	/* CTR. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) vPortEndScheduler;	/* LR. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode; /* SRR0. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_MSR;/* SRR1. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) vPortEndScheduler;/* Next LR. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x00000000UL;/* Backchain. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	prvSetupTimerInterrupt();

+	XExc_RegisterHandler( XEXC_ID_SYSTEM_CALL, ( XExceptionHandler ) vPortYield, ( void * ) 0 );

+	vPortStartFirstTask();

+

+	/* Should not get here as the tasks are now running! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+	for( ;; );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulInterval = ( ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL );

+

+	XTime_DECClearInterrupt();

+	XTime_FITClearInterrupt();

+	XTime_WDTClearInterrupt();

+	XTime_WDTDisableInterrupt();

+	XTime_FITDisableInterrupt();

+

+	XExc_RegisterHandler( XEXC_ID_DEC_INT, ( XExceptionHandler ) vPortTickISR, ( void * ) 0 );

+

+	XTime_DECEnableAutoReload();

+	XTime_DECSetInterval( ulInterval );

+	XTime_DECEnableInterrupt();

+}

+/*-----------------------------------------------------------*/

+

+void vPortISRHandler( void *pvNullDoNotUse )

+{

+unsigned long ulInterruptStatus, ulInterruptMask = 1UL;

+portBASE_TYPE xInterruptNumber;

+XIntc_Config *pxInterruptController;

+XIntc_VectorTableEntry *pxTable;

+

+	/* Just to remove compiler warning. */

+	( void ) pvNullDoNotUse;

+

+	/* Get the configuration by using the device ID - in this case it is

+	assumed that only one interrupt controller is being used. */

+	pxInterruptController = &XIntc_ConfigTable[ XPAR_XPS_INTC_0_DEVICE_ID ];

+

+	/* Which interrupts are pending? */

+	ulInterruptStatus = XIntc_mGetIntrStatus( pxInterruptController->BaseAddress );

+

+	for( xInterruptNumber = 0; xInterruptNumber < XPAR_INTC_MAX_NUM_INTR_INPUTS; xInterruptNumber++ )

+	{

+		if( ulInterruptStatus & 0x01UL )

+		{

+			/* Clear the pending interrupt. */

+			XIntc_mAckIntr( pxInterruptController->BaseAddress, ulInterruptMask );

+

+			/* Call the registered handler. */

+			pxTable = &( pxInterruptController->HandlerTable[ xInterruptNumber ] );

+			pxTable->Handler( pxTable->CallBackRef );

+		}

+

+		/* Check the next interrupt. */

+		ulInterruptMask <<= 0x01UL;

+		ulInterruptStatus >>= 0x01UL;

+

+		/* Have we serviced all interrupts? */

+		if( ulInterruptStatus == 0UL )

+		{

+			break;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortSetupInterruptController( void )

+{

+extern void vPortISRWrapper( void );

+

+	/* Perform all library calls necessary to initialise the exception table

+	and interrupt controller.  This assumes only one interrupt controller is in

+	use. */

+	XExc_mDisableExceptions( XEXC_NON_CRITICAL );

+	XExc_Init();

+

+	/* The library functions save the context - we then jump to a wrapper to

+	save the stack into the TCB.  The wrapper then calls the handler defined

+	above. */

+	XExc_RegisterHandler( XEXC_ID_NON_CRITICAL_INT, ( XExceptionHandler ) vPortISRWrapper, NULL );

+	XIntc_Initialize( &xInterruptController, XPAR_XPS_INTC_0_DEVICE_ID );

+	XIntc_Start( &xInterruptController, XIN_REAL_MODE );

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortInstallInterruptHandler( unsigned char ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef )

+{

+portBASE_TYPE xReturn = pdFAIL;

+

+	/* This function is defined here so the scope of xInterruptController can

+	remain within this file. */

+

+	if( XST_SUCCESS == XIntc_Connect( &xInterruptController, ucInterruptID, pxHandler, pvCallBackRef ) )

+	{

+		XIntc_Enable( &xInterruptController, ucInterruptID );

+		xReturn = pdPASS;

+	}

+

+	return xReturn;

+}

diff --git a/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portasm.S b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portasm.S
new file mode 100644
index 0000000..4abff80
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portasm.S
@@ -0,0 +1,421 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOSConfig.h"

+

+	.extern pxCurrentTCB

+	.extern vTaskSwitchContext

+	.extern vTaskIncrementTick

+	.extern vPortISRHandler

+

+	.global vPortStartFirstTask

+	.global vPortYield

+	.global vPortTickISR

+	.global vPortISRWrapper

+	.global vPortSaveFPURegisters

+	.global vPortRestoreFPURegisters

+

+.set	BChainField, 0

+.set	NextLRField, BChainField + 4

+.set	MSRField,    NextLRField + 4

+.set	PCField,     MSRField    + 4

+.set	LRField,     PCField     + 4

+.set	CTRField,    LRField     + 4

+.set	XERField,    CTRField    + 4

+.set	CRField,     XERField    + 4

+.set	USPRG0Field, CRField     + 4

+.set	r0Field,     USPRG0Field + 4

+.set	r2Field,     r0Field     + 4

+.set	r3r31Field,  r2Field     + 4

+.set	IFrameSize,  r3r31Field  + ( ( 31 - 3 ) + 1 ) * 4

+

+

+.macro portSAVE_STACK_POINTER_AND_LR

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+	addis	R2, R0, pxCurrentTCB@ha

+	lwz		R2,	pxCurrentTCB@l( R2 )

+

+	/* Store the stack pointer into the TCB */

+	stw		SP,	0( R2 )

+

+	/* Save the link register */

+	stwu	R1, -24( R1 )

+	mflr	R0

+	stw		R31, 20( R1 )

+	stw		R0, 28( R1 )

+	mr		R31, r1

+

+.endm

+

+.macro portRESTORE_STACK_POINTER_AND_LR

+

+	/* Restore the link register */

+	lwz		R11, 0( R1 )

+	lwz		R0, 4( R11 )

+	mtlr	R0

+	lwz		R31, -4( R11 )

+	mr		R1, R11

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+	addis   SP, R0, pxCurrentTCB@ha

+	lwz		SP,	pxCurrentTCB@l( R1 )

+

+	/* Get the task stack pointer from the TCB. */

+	lwz		SP, 0( SP )

+

+.endm

+

+

+vPortStartFirstTask:

+

+	/* Get the address of the TCB. */

+	xor		R0, R0, R0

+    addis   SP, R0, pxCurrentTCB@ha

+    lwz		SP,	pxCurrentTCB@l( SP )

+

+	/* Get the task stack pointer from the TCB. */

+	lwz		SP, 0( SP )

+	

+	/* Restore MSR register to SRR1. */

+	lwz		R0, MSRField(R1)

+	mtsrr1	R0

+	

+	/* Restore current PC location to SRR0. */

+	lwz		R0, PCField(R1)

+	mtsrr0	R0

+

+	/* Save  USPRG0 register */

+	lwz		R0, USPRG0Field(R1)

+	mtspr	0x100,R0

+	

+	/* Restore Condition register */

+	lwz		R0, CRField(R1)

+	mtcr	R0

+	

+	/* Restore Fixed Point Exception register */

+	lwz		R0, XERField(R1)

+	mtxer	R0

+	

+	/* Restore Counter register */

+	lwz		R0, CTRField(R1)

+	mtctr	R0

+	

+	/* Restore Link register */

+	lwz		R0, LRField(R1)

+	mtlr	R0

+	

+	/* Restore remaining GPR registers. */

+	lmw	R3,r3r31Field(R1)

+	

+	/* Restore r0 and r2. */

+	lwz		R0, r0Field(R1)

+	lwz		R2, r2Field(R1)

+	

+	/* Remove frame from stack */

+	addi	R1,R1,IFrameSize

+

+	/* Return into the first task */

+	rfi

+

+

+

+vPortYield:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vTaskSwitchContext

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+vPortTickISR:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vTaskIncrementTick

+	

+	#if configUSE_PREEMPTION == 1

+		bl vTaskSwitchContext

+	#endif

+

+	/* Clear the interrupt */

+	lis		R0, 2048

+	mttsr	R0

+

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+vPortISRWrapper:

+

+	portSAVE_STACK_POINTER_AND_LR

+	bl vPortISRHandler

+	portRESTORE_STACK_POINTER_AND_LR

+	blr

+

+#if configUSE_FPU == 1

+

+vPortSaveFPURegisters:

+

+	/* Enable APU and mark FPU as present. */

+	mfmsr	r0

+	xor		r30, r30, r30

+	oris	r30, r30, 512

+	ori		r30, r30, 8192

+	or		r0, r0, r30

+	mtmsr	r0

+

+#ifdef USE_DP_FPU

+

+	/* Buffer address is in r3.  Save each flop register into an offset from

+	this buffer address. */

+	stfd	f0, 0(r3)

+	stfd	f1, 8(r3)

+	stfd	f2, 16(r3)

+	stfd	f3, 24(r3)

+	stfd	f4, 32(r3)

+	stfd	f5, 40(r3)

+	stfd	f6, 48(r3)

+	stfd	f7, 56(r3)

+	stfd	f8, 64(r3)

+	stfd	f9, 72(r3)

+	stfd	f10, 80(r3)

+	stfd	f11, 88(r3)

+	stfd	f12, 96(r3)

+	stfd	f13, 104(r3)

+	stfd	f14, 112(r3)

+	stfd	f15, 120(r3)

+	stfd	f16, 128(r3)

+	stfd	f17, 136(r3)

+	stfd	f18, 144(r3)

+	stfd	f19, 152(r3)

+	stfd	f20, 160(r3)

+	stfd	f21, 168(r3)

+	stfd	f22, 176(r3)

+	stfd	f23, 184(r3)

+	stfd	f24, 192(r3)

+	stfd	f25, 200(r3)

+	stfd	f26, 208(r3)

+	stfd	f27, 216(r3)

+	stfd	f28, 224(r3)

+	stfd	f29, 232(r3)

+	stfd	f30, 240(r3)

+	stfd	f31, 248(r3)	

+	

+	/* Also save the FPSCR. */

+	mffs	f31

+	stfs	f31, 256(r3)

+

+#else

+

+	/* Buffer address is in r3.  Save each flop register into an offset from

+	this buffer address. */

+	stfs	f0, 0(r3)

+	stfs	f1, 4(r3)

+	stfs	f2, 8(r3)

+	stfs	f3, 12(r3)

+	stfs	f4, 16(r3)

+	stfs	f5, 20(r3)

+	stfs	f6, 24(r3)

+	stfs	f7, 28(r3)

+	stfs	f8, 32(r3)

+	stfs	f9, 36(r3)

+	stfs	f10, 40(r3)

+	stfs	f11, 44(r3)

+	stfs	f12, 48(r3)

+	stfs	f13, 52(r3)

+	stfs	f14, 56(r3)

+	stfs	f15, 60(r3)

+	stfs	f16, 64(r3)

+	stfs	f17, 68(r3)

+	stfs	f18, 72(r3)

+	stfs	f19, 76(r3)

+	stfs	f20, 80(r3)

+	stfs	f21, 84(r3)

+	stfs	f22, 88(r3)

+	stfs	f23, 92(r3)

+	stfs	f24, 96(r3)

+	stfs	f25, 100(r3)

+	stfs	f26, 104(r3)

+	stfs	f27, 108(r3)

+	stfs	f28, 112(r3)

+	stfs	f29, 116(r3)

+	stfs	f30, 120(r3)

+	stfs	f31, 124(r3)

+	

+	/* Also save the FPSCR. */

+	mffs	f31

+	stfs	f31, 128(r3)

+	

+#endif

+

+	blr

+

+#endif /* configUSE_FPU. */

+

+

+#if configUSE_FPU == 1

+

+vPortRestoreFPURegisters:

+

+	/* Enable APU and mark FPU as present. */

+	mfmsr	r0

+	xor		r30, r30, r30

+	oris	r30, r30, 512

+	ori		r30, r30, 8192

+	or		r0, r0, r30

+	mtmsr	r0

+

+#ifdef USE_DP_FPU

+

+	/* Buffer address is in r3.  Restore each flop register from an offset

+	into this buffer. 

+	

+	First the FPSCR. */

+	lfs		f31, 256(r3)

+	mtfsf	f31, 7

+

+	lfd		f0, 0(r3)

+	lfd	    f1, 8(r3)

+	lfd		f2, 16(r3)

+	lfd		f3, 24(r3)

+	lfd		f4, 32(r3)

+	lfd		f5, 40(r3)

+	lfd		f6, 48(r3)

+	lfd		f7, 56(r3)

+	lfd		f8, 64(r3)

+	lfd		f9, 72(r3)

+	lfd		f10, 80(r3)

+	lfd		f11, 88(r3)

+	lfd		f12, 96(r3)

+	lfd		f13, 104(r3)

+	lfd		f14, 112(r3)

+	lfd		f15, 120(r3)

+	lfd		f16, 128(r3)

+	lfd		f17, 136(r3)

+	lfd		f18, 144(r3)

+	lfd		f19, 152(r3)

+	lfd		f20, 160(r3)

+	lfd		f21, 168(r3)

+	lfd		f22, 176(r3)

+	lfd		f23, 184(r3)

+	lfd		f24, 192(r3)

+	lfd		f25, 200(r3)

+	lfd		f26, 208(r3)

+	lfd		f27, 216(r3)

+	lfd		f28, 224(r3)

+	lfd		f29, 232(r3)

+	lfd		f30, 240(r3)

+	lfd		f31, 248(r3)

+

+#else

+

+	/* Buffer address is in r3.  Restore each flop register from an offset

+	into this buffer. 

+	

+	First the FPSCR. */

+	lfs		f31, 128(r3)

+	mtfsf	f31, 7

+

+	lfs		f0, 0(r3)

+	lfs		f1, 4(r3)

+	lfs		f2, 8(r3)

+	lfs		f3, 12(r3)

+	lfs		f4, 16(r3)

+	lfs		f5, 20(r3)

+	lfs		f6, 24(r3)

+	lfs		f7, 28(r3)

+	lfs		f8, 32(r3)

+	lfs		f9, 36(r3)

+	lfs		f10, 40(r3)

+	lfs		f11, 44(r3)

+	lfs		f12, 48(r3)

+	lfs		f13, 52(r3)

+	lfs		f14, 56(r3)

+	lfs		f15, 60(r3)

+	lfs		f16, 64(r3)

+	lfs		f17, 68(r3)

+	lfs		f18, 72(r3)

+	lfs		f19, 76(r3)

+	lfs		f20, 80(r3)

+	lfs		f21, 84(r3)

+	lfs		f22, 88(r3)

+	lfs		f23, 92(r3)

+	lfs		f24, 96(r3)

+	lfs		f25, 100(r3)

+	lfs		f26, 104(r3)

+	lfs		f27, 108(r3)

+	lfs		f28, 112(r3)

+	lfs		f29, 116(r3)

+	lfs		f30, 120(r3)

+	lfs		f31, 124(r3)

+

+#endif

+

+	blr

+

+#endif /* configUSE_FPU. */

+

+

diff --git a/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portmacro.h b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portmacro.h
new file mode 100644
index 0000000..c1d36ad
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/PPC440_Xilinx/portmacro.h
@@ -0,0 +1,153 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include "xexception_l.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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* This port uses the critical nesting count from the TCB rather than

+maintaining a separate value and then saving this value in the task stack. */

+#define portCRITICAL_NESTING_IN_TCB		1

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()		XExc_mDisableExceptions( XEXC_NON_CRITICAL );

+#define portENABLE_INTERRUPTS()			XExc_mEnableExceptions( XEXC_NON_CRITICAL );

+

+/*-----------------------------------------------------------*/

+

+/* Critical section macros. */

+void vTaskEnterCritical( void );

+void vTaskExitCritical( void );

+#define portENTER_CRITICAL()			vTaskEnterCritical()

+#define portEXIT_CRITICAL()				vTaskExitCritical()

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+void vPortYield( void );

+#define portYIELD() asm volatile ( "SC \n\t NOP" )

+#define portYIELD_FROM_ISR() vTaskSwitchContext()

+

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			8

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()					asm volatile ( "NOP" )

+

+/* There are 32 * 32bit floating point regieters, plus the FPSCR to save. */

+#define portNO_FLOP_REGISTERS_TO_SAVE  ( 32 + 1 )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+/* Port specific interrupt handling functions. */

+void vPortSetupInterruptController( void );

+portBASE_TYPE xPortInstallInterruptHandler( unsigned portCHAR ucInterruptID, XInterruptHandler pxHandler, void *pvCallBackRef );

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/Posix/port.c b/FreeRTOS/Source/portable/GCC/Posix/port.c
new file mode 100644
index 0000000..2560132
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/Posix/port.c
@@ -0,0 +1,1201 @@
+/*
+	Copyright (C) 2011 Corvus Corax from OpenPilot.org
+	based on linux port from William Davy
+
+	This file is part of the FreeRTOS.org distribution.
+
+	FreeRTOS.org is free software; you can redistribute it and/or modify it
+	under the terms of the GNU General Public License (version 2) as published
+	by the Free Software Foundation and modified by the FreeRTOS exception.
+
+	FreeRTOS.org is distributed in the hope that it will be useful,	but WITHOUT
+	ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+	FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
+	more details.
+
+	You should have received a copy of the GNU General Public License along
+	with FreeRTOS.org; if not, write to the Free Software Foundation, Inc., 59
+	Temple Place, Suite 330, Boston, MA  02111-1307  USA.
+
+	A special exception to the GPL is included to allow you to distribute a
+	combined work that includes FreeRTOS.org without being obliged to provide
+	the source code for any proprietary components.  See the licensing section
+	of http://www.FreeRTOS.org for full details.
+
+
+	***************************************************************************
+	*                                                                         *
+	* Get the FreeRTOS eBook!  See http://www.FreeRTOS.org/Documentation      *
+	*                                                                         *
+	* This is a concise, step by step, 'hands on' guide that describes both   *
+	* general multitasking concepts and FreeRTOS specifics. It presents and   *
+	* explains numerous examples that are written using the FreeRTOS API.     *
+	* Full source code for all the examples is provided in an accompanying    *
+	* .zip file.                                                              *
+	*                                                                         *
+	***************************************************************************
+
+	1 tab == 4 spaces!
+
+	Please ensure to read the configuration and relevant port sections of the
+	online documentation.
+
+	http://www.FreeRTOS.org - Documentation, latest information, license and
+	contact details.
+
+	http://www.SafeRTOS.com - A version that is certified for use in safety
+	critical systems.
+
+	http://www.OpenRTOS.com - Commercial support, development, porting,
+	licensing and training services.
+*/
+
+/*-----------------------------------------------------------
+ * Implementation of functions defined in portable.h for the Posix port.
+ *----------------------------------------------------------*/
+
+
+/** Description of scheduler:
+
+This scheduler is based on posix signals to halt or preempt tasks, and on
+pthread conditions to resume them.
+
+Each FreeRTOS thread is created as a posix thread, with a signal handler to
+SIGUSR1 (SIG_SUSPEND) signals.
+
+Suspension of a thread is done by setting the threads state to
+"YIELDING/PREEMPTING", then signaling the thread until the signal handler
+changes that state to "SLEEPING", thus acknowledging the suspend.
+
+The thread will then wait within the signal handler for a thread specific
+condition to be set, which allows it to resume operation, setting its state to
+"RUNNING"
+
+The running thread also always holds a mutex (xRunningThreadMutex) which is
+given up only when the thread suspends.
+
+On thread creation the new thread will acquire this mutex, then yield.
+
+Both preemption and yielding is done using the same mechanism, sending a
+SIG_SUSPEND to the preempted thread respectively to itself, however different
+synchronization safeguards apply depending if a thread suspends itself or is
+suspended remotely
+
+Preemption is done by the main scheduler thread which attempts to run a tick
+handler at accurate intervals using nanosleep and gettimeofday, which allows
+more accurate high frequency ticks than a timer signal handler.
+
+All public functions in this port are protected by a safeguard mutex which
+assures priority access on all data objects
+
+This approach is tested and works both on Linux and BSD style Unix (MAC OS X)
+
+*/
+
+#include <pthread.h>
+#include <sched.h>
+#include <signal.h>
+#include <errno.h>
+#include <sys/time.h>
+#include <time.h>
+#include <sys/times.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <limits.h>
+
+/* Scheduler includes. */
+#include "FreeRTOS.h"
+#include "task.h"
+/*-----------------------------------------------------------*/
+
+#define MAX_NUMBER_OF_TASKS 		( _POSIX_THREAD_THREADS_MAX )
+/*-----------------------------------------------------------*/
+
+#define PORT_PRINT(...) fprintf(stderr,__VA_ARGS__)
+#define PORT_ASSERT(assertion)    if ( !(assertion) ) { PORT_PRINT("Assertion failed in %s:%i  " #assertion "\n",__FILE__,__LINE__); int volatile assfail=0; assfail=assfail/assfail; }
+
+#ifdef DEBUG_SCHEDULER
+#define PORT_LOCK(mutex) printf("Locking %llx by %llx at %d\n", (unsigned long long)&mutex, (unsigned long long)pthread_self(), __LINE__);PORT_ASSERT( 0 == pthread_mutex_lock(&(mutex)) ); printf("Locked %llx by %llx\n", (unsigned long long)&mutex, (unsigned long long)pthread_self());
+#define PORT_TRYLOCK(mutex) printf("Try Locking %llx by %llx\n", (unsigned long long)&mutex, (unsigned long long)pthread_self());pthread_mutex_trylock(&(mutex)); printf("Locked %llx by %llx\n", (unsigned long long)&mutex, (unsigned long long)pthread_self());
+#define PORT_UNLOCK(mutex) printf("Unlocking %llx by %llx at %d\n", (unsigned long long)&mutex, (unsigned long long)pthread_self(), __LINE__); PORT_ASSERT( 0 == pthread_mutex_unlock(&(mutex)) ); printf("Unlocked %llx by %llx\n", (unsigned long long)&mutex, (unsigned long long)pthread_self());
+#else
+#define PORT_LOCK(mutex) PORT_ASSERT( 0 == pthread_mutex_lock(&(mutex)) );
+#define PORT_TRYLOCK(mutex) pthread_mutex_trylock(&(mutex));
+#define PORT_UNLOCK(mutex) PORT_ASSERT( 0 == pthread_mutex_unlock(&(mutex)) );
+#endif
+
+/* Parameters to pass to the newly created pthread. */
+typedef struct XPARAMS
+{
+	pdTASK_CODE pxCode;
+	void *pvParams;
+} xParams;
+
+/* Each task maintains its own interrupt status in the critical nesting variable. */
+typedef struct THREAD_SUSPENSIONS
+{
+	pthread_t hThread;
+	xTaskHandle hTask;
+	unsigned portBASE_TYPE uxCriticalNesting;
+	pthread_mutex_t threadSleepMutex;
+	pthread_cond_t threadSleepCond;
+    volatile enum {THREAD_SLEEPING,THREAD_RUNNING,THREAD_STARTING,THREAD_YIELDING,THREAD_PREEMPTING,THREAD_WAKING} threadStatus;
+} xThreadState;
+/*-----------------------------------------------------------*/
+
+/* Needed to keep track of critical section depth before scheduler got started */
+static xThreadState xDummyThread = { .uxCriticalNesting=0, .threadStatus=THREAD_RUNNING };
+
+static xThreadState *pxThreads = NULL;
+static pthread_once_t hSigSetupThread = PTHREAD_ONCE_INIT;
+static pthread_attr_t xThreadAttributes;
+static pthread_mutex_t xRunningThreadMutex = PTHREAD_MUTEX_INITIALIZER;
+static pthread_mutex_t xYieldingThreadMutex = PTHREAD_MUTEX_INITIALIZER;
+static pthread_mutex_t xResumingThreadMutex = PTHREAD_MUTEX_INITIALIZER;
+static pthread_mutex_t xGuardMutex = PTHREAD_MUTEX_INITIALIZER;
+/*-----------------------------------------------------------*/
+
+static volatile portBASE_TYPE xSchedulerEnd = pdFALSE;
+static volatile portBASE_TYPE xSchedulerStarted = pdFALSE;
+static volatile portBASE_TYPE xInterruptsEnabled = pdFALSE;
+static volatile portBASE_TYPE xSchedulerNesting = 0;
+static volatile portBASE_TYPE xPendYield = pdFALSE;
+static volatile portLONG lIndexOfLastAddedTask = 0;
+/*-----------------------------------------------------------*/
+
+/*
+ * Setup the timer to generate the tick interrupts.
+ */
+static void *prvWaitForStart( void * pvParams );
+static void prvSuspendSignalHandler(int sig);
+static void prvSetupSignalsAndSchedulerPolicy( void );
+static void prvResumeThread( xThreadState* xThreadId );
+static xThreadState* prvGetThreadHandle( xTaskHandle hTask );
+static xThreadState* prvGetThreadHandleByThread( pthread_t hThread );
+static portLONG prvGetFreeThreadState( void );
+static void prvDeleteThread( void *xThreadId );
+static void prvPortYield( void );
+/*-----------------------------------------------------------*/
+
+/*
+ * Exception handlers.
+ */
+void vPortYield( void );
+void vPortSystemTickHandler( void );
+
+/*
+ * Start first task is a separate function so it can be tested in isolation.
+ */
+void vPortStartFirstTask( void );
+/*-----------------------------------------------------------*/
+
+/**
+ * inline macro functions
+ * (easierto debug than macros)
+ */
+static inline void PORT_ENTER( void ) {
+    
+    xThreadState *selfThreadState = prvGetThreadHandleByThread(pthread_self());
+	while( selfThreadState && selfThreadState->threadStatus!=THREAD_RUNNING) sched_yield();
+    
+    // Block SUSPEND from interrupting
+	sigset_t xSignalToBlock;
+	sigemptyset(&xSignalToBlock);
+	sigaddset(&xSignalToBlock,SIG_SUSPEND);
+	(void)pthread_sigmask(SIG_BLOCK, &xSignalToBlock, NULL);
+    
+    while (1)
+    {
+#ifdef DEBUG_SCHEDULER
+        printf("Locking xGuardMutex by %llx\n", (unsigned long long)pthread_self());
+#endif
+        if (pthread_mutex_trylock(&(xGuardMutex)) == 0)
+        {
+#ifdef DEBUG_SCHEDULER
+            printf("Locked xGuardMutex by %llx\n", (unsigned long long)pthread_self());
+#endif
+            break;
+        }
+        
+        // Allow it to interrupt again
+        (void)pthread_sigmask(SIG_UNBLOCK, &xSignalToBlock, NULL);
+        
+        // Yield
+        sched_yield();
+        
+        // Block SUSPEND from interrupting
+        (void)pthread_sigmask(SIG_BLOCK, &xSignalToBlock, NULL);
+    }
+    
+    // Allow it to interrupt again
+	(void)pthread_sigmask(SIG_UNBLOCK, &xSignalToBlock, NULL);
+    
+	PORT_ASSERT( xSchedulerStarted?( (selfThreadState==NULL) || (selfThreadState==prvGetThreadHandle(xTaskGetCurrentTaskHandle())) ):pdTRUE )
+}
+
+static inline void PORT_LEAVE( void ) {
+    xThreadState *selfThreadState = prvGetThreadHandleByThread(pthread_self());
+	PORT_ASSERT( xSchedulerStarted?( (selfThreadState==NULL) || (selfThreadState==prvGetThreadHandle(xTaskGetCurrentTaskHandle())) ):pdTRUE );
+	PORT_ASSERT( selfThreadState == NULL || selfThreadState->threadStatus==THREAD_RUNNING );
+	PORT_UNLOCK( xGuardMutex );
+}
+
+/*-----------------------------------------------------------*/
+
+/**
+ * Creates a new thread.
+ */
+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )
+{
+	/* Should actually keep this struct on the stack. */
+	xParams *pxThisThreadParams = pvPortMalloc( sizeof( xParams ) );
+	
+	/* Initialize scheduler during first call */
+	(void)pthread_once( &hSigSetupThread, prvSetupSignalsAndSchedulerPolicy );
+
+	/**
+	 * port enter needs to be delayed since pvPortMalloc() and
+	 * SetupSignalsAndSchedulerPolicy() both call critical section code
+	 */
+	PORT_ENTER();
+
+	/* No need to join the threads. */
+	pthread_attr_init( &xThreadAttributes );
+	pthread_attr_setdetachstate( &xThreadAttributes, PTHREAD_CREATE_DETACHED );
+
+	/* Add the task parameters. */
+	pxThisThreadParams->pxCode = pxCode;
+	pxThisThreadParams->pvParams = pvParameters;
+
+	lIndexOfLastAddedTask = prvGetFreeThreadState();
+	
+	PORT_LOCK( xYieldingThreadMutex );
+
+	pxThreads[ lIndexOfLastAddedTask ].threadStatus = THREAD_STARTING;
+	pxThreads[ lIndexOfLastAddedTask ].uxCriticalNesting = 0;
+
+#ifdef DEBUG_SCHEDULER
+    printf("Bleh Set threadStatus = %d for %llx\n", pxThreads[ lIndexOfLastAddedTask ].threadStatus, (unsigned long long)&pxThreads[ lIndexOfLastAddedTask ]);
+#endif
+    
+	/* create the thead */
+	PORT_ASSERT( 0 == pthread_create( &( pxThreads[ lIndexOfLastAddedTask ].hThread ), &xThreadAttributes, prvWaitForStart, (void *)pxThisThreadParams ) );
+
+	/* Let the task run a bit and wait until it suspends. */
+	while ( pxThreads[ lIndexOfLastAddedTask ].threadStatus == THREAD_STARTING ) sched_yield();
+
+	/* this ensures the sleeping thread reached deep sleep (and not more) */
+	PORT_UNLOCK( xYieldingThreadMutex );
+
+	PORT_LEAVE();
+
+	return pxTopOfStack;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * Initially the schedulers main thread holds the running thread mutex.
+ * it needs to be given up, to allow the first running task to execute
+ */
+void vPortStartFirstTask( void )
+{
+	/* Mark scheduler as started */
+	xSchedulerStarted = pdTRUE;
+
+	/* Start the first task. */
+	prvResumeThread( prvGetThreadHandle( xTaskGetCurrentTaskHandle() ) );
+
+	/* Give up running thread handle */
+	PORT_UNLOCK(xRunningThreadMutex);
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * After tasks have been set up the main thread goes into a sleeping loop, but
+ * allows to be interrupted by timer ticks.
+ */
+portBASE_TYPE xPortStartScheduler( void )
+{
+	sigset_t xSignalToBlock;
+
+#ifdef DEBUG_SCHEDULER
+    printf("xGuardMutex = %llx\n", (unsigned long long)&xGuardMutex);
+#endif
+    
+	/**
+	 * note: NO PORT_ENTER ! - this is the supervisor thread which runs outside
+	 * of the schedulers context
+	 */
+
+	/* do not respond to SUSPEND signal (but all others) */
+	sigemptyset( &xSignalToBlock );
+	(void)pthread_sigmask( SIG_SETMASK, &xSignalToBlock, NULL );
+	sigemptyset(&xSignalToBlock);
+	sigaddset(&xSignalToBlock,SIG_SUSPEND);
+	(void)pthread_sigmask(SIG_BLOCK, &xSignalToBlock, NULL);
+
+	/* Start the first task. This gives up the RunningThreadMutex*/
+	vPortStartFirstTask();
+
+	/**
+	 * Main scheduling loop. Call the tick handler every
+	 * portTICK_RATE_MICROSECONDS
+	 */
+	portTickType sleepTimeUS = portTICK_RATE_MICROSECONDS;
+    portTickType actualSleepTime;
+	struct timeval lastTime,currentTime;
+	gettimeofday( &lastTime, NULL );
+	struct timespec wait;
+	
+	while ( pdTRUE != xSchedulerEnd )
+	{
+		/* wait for the specified wait time */
+		wait.tv_sec = sleepTimeUS / 1000000;
+		wait.tv_nsec = 1000 * ( sleepTimeUS % 1000000 );
+		nanosleep( &wait, NULL );
+
+		/* check the time */
+		gettimeofday( &currentTime, NULL);
+		actualSleepTime = 1000000 * ( currentTime.tv_sec - lastTime.tv_sec ) + ( currentTime.tv_usec - lastTime.tv_usec );
+
+		/* only hit the tick if we slept at least half the period */
+		if ( actualSleepTime >= sleepTimeUS/2 ) {
+
+			vPortSystemTickHandler();
+
+			/* check the time again */
+			gettimeofday( &currentTime, NULL);
+			actualSleepTime = 1000000 * ( currentTime.tv_sec - lastTime.tv_sec ) + ( currentTime.tv_usec - lastTime.tv_usec );
+
+			/* sleep until the next tick is due */
+			sleepTimeUS += portTICK_RATE_MICROSECONDS;
+		}
+
+		/* reduce remaining sleep time by the slept time */
+		sleepTimeUS -= actualSleepTime;
+		lastTime = currentTime;
+
+		/* safety checks */
+		if (sleepTimeUS <=0 || sleepTimeUS >= 3 * portTICK_RATE_MICROSECONDS) sleepTimeUS = portTICK_RATE_MICROSECONDS;
+
+	}
+
+	PORT_PRINT( "Cleaning Up, Exiting.\n" );
+	/* Cleanup the mutexes */
+	pthread_mutex_destroy( &xRunningThreadMutex );
+	pthread_mutex_destroy( &xYieldingThreadMutex );
+	pthread_mutex_destroy( &xGuardMutex );
+	vPortFree( (void *)pxThreads );
+
+	/* Should not get here! */
+	return 0;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * quickly clean up all running threads, without asking them first
+ */
+void vPortEndScheduler( void )
+{
+portBASE_TYPE xNumberOfThreads;
+	for ( xNumberOfThreads = 0; xNumberOfThreads < MAX_NUMBER_OF_TASKS; xNumberOfThreads++ )
+	{
+		if ( ( pthread_t )NULL != pxThreads[ xNumberOfThreads ].hThread )
+		{
+			/* Kill all of the threads, they are in the detached state. */
+			pthread_cancel( pxThreads[ xNumberOfThreads ].hThread );
+		}
+	}
+
+	/* Signal the scheduler to exit its loop. */
+	xSchedulerEnd = pdTRUE;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * we must assume this one is called from outside the schedulers context
+ * (ISR's, signal handlers, or non-freertos threads)
+ * we cannot safely assume mutual exclusion
+ */
+void vPortYieldFromISR( void )
+{
+	xPendYield = pdTRUE;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * enter a critical section (public)
+ */
+void vPortEnterCritical( void )
+{
+	PORT_ENTER();
+	xInterruptsEnabled = pdFALSE;
+	prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting++;
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * leave a critical section (public)
+ */
+void vPortExitCritical( void )
+{
+	PORT_ENTER();
+
+	/* Check for unmatched exits. */
+	PORT_ASSERT( prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting > 0 );
+	if ( prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting > 0 )
+	{
+		prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting--;
+	}
+
+	/* If we have reached 0 then re-enable the interrupts. */
+	if( prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting == 0 )
+	{
+		/* Have we missed ticks? This is the equivalent of pending an interrupt. */
+		if ( pdTRUE == xPendYield )
+		{
+			xPendYield = pdFALSE;
+			prvPortYield();
+		}
+
+		xInterruptsEnabled = pdTRUE;
+
+	}
+
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * code to self-yield a task
+ * (without the mutex encapsulation)
+ * for internal use
+ */
+void prvPortYield( void )
+{
+	xThreadState *xTaskToSuspend, *xTaskToResume;
+
+	/* timer handler should NOT get in our way (just in case) */
+	xInterruptsEnabled = pdFALSE;
+
+	/* suspend the current task */
+	xTaskToSuspend = prvGetThreadHandleByThread( pthread_self() );
+
+	/**
+	 * make sure not to suspend threads that are already trying to do so
+	 */
+	PORT_ASSERT( xTaskToSuspend->threadStatus == THREAD_RUNNING );
+
+	/**
+	 * FreeRTOS switch context
+	 */
+	vTaskSwitchContext();
+
+	/**
+	 * find out which task to resume
+	 */
+	xTaskToResume = prvGetThreadHandle( xTaskGetCurrentTaskHandle() );
+	if ( xTaskToSuspend != xTaskToResume )
+	{
+		/* Resume the other thread first */
+		prvResumeThread( xTaskToResume );
+
+		/* prepare the current task for yielding */
+		xTaskToSuspend->threadStatus = THREAD_YIELDING;
+
+#ifdef DEBUG_SCHEDULER
+        printf("Suspending thread (yield) %llx\n", (unsigned long long)xTaskToSuspend->hThread);
+#endif
+		/**
+		 * Send signals until the signal handler acknowledges.  How long that takes
+		 * depends on the systems signal implementation.  During a preemption we
+		 * will see the actual THREAD_SLEEPING STATE - but when yielding we
+		 * would only see a future THREAD_RUNNING after having woken up - both is
+		 * OK
+		 */
+		while ( xTaskToSuspend->threadStatus == THREAD_YIELDING ) {
+			pthread_kill( xTaskToSuspend->hThread, SIG_SUSPEND );
+			sched_yield();
+		}
+
+		/**
+		 * mark: once we reach this point, the task has already slept and awaken anew
+		 */
+
+	} else {
+		/**
+		 * no context switch - keep running
+		 */
+		if (xTaskToResume->uxCriticalNesting==0) {
+			xInterruptsEnabled = pdTRUE;
+		}
+	}
+
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * public yield function - secure
+ */
+void vPortYield( void )
+{
+	PORT_ENTER();
+
+	prvPortYield();
+
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * public function to disable interrupts
+ */
+void vPortDisableInterrupts( void )
+{
+	PORT_ENTER();
+
+	xInterruptsEnabled = pdFALSE;
+
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * public function to enable interrupts
+ */
+void vPortEnableInterrupts( void )
+{
+	PORT_ENTER();
+
+	/**
+	 * It is bad practice to enable interrupts explicitly while in a critical section
+	 * most likely this is a bug - better prevent the userspace from being stupid
+	 */
+    xThreadState *selfThreadState = prvGetThreadHandleByThread(pthread_self());    
+    if (selfThreadState)
+        PORT_ASSERT( selfThreadState->uxCriticalNesting == 0 );
+
+	xInterruptsEnabled = pdTRUE;
+
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * set and clear interrupt masks are used by FreeRTOS to enter and leave critical sections
+ * with unknown nexting level - but we DO know the nesting level
+ */
+portBASE_TYPE xPortSetInterruptMask( void )
+{
+	portBASE_TYPE xReturn;
+    xThreadState *selfThreadState = prvGetThreadHandleByThread(pthread_self());
+
+	PORT_ENTER();
+
+	xReturn = xInterruptsEnabled;
+
+	xInterruptsEnabled = pdFALSE;
+	
+	if (selfThreadState)
+		selfThreadState->uxCriticalNesting++;
+
+	PORT_LEAVE();
+
+	return xReturn;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * sets the "interrupt mask back to a stored setting
+ */
+void vPortClearInterruptMask( portBASE_TYPE xMask )
+{
+	PORT_ENTER();
+
+	/**
+	 * we better make sure the calling code behaves
+	 * if it doesn't it might indicate something went seriously wrong
+	 */
+    xThreadState *selfThreadState = prvGetThreadHandleByThread(pthread_self());
+	PORT_ASSERT( xMask == pdTRUE || xMask == pdFALSE );
+	PORT_ASSERT(
+        ( selfThreadState == NULL )
+        ||
+		( selfThreadState->uxCriticalNesting == 1 && xMask==pdTRUE )
+		|| 
+		( selfThreadState->uxCriticalNesting > 1 && xMask==pdFALSE )
+	);
+
+	xInterruptsEnabled = xMask;
+
+    if (selfThreadState)
+    {
+        if (prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting>0) {
+            prvGetThreadHandleByThread(pthread_self())->uxCriticalNesting--;
+        }
+    }
+    
+	PORT_LEAVE();
+}
+
+/*-----------------------------------------------------------*/
+
+/**
+ * the tick handler is just an ordinary function, called by the supervisor thread periodically
+ */
+void vPortSystemTickHandler()
+{
+	/**
+	 * the problem with the tick handler is, that it runs outside of the schedulers domain - worse,
+	 * on a multi core machine there might be a task running *right now*
+	 * - we need to stop it in order to do anything. However we need to make sure we are able to first
+	 */
+	PORT_LOCK( xGuardMutex );
+
+	/* thread MUST be running */
+        if (prvGetThreadHandle(xTaskGetCurrentTaskHandle()) == NULL)
+        {
+            printf("NULL thread handle in systick!\n");
+            return;
+        }
+	if ( prvGetThreadHandle(xTaskGetCurrentTaskHandle())->threadStatus!=THREAD_RUNNING ) {
+		xPendYield = pdTRUE;
+		PORT_UNLOCK( xGuardMutex );
+		return;
+	}
+
+	/* interrupts MUST be enabled */
+	if ( xInterruptsEnabled != pdTRUE ) {
+		xPendYield = pdTRUE;
+		PORT_UNLOCK( xGuardMutex );
+		return;
+	}
+
+	/* this should always be true, but it can't harm to check */
+	PORT_ASSERT( prvGetThreadHandle(xTaskGetCurrentTaskHandle())->uxCriticalNesting==0 );
+
+	/* acquire switching mutex for synchronization */
+	PORT_LOCK(xYieldingThreadMutex);
+
+	xThreadState *xTaskToSuspend = prvGetThreadHandle( xTaskGetCurrentTaskHandle() );
+
+#ifdef DEBUG_SCHEDULER
+    printf("Suspending thread (tick) %llx\n", (unsigned long long)xTaskToSuspend->hThread);
+#endif
+    
+	/**
+	 * halt current task - this means NO task is running!
+	 * Send signals until the signal handler acknowledges.  how long that takes
+	 * depends on the systems signal implementation.  During a preemption we
+	 * will see the actual THREAD_SLEEPING STATE when yielding we would only
+	 * see a future THREAD_RUNNING after having woken up both is OK
+	 * note: we do NOT give up switchingThreadMutex!
+	 */
+	xTaskToSuspend->threadStatus = THREAD_PREEMPTING;
+	while ( xTaskToSuspend->threadStatus != THREAD_SLEEPING ) {
+		pthread_kill( xTaskToSuspend->hThread, SIG_SUSPEND );
+		sched_yield();
+	}
+
+	/**
+	 * synchronize and acquire the running thread mutex
+	 */
+	PORT_UNLOCK( xYieldingThreadMutex );
+	PORT_LOCK( xRunningThreadMutex );
+
+	/**
+	 * now the tick handler runs INSTEAD of the currently active thread
+	 * - even on a multicore system
+	 * failure to do so can lead to unexpected results during
+	 * vTaskIncrementTick()...
+	 */
+
+	/**
+	 * call tick handler
+	 */
+	vTaskIncrementTick();
+
+	
+#if ( configUSE_PREEMPTION == 1 )
+	/**
+	 * while we are here we can as well switch the running thread
+	 */
+	vTaskSwitchContext();
+
+	xTaskToSuspend = prvGetThreadHandle( xTaskGetCurrentTaskHandle() );
+#endif
+
+	/**
+	 * wake up the task (again)
+	 */
+	prvResumeThread( xTaskToSuspend );
+
+	/**
+	 * give control to the userspace task
+	 */
+	PORT_UNLOCK( xRunningThreadMutex );
+
+	/* finish up */
+	PORT_UNLOCK( xGuardMutex );    
+
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * thread kill implementation
+ */
+void vPortForciblyEndThread( void *pxTaskToDelete )
+{
+xTaskHandle hTaskToDelete = ( xTaskHandle )pxTaskToDelete;
+xThreadState* xTaskToDelete;
+xThreadState* xTaskToResume;
+
+	PORT_ENTER();
+
+	xTaskToDelete = prvGetThreadHandle( hTaskToDelete );
+	xTaskToResume = prvGetThreadHandle( xTaskGetCurrentTaskHandle() );
+
+	PORT_ASSERT(  xTaskToDelete );
+	PORT_ASSERT(  xTaskToResume );
+
+	if ( xTaskToResume == xTaskToDelete )
+	{
+		/* This is a suicidal thread, need to select a different task to run. */
+		vTaskSwitchContext();
+		xTaskToResume = prvGetThreadHandle( xTaskGetCurrentTaskHandle() );
+	}
+
+	if ( pthread_self() != xTaskToDelete->hThread )
+	{
+		/* Cancelling a thread that is not me. */
+
+		/* Send a signal to wake the task so that it definitely cancels. */
+		pthread_testcancel();
+		pthread_cancel( xTaskToDelete->hThread );
+
+	}
+	else
+	{
+		/* Resume the other thread. */
+		prvResumeThread( xTaskToResume );
+		/* Pthread Clean-up function will note the cancellation. */
+		/* Release the execution. */
+
+		PORT_UNLOCK( xRunningThreadMutex );
+
+		//PORT_LEAVE();
+		PORT_UNLOCK( xGuardMutex );
+		/* Commit suicide */
+		pthread_exit( (void *)1 );
+	}
+	PORT_LEAVE();
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * any new thread first acquires the runningThreadMutex, but then suspends
+ * immediately, giving control back to the thread starting the new one
+ */
+void *prvWaitForStart( void * pvParams )
+{
+	xParams * pxParams = ( xParams * )pvParams;
+	pdTASK_CODE pvCode = pxParams->pxCode;
+	void * pParams = pxParams->pvParams;
+	sigset_t xSignalToBlock;
+	xThreadState * myself = prvGetThreadHandleByThread( pthread_self() );
+
+	pthread_cleanup_push( prvDeleteThread, (void *)pthread_self() );
+
+	/* do respond to signals */
+	sigemptyset( &xSignalToBlock );
+	(void)pthread_sigmask( SIG_SETMASK, &xSignalToBlock, NULL );
+
+	/**
+	 * Suspend ourselves. It's important to do that first
+	 * because until we come back from this we run outside the schedulers scope
+	 * and can't call functions like vPortFree() safely
+	 */
+	while ( myself->threadStatus == THREAD_STARTING ) {
+		pthread_kill( myself->hThread, SIG_SUSPEND );
+		sched_yield();
+	}
+
+	/**
+	 * now we have returned from the dead - reborn as a real thread inside the
+	 * schedulers scope.
+	 */
+	vPortFree( pvParams );
+
+	/* run the actual payload */
+	pvCode( pParams );
+
+	pthread_cleanup_pop( 1 );
+	return (void *)NULL;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * The suspend signal handler is called when a thread gets a SIGSUSPEND
+ * signal, which is supposed to send it to sleep
+ */
+void prvSuspendSignalHandler(int sig)
+{
+
+    // quell "unused parameter" warning
+    (void) sig;
+
+	portBASE_TYPE hangover;
+
+	/* make sure who we are */
+	xThreadState* myself = prvGetThreadHandleByThread(pthread_self());
+	PORT_ASSERT( myself );
+        
+	/* make sure we are actually supposed to sleep */
+	if (myself->threadStatus != THREAD_YIELDING && myself->threadStatus != THREAD_STARTING && myself->threadStatus != THREAD_PREEMPTING ) {
+		/* Spurious signal has arrived, we are not really supposed to halt.
+		 * Not a real problem, we can safely ignore that. */
+		return;
+	}
+
+	/* we need that to wake up later (cond_wait needs a mutex locked) */
+	PORT_LOCK(myself->threadSleepMutex);
+
+	/* even waking up is a bit different depending on how we went to sleep */
+	hangover = myself->threadStatus;
+
+	myself->threadStatus = THREAD_SLEEPING;
+
+#ifdef DEBUG_SCHEDULER
+    printf("Set threadStatus = %d for %llx\n", myself->threadStatus, (unsigned long long)myself);
+#endif
+    
+	if ( hangover == THREAD_STARTING ) {
+		/**
+		 * Synchronization with spawning thread through YieldingMutex
+		 * This thread does NOT have the running thread mutex
+		 * because it never officially ran before.
+		 * It will get that mutex on wakeup though.
+		 */
+		PORT_LOCK(xYieldingThreadMutex);
+		PORT_UNLOCK(xYieldingThreadMutex);
+	} else if ( hangover == THREAD_YIELDING) {
+		/**
+		 * The caller is the same thread as the signal handler.
+		 * No synchronization possible or needed.
+		 * But we need to unlock the mutexes it holds, so
+		 * other threads can run.
+		 */
+		PORT_UNLOCK(xRunningThreadMutex );
+		PORT_UNLOCK(xGuardMutex );
+	} else if ( hangover == THREAD_PREEMPTING) {
+		/**
+		 * The caller is the tick handler.
+		 * Use YieldingMutex for synchronization
+		 * Give up RunningThreadMutex, so the tick handler
+		 * can take it and start another thread.
+		 */
+		PORT_LOCK(xYieldingThreadMutex);
+		PORT_UNLOCK(xRunningThreadMutex );
+		PORT_UNLOCK(xYieldingThreadMutex);
+	}
+
+#ifdef DEBUG_SCHEDULER
+    printf("Thread suspended %llx\n", (unsigned long long)myself->hThread);
+#endif
+    
+	/* deep sleep until wake condition is met*/
+	pthread_cond_wait( &myself->threadSleepCond, &myself->threadSleepMutex );
+
+#ifdef DEBUG_SCHEDULER
+    printf("Thread resumed %llx\n", (unsigned long long)myself->hThread);
+#endif
+    
+	/* waking */
+	myself->threadStatus = THREAD_WAKING;
+	
+	/* synchronize with waker - quick assertion if the right thread got the condition sent to*/
+	PORT_LOCK(xResumingThreadMutex);
+	PORT_ASSERT(prvGetThreadHandle( xTaskGetCurrentTaskHandle())==myself);
+	PORT_UNLOCK(xResumingThreadMutex);
+
+	/* we don't need that condition mutex anymore */
+	PORT_UNLOCK(myself->threadSleepMutex);
+
+#if ( INCLUDE_pcTaskGetTaskName == 1 )
+    // Set the name of the thread
+    xTaskHandle xTask = myself->hTask;
+    if (xTask)
+    {
+        signed char *taskName = pcTaskGetTaskName(xTask);
+#if defined(__APPLE__)
+        pthread_setname_np((const char *)taskName);
+#else
+        taskName = taskName;
+#endif
+    }
+#endif
+        
+	/* we ARE the running thread now (the one and only) */
+	PORT_LOCK(xRunningThreadMutex);
+
+	/**
+	 * and we have important stuff to do, nobody should interfere with
+	 * ( GuardMutex is usually set by PORT_ENTER() )
+	 * */
+	PORT_LOCK( xGuardMutex );
+	if ( myself->uxCriticalNesting == 0 )
+	{
+		xInterruptsEnabled = pdTRUE;
+	}
+	else
+	{
+		xInterruptsEnabled = pdFALSE;
+	}
+
+	myself->threadStatus = THREAD_RUNNING;
+
+	/**
+	 * if we jump back to user code, we are done with important stuff,
+	 * but if we had yielded we are still in protected code after returning.
+	 **/
+	if (hangover!=THREAD_YIELDING) {
+		PORT_UNLOCK( xGuardMutex );
+	}
+
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * Signal the condition.
+ * Unlike pthread_kill this actually is supposed to be reliable, so we need no
+ * checks on the outcome.
+ */
+void prvResumeThread( xThreadState* xThreadId )
+{
+	PORT_ASSERT( xThreadId );
+	PORT_LOCK( xResumingThreadMutex );
+
+	PORT_ASSERT(xThreadId->threadStatus == THREAD_SLEEPING);
+
+#ifdef DEBUG_SCHEDULER
+    printf("Resuming thread %llx\n", (unsigned long long)xThreadId->hThread);
+#endif
+    
+	/**
+	 * Unfortunately "is supposed to" does not hold on all Posix-ish systems
+	 * but sending the cond_signal again doesn't hurt anyone.
+	 */
+	while ( xThreadId->threadStatus != THREAD_WAKING ) {
+		pthread_cond_signal(& xThreadId->threadSleepCond);
+		sched_yield();
+	}
+	
+	PORT_UNLOCK( xResumingThreadMutex );
+
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * this is init code executed the first time a thread is created
+ */
+void prvSetupSignalsAndSchedulerPolicy( void )
+{
+/* The following code would allow for configuring the scheduling of this task as a Real-time task.
+ * The process would then need to be run with higher privileges for it to take affect.
+int iPolicy;
+int iResult;
+int iSchedulerPriority;
+	iResult = pthread_getschedparam( pthread_self(), &iPolicy, &iSchedulerPriority );
+	iResult = pthread_attr_setschedpolicy( &xThreadAttributes, SCHED_FIFO );
+	iPolicy = SCHED_FIFO;
+	iResult = pthread_setschedparam( pthread_self(), iPolicy, &iSchedulerPriority );		*/
+
+struct sigaction sigsuspendself;
+portLONG lIndex;
+
+	pxThreads = ( xThreadState *)pvPortMalloc( sizeof( xThreadState ) * MAX_NUMBER_OF_TASKS );
+	
+	const pthread_cond_t cinit = PTHREAD_COND_INITIALIZER;
+	const pthread_mutex_t minit = PTHREAD_MUTEX_INITIALIZER;
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		pxThreads[ lIndex ].hThread = ( pthread_t )NULL;
+		pxThreads[ lIndex ].hTask = ( xTaskHandle )NULL;
+		pxThreads[ lIndex ].uxCriticalNesting = 0;
+		pxThreads[ lIndex ].threadSleepMutex = minit;
+		pxThreads[ lIndex ].threadSleepCond = cinit;
+	}
+
+	sigsuspendself.sa_flags = 0;
+	sigsuspendself.sa_handler = prvSuspendSignalHandler;
+	sigfillset( &sigsuspendself.sa_mask );
+
+	if ( 0 != sigaction( SIG_SUSPEND, &sigsuspendself, NULL ) )
+	{
+		PORT_PRINT( "Problem installing SIG_SUSPEND_SELF\n" );
+	}
+	PORT_PRINT( "Running as PID: %d\n", getpid() );
+
+	/* When scheduler is set up main thread first claims the running thread mutex */
+	PORT_LOCK( xRunningThreadMutex );
+
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * get a thread handle based on a task handle
+ */
+xThreadState* prvGetThreadHandle( xTaskHandle hTask )
+{
+    portLONG lIndex;
+	if (!pxThreads)
+		return NULL;
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		if ( pxThreads[ lIndex ].hTask == hTask )
+		{
+			return &pxThreads[ lIndex ];
+			break;
+		}
+	}
+	return NULL;
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * get a thread handle based on a posix thread handle
+ */
+xThreadState* prvGetThreadHandleByThread( pthread_t hThread )
+{
+portLONG lIndex;
+	/**
+	 * if the scheduler is NOT yet started, we can give back a dummy thread handle
+	 * to allow keeping track of interrupt nesting.
+	 * However once the scheduler is started we return a NULL,
+	 * so any misbehaving code can nicely segfault.
+	 */
+	if (!xSchedulerStarted && !pxThreads) return &xDummyThread;
+	if (!pxThreads) return NULL;
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		if ( pxThreads[ lIndex ].hThread == hThread )
+		{
+			return &pxThreads[ lIndex ];
+		}
+	}
+	if (!xSchedulerStarted) return &xDummyThread;
+	return NULL;
+}
+/*-----------------------------------------------------------*/
+
+/* next free task handle */
+portLONG prvGetFreeThreadState( void )
+{
+portLONG lIndex;
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		if ( pxThreads[ lIndex ].hThread == ( pthread_t )NULL )
+		{
+			break;
+		}
+	}
+
+	if ( MAX_NUMBER_OF_TASKS == lIndex )
+	{
+		PORT_PRINT( "No more free threads, please increase the maximum.\n" );
+		lIndex = 0;
+		vPortEndScheduler();
+	}
+
+	return lIndex;
+}
+
+/*-----------------------------------------------------------*/
+
+/**
+ * delete a thread from the list
+ */
+void prvDeleteThread( void *xThreadId )
+{
+portLONG lIndex;
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		if ( pxThreads[ lIndex ].hThread == ( pthread_t )xThreadId )
+		{
+#ifdef DEBUG_SCHEDULER
+            printf("Deleting thread %llx\n", (unsigned long long)xThreadId);
+#endif
+			pxThreads[ lIndex ].hThread = (pthread_t)NULL;
+			pxThreads[ lIndex ].hTask = (xTaskHandle)NULL;
+			if ( pxThreads[ lIndex ].uxCriticalNesting > 0 )
+			{
+				//vPortEnableInterrupts();
+				xInterruptsEnabled = pdTRUE;
+			}
+			pxThreads[ lIndex ].uxCriticalNesting = 0;
+            PORT_UNLOCK( pxThreads[ lIndex].threadSleepMutex );
+			break;
+		}
+	}
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * add a thread to the list
+ */
+void vPortAddTaskHandle( void *pxTaskHandle )
+{
+portLONG lIndex;
+
+	pxThreads[ lIndexOfLastAddedTask ].hTask = ( xTaskHandle )pxTaskHandle;
+        
+	for ( lIndex = 0; lIndex < MAX_NUMBER_OF_TASKS; lIndex++ )
+	{
+		if ( pxThreads[ lIndex ].hThread == pxThreads[ lIndexOfLastAddedTask ].hThread )
+		{
+			if ( pxThreads[ lIndex ].hTask != pxThreads[ lIndexOfLastAddedTask ].hTask )
+			{
+#ifdef DEBUG_SCHEDULER
+                printf("Deleting thread weirdly %llx\n", (unsigned long long)pxThreads[ lIndex ].hThread);
+#endif
+				pxThreads[ lIndex ].hThread = ( pthread_t )NULL;
+				pxThreads[ lIndex ].hTask = NULL;
+				pxThreads[ lIndex ].uxCriticalNesting = 0;
+                PORT_UNLOCK( pxThreads[ lIndex].threadSleepMutex );
+			}
+		}
+	}
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * find out system speed
+ */
+void vPortFindTicksPerSecond( void )
+{
+	/* Needs to be reasonably high for accuracy. */
+	unsigned long ulTicksPerSecond = sysconf(_SC_CLK_TCK);
+	PORT_PRINT( "Timer Resolution for Run TimeStats is %ld ticks per second.\n", ulTicksPerSecond );
+}
+/*-----------------------------------------------------------*/
+
+/**
+ * timer stuff
+ */
+unsigned long ulPortGetTimerValue( void )
+{
+struct tms xTimes;
+	unsigned long ulTotalTime = times( &xTimes );
+	/* Return the application code times.
+	 * The timer only increases when the application code is actually running
+	 * which means that the total execution times should add up to 100%.
+	 */
+	return ( unsigned long ) xTimes.tms_utime;
+
+	/* Should check ulTotalTime for being clock_t max minus 1. */
+	(void)ulTotalTime;
+}
+/*-----------------------------------------------------------*/
+
diff --git a/FreeRTOS/Source/portable/GCC/Posix/port.c.documentation.txt b/FreeRTOS/Source/portable/GCC/Posix/port.c.documentation.txt
new file mode 100644
index 0000000..022ab59
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/Posix/port.c.documentation.txt
@@ -0,0 +1,188 @@
+File: port.c.documentation.txt
+Author: Corvus Corax
+Desc: Description of port.c Functions and Directions about porting.
+See FreeRTOS documentation ebook for details.
+
+
+FreeRTOS is an architecture independent real time operating system.
+Most architecture dependant code sits in a single file: port.c
+Architecture dependant definitions sit in: portmacro.h
+
+Other important files:
+
+Source/portable/MemMang/head_3.c - memory management - very simple. Provides
+functions like malloc and free - very easy to make a wrapper for on any system
+that provides memory management.
+
+FreeRTOS has internal scheduling. The real time scheduler sits in Source/task.c and calls low level functions of port.c for thread management.
+
+For that port.c needs to provide functions to switch between threads on
+request, as well as a tick handler that preempts threads on a periodic basis.
+
+Only one FreeRTOS thread is active at any time!
+
+
+port.c provides the API defined in portmacro.h.
+
+Only a subset of the functions is explained here (with the naming from the
+posix port. Their macros are sometimes named a bit different)
+
+
+void vPortEnterCritical(void);
+
+This function is called if a thread enters a "critical section".
+In a critical sections the thread must not be preempted.
+
+(To preempt a thread means to halt its execution when a timer interrupt comes
+in, and give execution to another thread)
+This function should increase a counter for that thread, since several
+"Critical Sections" could be cascaded. Only if the outermost critical section
+is exited, is preemtion allowed again.
+
+void vPortExitCritical(void);
+This function is called if a thread leaves a "critical section".
+If a thread leaves the outermost critical section, the scheduler is allowed to
+preempt it on timer interrupt (or other interrupts)
+
+
+void vPortEnableInterrupts(void);
+void vPortDisableInterrupts(void);
+
+functions to enable and disable interrupts. On "real systems" this means all
+interrupts including IO. When "simulating" this means the tick handler/ timer
+/ timer interrupt. The tick handler is supposed to not do anything if interrupts are disabled.
+
+
+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack,
+pdTASK_CODE pxCode, void *pvParameters );
+
+Used to initialize a new thread. The stack memory area, command line
+parameters for this task and the entry function (pxCode) are given
+
+This function needs to initialize the new task/thread, but suspend it
+immediately. It is only to be executed later if the scheduler says so.
+
+returns pxTopOfStack if success and 0 on failure.
+
+THIS WILL BE THE FIRST FUNCTION FreeRTOS CALLS.
+The first thread to be created is likely the idle thread. At this time the
+scheduler has not been started yet. Therefore it's important to start all
+threads in suspended state!
+
+void vPortEndScheduler(void);
+
+Needs to end the scheduler (and as such all Tasks/threads) This means FreeRTOS
+terminates - as in (simulated) system shutdown.
+
+
+portBASE_TYPE xPortStartScheduler(void);
+
+This function doesn't return until someone (another thread) calls
+vPortEndScheduler(). You can set up your timer and tick handler here and start
+the first thread. Then do what a scheduler does (manage threads)
+
+
+vPortYield()
+
+Sometimes threads go sleeping on purpose (for example during one of FreeRTOS
+system calls - including sleep() )
+This function should send the thread that calls it into suspended state and
+not return until the scheduler gives back execution to this thread.
+
+
+===========
+The scheduler.
+
+What your scheduler needs to do:
+
+Basically what your self written scheduler is allowed to do is the "dirty
+work" for the high level scheduler logic provided by FreeRTOS task.c
+
+The scheduler is supposed to run a timer interrupt/tick handler that gets
+called every portTICK_RATE_MICROSECONDS microseconds.
+That value is defined somewhere in OpenPilot and has to be exact as well as
+the same on all architectures.
+
+If you cannot set up a timer with that accuracy you are screwed!
+
+Anyway. Every time the timer tick happens, you have to
+
+- check whether you are allowed to execute the tick handler.
+  If interrupts are disabled and/or the thread is in a critical section, the
+  tick handler should do nothing
+
+- Tell FreeRTOS that the tick has happened
+  Increment the Tick Count using the FreeRTOS function
+  vTaskIncrementTick();
+
+- If preemption is enabled (and in OpenPilot it is!)
+  Tell the high level Scheduler of FreeRTOS to do its magic, using the
+  function
+  vTaskSwitchContext();
+
+- You can find out which thread is SUPPOSED to be running with the function
+  xTaskGetCurrentTaskHandle();
+
+- If this is for some reason not the currently running thread, SUSPEND that
+  thread with whatever method possible (signals, events, operating system
+  thread.suspend() - I don't know how to do that in Qt.
+
+- Make the thread returned by xTaskGetCurrentTaskHandle() resume operation as
+  normal.
+
+- Make sure that when you return from the tick handler, exactly one thread is
+  running and that is the one by xTaskGetCurrentTaskHandle() and all others
+  are suspended!
+
+
+
+On top of that, threads can suspend themselves just like that. That happens
+every time they call any blocking FreeRTOS function.
+
+They do that with above mentioned function
+
+vPortYield()
+
+When vPortYield is called your scheduler must:
+
+- Tell the high level Scheduler of FreeRTOS to do its magic, using the
+  function
+  vTaskSwitchContext();
+
+- You can then find out which thread is SUPPOSED to be running with the function
+  xTaskGetCurrentTaskHandle();
+
+- Make sure that the thread calling this function SUSPENDS and the thread
+  returned by xTaskGetCurrentTaskHandle() gets executed. Be aware that they
+  could be the same in which case vPortYield does exactly NOTHING!
+
+- This function does not return (since the current thread is sent to sleep)
+  until the scheduler makes it wake up - either by the tick handler, or by
+  another thread calling vPortYield().
+
+- So it must not ever return until xTaskGetCurrentTaskHandle() says the
+  calling thread is the current task handle.
+
+- Then it returns to the caller.
+ 
+
+
+=====
+
+What emthod you use to send threads/tasks to sleep and wake them up again is
+up to you.
+
+The posix implementation uses signals and a signal handler in each thread that
+sleeps until a resume signal is received
+
+The native STM32 implementation manually switches contexts by and uses actual
+system interrupts
+(so does the native x86 implementation)
+
+The native Win32 implementation uses win32 API calls to manipulate windows
+threads (windows actually provides a call to remote-suspend and resume a
+thread - posix doesn't)
+
+I have no clue what measures for thread control and suspension/interruption Qt
+offers. (I hope there are some)
+
diff --git a/FreeRTOS/Source/portable/GCC/Posix/port.c.nestnotes.txt b/FreeRTOS/Source/portable/GCC/Posix/port.c.nestnotes.txt
new file mode 100644
index 0000000..9cefb48
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/Posix/port.c.nestnotes.txt
@@ -0,0 +1,11 @@
+Notes from Nest
+
+Debugging and signals
+=====================
+The POSIX port uses SIGUSR1 to signal a thread to sleep.  Be sure to turn off debug breaks on these signals by issuing the following:
+
+If using GDB
+handle SIGUSR1 nostop noignore noprint 
+
+If using LLDB
+process handle SIGUSR1 -n true -p true -s false
diff --git a/FreeRTOS/Source/portable/GCC/Posix/portmacro.h b/FreeRTOS/Source/portable/GCC/Posix/portmacro.h
new file mode 100644
index 0000000..775c2ba
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/Posix/portmacro.h
@@ -0,0 +1,159 @@
+/*

+	FreeRTOS.org V5.2.0 - Copyright (C) 2003-2009 Richard Barry.

+

+	This file is part of the FreeRTOS.org distribution.

+

+	FreeRTOS.org is free software; you can redistribute it and/or modify it

+	under the terms of the GNU General Public License (version 2) as published

+	by the Free Software Foundation and modified by the FreeRTOS exception.

+

+	FreeRTOS.org is distributed in the hope that it will be useful,	but WITHOUT

+	ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or

+	FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+	more details.

+

+	You should have received a copy of the GNU General Public License along

+	with FreeRTOS.org; if not, write to the Free Software Foundation, Inc., 59

+	Temple Place, Suite 330, Boston, MA  02111-1307  USA.

+

+	A special exception to the GPL is included to allow you to distribute a

+	combined work that includes FreeRTOS.org without being obliged to provide

+	the source code for any proprietary components.  See the licensing section

+	of http://www.FreeRTOS.org for full details.

+

+

+	***************************************************************************

+	*                                                                         *

+	* Get the FreeRTOS eBook!  See http://www.FreeRTOS.org/Documentation      *

+	*                                                                         *

+	* This is a concise, step by step, 'hands on' guide that describes both   *

+	* general multitasking concepts and FreeRTOS specifics. It presents and   *

+	* explains numerous examples that are written using the FreeRTOS API.     *

+	* Full source code for all the examples is provided in an accompanying    *

+	* .zip file.                                                              *

+	*                                                                         *

+	***************************************************************************

+

+	1 tab == 4 spaces!

+

+	Please ensure to read the configuration and relevant port sections of the

+	online documentation.

+

+	http://www.FreeRTOS.org - Documentation, latest information, license and

+	contact details.

+

+	http://www.SafeRTOS.com - A version that is certified for use in safety

+	critical systems.

+

+	http://www.OpenRTOS.com - Commercial support, development, porting,

+	licensing and training services.

+*/

+

+

+#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		int

+#define portSHORT		short

+#define portSTACK_TYPE  unsigned long

+#define portBASE_TYPE   long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH				( -1 )

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portTICK_RATE_MICROSECONDS		( ( portTickType ) 1000000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT				4

+#define portREMOVE_STATIC_QUALIFIER

+/*-----------------------------------------------------------*/

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+extern void vPortYield( void );

+

+#define portYIELD()					vPortYield()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+extern void vPortDisableInterrupts( void );

+extern void vPortEnableInterrupts( void );

+#define portSET_INTERRUPT_MASK()	( vPortDisableInterrupts() )

+#define portCLEAR_INTERRUPT_MASK()	( vPortEnableInterrupts() )

+

+extern portBASE_TYPE xPortSetInterruptMask( void );

+extern void vPortClearInterruptMask( portBASE_TYPE xMask );

+

+#define portSET_INTERRUPT_MASK_FROM_ISR()		xPortSetInterruptMask()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	vPortClearInterruptMask(x)

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#define portOUTPUT_BYTE( a, b )

+

+extern void vPortForciblyEndThread( void *pxTaskToDelete );

+#define traceTASK_DELETE( pxTaskToDelete )		vPortForciblyEndThread( pxTaskToDelete )

+

+extern void vPortAddTaskHandle( void *pxTaskHandle );

+#define traceTASK_CREATE( pxNewTCB )			vPortAddTaskHandle( pxNewTCB )

+

+/* Posix Signal definitions that can be changed or read as appropriate. */

+#define SIG_SUSPEND					SIGUSR1

+

+/* Make use of times(man 2) to gather run-time statistics on the tasks. */

+extern void vPortFindTicksPerSecond( void );

+#undef portCONFIGURE_TIMER_FOR_RUN_TIME_STATS

+#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS()	vPortFindTicksPerSecond()		/* Nothing to do because the timer is already present. */

+extern unsigned long ulPortGetTimerValue( void );

+#undef portGET_RUN_TIME_COUNTER_VALUE

+#define portGET_RUN_TIME_COUNTER_VALUE()			ulPortGetTimerValue()			/* Query the System time stats for this process. */

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/RX600/port.c b/FreeRTOS/Source/portable/GCC/RX600/port.c
new file mode 100644
index 0000000..c91b328
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/RX600/port.c
@@ -0,0 +1,397 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the SH2A port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "string.h"

+

+/* Hardware specifics. */

+#include "iodefine.h"

+

+/*-----------------------------------------------------------*/

+

+/* Tasks should start with interrupts enabled and in Supervisor mode, therefore 

+PSW is set with U and I set, and PM and IPL clear. */

+#define portINITIAL_PSW     ( ( portSTACK_TYPE ) 0x00030000 )

+#define portINITIAL_FPSW    ( ( portSTACK_TYPE ) 0x00000100 )

+

+/* These macros allow a critical section to be added around the call to

+vTaskIncrementTick(), which is only ever called from interrupts at the kernel 

+priority - ie a known priority.  Therefore these local macros are a slight 

+optimisation compared to calling the global SET/CLEAR_INTERRUPT_MASK macros, 

+which would require the old IPL to be read first and stored in a local variable. */

+#define portDISABLE_INTERRUPTS_FROM_KERNEL_ISR() 	__asm volatile ( "MVTIPL	%0" ::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY) )

+#define portENABLE_INTERRUPTS_FROM_KERNEL_ISR() 	__asm volatile ( "MVTIPL	%0" ::"i"(configKERNEL_INTERRUPT_PRIORITY) )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Function to start the first task executing - written in asm code as direct

+ * access to registers is required. 

+ */

+static void prvStartFirstTask( void ) __attribute__((naked));

+

+/*

+ * Software interrupt handler.  Performs the actual context switch (saving and

+ * restoring of registers).  Written in asm code as direct register access is

+ * required.

+ */

+void vSoftwareInterruptISR( void ) __attribute__((naked));

+

+/*

+ * The tick interrupt handler.

+ */

+void vTickISR( void ) __attribute__((interrupt));

+

+/*-----------------------------------------------------------*/

+

+extern void *pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* R0 is not included as it is the stack pointer. */

+	

+	*pxTopOfStack = 0x00;

+	pxTopOfStack--;

+ 	*pxTopOfStack = portINITIAL_PSW;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	

+	/* When debugging it can be useful if every register is set to a known

+	value.  Otherwise code space can be saved by just setting the registers

+	that need to be set. */

+	#ifdef USE_FULL_REGISTER_INITIALISATION

+	{

+		pxTopOfStack--;

+		*pxTopOfStack = 0xffffffff;	/* r15. */

+		pxTopOfStack--;

+		*pxTopOfStack = 0xeeeeeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xdddddddd;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xcccccccc;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xbbbbbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xaaaaaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x99999999;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x88888888;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x77777777;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x66666666;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x55555555;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x44444444;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x33333333;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x22222222;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		pxTopOfStack -= 15;

+	}

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R1 */

+	pxTopOfStack--;				

+	*pxTopOfStack = portINITIAL_FPSW;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x12345678; /* Accumulator. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x87654321; /* Accumulator. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vApplicationSetupTimerInterrupt( void );

+

+	/* Use pxCurrentTCB just so it does not get optimised away. */

+	if( pxCurrentTCB != NULL )

+	{

+		/* Call an application function to set up the timer that will generate the

+		tick interrupt.  This way the application can decide which peripheral to 

+		use.  A demo application is provided to show a suitable example. */

+		vApplicationSetupTimerInterrupt();

+

+		/* Enable the software interrupt. */		

+		_IEN( _ICU_SWINT ) = 1;

+		

+		/* Ensure the software interrupt is clear. */

+		_IR( _ICU_SWINT ) = 0;

+		

+		/* Ensure the software interrupt is set to the kernel priority. */

+		_IPR( _ICU_SWINT ) = configKERNEL_INTERRUPT_PRIORITY;

+

+		/* Start the first task. */

+		prvStartFirstTask();

+	}

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvStartFirstTask( void )

+{

+	__asm volatile

+	(	

+		/* When starting the scheduler there is nothing that needs moving to the

+		interrupt stack because the function is not called from an interrupt.

+		Just ensure the current stack is the user stack. */

+		"SETPSW		U						\n" \

+

+		/* Obtain the location of the stack associated with which ever task 

+		pxCurrentTCB is currently pointing to. */

+		"MOV.L		#_pxCurrentTCB, R15		\n" \

+		"MOV.L		[R15], R15				\n" \

+		"MOV.L		[R15], R0				\n" \

+

+		/* Restore the registers from the stack of the task pointed to by 

+		pxCurrentTCB. */

+	    "POP		R15						\n" \

+		

+		/* Accumulator low 32 bits. */

+	    "MVTACLO	R15 					\n" \

+	    "POP		R15						\n" \

+		

+		/* Accumulator high 32 bits. */

+	    "MVTACHI	R15 					\n" \

+	    "POP		R15						\n" \

+		

+		/* Floating point status word. */

+	    "MVTC		R15, FPSW 				\n" \

+		

+		/* R1 to R15 - R0 is not included as it is the SP. */

+	    "POPM		R1-R15 					\n" \

+		

+		/* This pops the remaining registers. */

+	    "RTE								\n" \

+	    "NOP								\n" \

+	    "NOP								\n"

+	);

+}

+/*-----------------------------------------------------------*/

+

+void vSoftwareInterruptISR( void )

+{

+	__asm volatile

+	(

+		/* Re-enable interrupts. */

+		"SETPSW		I							\n" \

+

+		/* Move the data that was automatically pushed onto the interrupt stack when

+		the interrupt occurred from the interrupt stack to the user stack.  

+	

+		R15 is saved before it is clobbered. */

+		"PUSH.L		R15							\n" \

+	

+		/* Read the user stack pointer. */

+		"MVFC		USP, R15					\n" \

+	

+		/* Move the address down to the data being moved. */

+		"SUB		#12, R15					\n" \

+		"MVTC		R15, USP					\n" \

+	

+		/* Copy the data across, R15, then PC, then PSW. */

+		"MOV.L		[ R0 ], [ R15 ]				\n" \

+		"MOV.L 		4[ R0 ], 4[ R15 ]			\n" \

+		"MOV.L		8[ R0 ], 8[ R15 ]			\n" \

+

+		/* Move the interrupt stack pointer to its new correct position. */

+		"ADD		#12, R0						\n" \

+	

+		/* All the rest of the registers are saved directly to the user stack. */

+		"SETPSW		U							\n" \

+

+		/* Save the rest of the general registers (R15 has been saved already). */

+		"PUSHM		R1-R14						\n" \

+	

+		/* Save the FPSW and accumulator. */

+		"MVFC		FPSW, R15					\n" \

+		"PUSH.L		R15							\n" \

+		"MVFACHI 	R15							\n" \

+		"PUSH.L		R15							\n" \

+		

+		/* Middle word. */

+		"MVFACMI	R15							\n" \

+		

+		/* Shifted left as it is restored to the low order word. */

+		"SHLL		#16, R15					\n" \

+		"PUSH.L		R15							\n" \

+

+		/* Save the stack pointer to the TCB. */

+		"MOV.L		#_pxCurrentTCB, R15			\n" \

+		"MOV.L		[ R15 ], R15				\n" \

+		"MOV.L		R0, [ R15 ]					\n" \

+			

+		/* Ensure the interrupt mask is set to the syscall priority while the kernel

+		structures are being accessed. */

+		"MVTIPL		%0 							\n" \

+

+		/* Select the next task to run. */

+		"BSR.A		_vTaskSwitchContext			\n" \

+

+		/* Reset the interrupt mask as no more data structure access is required. */

+		"MVTIPL		%1							\n" \

+

+		/* Load the stack pointer of the task that is now selected as the Running

+		state task from its TCB. */

+		"MOV.L		#_pxCurrentTCB,R15			\n" \

+		"MOV.L		[ R15 ], R15				\n" \

+		"MOV.L		[ R15 ], R0					\n" \

+

+		/* Restore the context of the new task.  The PSW (Program Status Word) and

+		PC will be popped by the RTE instruction. */

+		"POP		R15							\n" \

+		"MVTACLO 	R15							\n" \

+		"POP		R15							\n" \

+		"MVTACHI 	R15							\n" \

+		"POP		R15							\n" \

+		"MVTC		R15, FPSW					\n" \

+		"POPM		R1-R15						\n" \

+		"RTE									\n" \

+		"NOP									\n" \

+		"NOP									  "

+		:: "i"(configMAX_SYSCALL_INTERRUPT_PRIORITY), "i"(configKERNEL_INTERRUPT_PRIORITY)

+	);

+}

+/*-----------------------------------------------------------*/

+

+void vTickISR( void )

+{

+	/* Re-enabled interrupts. */

+	__asm volatile( "SETPSW	I" );

+	

+	/* Increment the tick, and perform any processing the new tick value

+	necessitates.  Ensure IPL is at the max syscall value first. */

+	portDISABLE_INTERRUPTS_FROM_KERNEL_ISR();

+	{

+		vTaskIncrementTick(); 

+	}

+	portENABLE_INTERRUPTS_FROM_KERNEL_ISR();

+	

+	/* Only select a new task if the preemptive scheduler is being used. */

+	#if( configUSE_PREEMPTION == 1 )

+		taskYIELD();

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+unsigned long ulPortGetIPL( void )

+{

+	__asm volatile

+	( 

+		"MVFC	PSW, R1			\n"	\

+		"SHLR	#24, R1			\n"	\

+		"RTS					  "

+	);

+	

+	/* This will never get executed, but keeps the compiler from complaining. */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortSetIPL( unsigned long ulNewIPL )

+{

+	__asm volatile

+	( 

+		"PUSH	R5				\n" \

+		"MVFC	PSW, R5			\n"	\

+		"SHLL	#24, R1			\n" \

+		"AND	#-0F000001H, R5 \n" \

+		"OR		R1, R5			\n" \

+		"MVTC	R5, PSW			\n" \

+		"POP	R5				\n" \

+		"RTS					  "

+	 );

+}

diff --git a/FreeRTOS/Source/portable/GCC/RX600/portmacro.h b/FreeRTOS/Source/portable/GCC/RX600/portmacro.h
new file mode 100644
index 0000000..8f8a657
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/RX600/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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 - these are a bit legacy and not really used now, other than

+portSTACK_TYPE and portBASE_TYPE. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			8	/* Could make four, according to manual. */

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()					__asm volatile( "NOP" )

+

+/* The location of the software interrupt register.  Software interrupts use

+vector 27. */

+#define portITU_SWINTR			( ( unsigned char * ) 0x000872E0 )

+#define portYIELD()				*portITU_SWINTR = 0x01; portNOP(); portNOP(); portNOP(); portNOP(); portNOP()

+#define portYIELD_FROM_ISR( x )	if( x != pdFALSE ) portYIELD()

+

+/*

+ * These macros should be called directly, but through the taskENTER_CRITICAL()

+ * and taskEXIT_CRITICAL() macros.

+ */

+#define portENABLE_INTERRUPTS() 	__asm volatile ( "MVTIPL	#0" );

+#define portDISABLE_INTERRUPTS() 	__asm volatile ( "MVTIPL	%0" ::"i"(configMAX_SYSCALL_INTERRUPT_PRIORITY) )

+

+/* Critical nesting counts are stored in the TCB. */

+#define portCRITICAL_NESTING_IN_TCB ( 1 )

+

+/* The critical nesting functions defined within tasks.c. */

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()	vTaskEnterCritical();

+#define portEXIT_CRITICAL()		vTaskExitCritical();

+

+/* As this port allows interrupt nesting... */

+unsigned long ulPortGetIPL( void ) __attribute__((naked));

+void vPortSetIPL( unsigned long ulNewIPL ) __attribute__((naked));

+#define portSET_INTERRUPT_MASK_FROM_ISR() ulPortGetIPL(); portDISABLE_INTERRUPTS()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus ) vPortSetIPL( uxSavedInterruptStatus )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/GCC/STR75x/port.c b/FreeRTOS/Source/portable/GCC/STR75x/port.c
new file mode 100644
index 0000000..d0d3d54
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/STR75x/port.c
@@ -0,0 +1,236 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ST STR75x ARM7

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include "75x_tb.h"

+#include "75x_eic.h"

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+/* Prescale used on the timer clock when calculating the tick period. */

+#define portPRESCALE 20

+

+

+/*-----------------------------------------------------------*/

+

+/* Setup the TB to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	#ifdef THUMB_INTERWORK

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+	#endif

+

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortISRStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortISRStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+EIC_IRQInitTypeDef  EIC_IRQInitStructure;	

+TB_InitTypeDef      TB_InitStructure;

+

+	/* Setup the EIC for the TB. */

+	EIC_IRQInitStructure.EIC_IRQChannelCmd = ENABLE;

+	EIC_IRQInitStructure.EIC_IRQChannel = TB_IRQChannel;

+	EIC_IRQInitStructure.EIC_IRQChannelPriority = 1;

+	EIC_IRQInit(&EIC_IRQInitStructure);

+	

+	/* Setup the TB for the generation of the tick interrupt. */

+	TB_InitStructure.TB_Mode = TB_Mode_Timing;

+	TB_InitStructure.TB_CounterMode = TB_CounterMode_Down;

+	TB_InitStructure.TB_Prescaler = portPRESCALE - 1;

+	TB_InitStructure.TB_AutoReload = ( ( configCPU_CLOCK_HZ / portPRESCALE ) / configTICK_RATE_HZ );

+	TB_Init(&TB_InitStructure);

+	

+	/* Enable TB Update interrupt */

+	TB_ITConfig(TB_IT_Update, ENABLE);

+

+	/* Clear TB Update interrupt pending bit */

+	TB_ClearITPendingBit(TB_IT_Update);

+

+	/* Enable TB */

+	TB_Cmd(ENABLE);

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/STR75x/portISR.c b/FreeRTOS/Source/portable/GCC/STR75x/portISR.c
new file mode 100644
index 0000000..f8cbd5a
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/STR75x/portISR.c
@@ -0,0 +1,222 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Components that can be compiled to either ARM or THUMB mode are

+ * contained in port.c  The ISR routines, which can only be compiled

+ * to ARM mode, are contained in this file.

+ *----------------------------------------------------------*/

+

+/*

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING		( ( unsigned long ) 0 )

+

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * The scheduler can only be started from ARM mode, hence the inclusion of this

+ * function here.

+ */

+void vPortISRStartFirstTask( void );

+/*-----------------------------------------------------------*/

+

+void vPortISRStartFirstTask( void )

+{

+	/* Simply start the scheduler.  This is included here as it can only be

+	called from ARM mode. */

+	asm volatile (														\

+	"LDR		R0, =pxCurrentTCB								\n\t"	\

+	"LDR		R0, [R0]										\n\t"	\

+	"LDR		LR, [R0]										\n\t"	\

+																		\

+	/* The critical nesting depth is the first item on the stack. */	\

+	/* Load it into the ulCriticalNesting variable. */					\

+	"LDR		R0, =ulCriticalNesting							\n\t"	\

+	"LDMFD	LR!, {R1}											\n\t"	\

+	"STR		R1, [R0]										\n\t"	\

+																		\

+	/* Get the SPSR from the stack. */									\

+	"LDMFD	LR!, {R0}											\n\t"	\

+	"MSR		SPSR, R0										\n\t"	\

+																		\

+	/* Restore all system mode registers for the task. */				\

+	"LDMFD	LR, {R0-R14}^										\n\t"	\

+	"NOP														\n\t"	\

+																		\

+	/* Restore the return address. */									\

+	"LDR		LR, [LR, #+60]									\n\t"	\

+																		\

+	/* And return - correcting the offset in the LR to obtain the */	\

+	/* correct address. */												\

+	"SUBS PC, LR, #4											\n\t"	\

+	);																	

+}

+/*-----------------------------------------------------------*/

+

+void vPortTickISR( void )

+{

+	/* Increment the RTOS tick count, then look for the highest priority 

+	task that is ready to run. */

+	vTaskIncrementTick();

+	

+	#if configUSE_PREEMPTION == 1

+		vTaskSwitchContext();

+	#endif

+			

+	/* Ready for the next interrupt. */

+	TB_ClearITPendingBit( TB_IT_Update );	

+}

+

+/*-----------------------------------------------------------*/

+

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions here to

+ * ensure a switch to ARM mode.  When THUMB_INTERWORK is not defined then

+ * the utilities are defined as macros in portmacro.h - as per other ports.

+ */

+#ifdef THUMB_INTERWORK

+

+	void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	void vPortDisableInterruptsFromThumb( void )

+	{

+		asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.						*/

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+			

+	void vPortEnableInterruptsFromThumb( void )

+	{

+		asm volatile ( 

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.									*/	

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.								*/	

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.							*/	

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.				*/	

+			"LDMIA	SP!, {R0}		\n\t"	/* Pop R0.									*/

+			"BX		R14" );					/* Return back to thumb.					*/

+	}

+

+#endif /* THUMB_INTERWORK */

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	asm volatile ( 

+		"STMDB	SP!, {R0}			\n\t"	/* Push R0.								*/

+		"MRS	R0, CPSR			\n\t"	/* Get CPSR.							*/

+		"ORR	R0, R0, #0xC0		\n\t"	/* Disable IRQ, FIQ.					*/

+		"MSR	CPSR, R0			\n\t"	/* Write back modified value.			*/

+		"LDMIA	SP!, {R0}" );				/* Pop R0.								*/

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL().					*/

+			asm volatile ( 

+				"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	

+				"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	

+				"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	

+				"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	

+				"LDMIA	SP!, {R0}" );			/* Pop R0.						*/

+		}

+	}

+}

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/GCC/STR75x/portmacro.h b/FreeRTOS/Source/portable/GCC/STR75x/portmacro.h
new file mode 100644
index 0000000..73332af
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/STR75x/portmacro.h
@@ -0,0 +1,176 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm volatile ( "SWI 0" )

+#define portNOP()					asm volatile ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+/*

+ * The interrupt management utilities can only be called from ARM mode.  When

+ * THUMB_INTERWORK is defined the utilities are defined as functions in 

+ * portISR.c to ensure a switch to ARM mode.  When THUMB_INTERWORK is not 

+ * defined then the utilities are defined as macros here - as per other ports.

+ */

+

+#ifdef THUMB_INTERWORK

+

+	extern void vPortDisableInterruptsFromThumb( void ) __attribute__ ((naked));

+	extern void vPortEnableInterruptsFromThumb( void ) __attribute__ ((naked));

+

+	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()

+	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

+	

+#else

+

+	#define portDISABLE_INTERRUPTS()											\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"ORR	R0, R0, #0xC0	\n\t"	/* Disable IRQ, FIQ.			*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+			

+	#define portENABLE_INTERRUPTS()												\

+		asm volatile (															\

+			"STMDB	SP!, {R0}		\n\t"	/* Push R0.						*/	\

+			"MRS	R0, CPSR		\n\t"	/* Get CPSR.					*/	\

+			"BIC	R0, R0, #0xC0	\n\t"	/* Enable IRQ, FIQ.				*/	\

+			"MSR	CPSR, R0		\n\t"	/* Write back modified value.	*/	\

+			"LDMIA	SP!, {R0}			" )	/* Pop R0.						*/

+

+#endif /* THUMB_INTERWORK */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/GCC/TriCore_1782/port.c b/FreeRTOS/Source/portable/GCC/TriCore_1782/port.c
new file mode 100644
index 0000000..db7508c
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/TriCore_1782/port.c
@@ -0,0 +1,580 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+#include <string.h>

+

+/* TriCore specific includes. */

+#include <tc1782.h>

+#include <machine/intrinsics.h>

+#include <machine/cint.h>

+#include <machine/wdtcon.h>

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+#include "list.h"

+

+#if configCHECK_FOR_STACK_OVERFLOW > 0

+	#error "Stack checking cannot be used with this port, as, unlike most ports, the pxTopOfStack member of the TCB is consumed CSA.  CSA starvation, loosely equivalent to stack overflow, will result in a trap exception."

+	/* The stack pointer is accessible using portCSA_TO_ADDRESS( portCSA_TO_ADDRESS( pxCurrentTCB->pxTopOfStack )[ 0 ] )[ 2 ]; */

+#endif /* configCHECK_FOR_STACK_OVERFLOW */

+

+

+/*-----------------------------------------------------------*/

+

+/* System register Definitions. */

+#define portSYSTEM_PROGRAM_STATUS_WORD					( 0x000008FFUL ) /* Supervisor Mode, MPU Register Set 0 and Call Depth Counting disabled. */

+#define portINITIAL_PRIVILEGED_PROGRAM_STATUS_WORD		( 0x000014FFUL ) /* IO Level 1, MPU Register Set 1 and Call Depth Counting disabled. */

+#define portINITIAL_UNPRIVILEGED_PROGRAM_STATUS_WORD	( 0x000010FFUL ) /* IO Level 0, MPU Register Set 1 and Call Depth Counting disabled. */

+#define portINITIAL_PCXI_UPPER_CONTEXT_WORD				( 0x00C00000UL ) /* The lower 20 bits identify the CSA address. */

+#define portINITIAL_SYSCON								( 0x00000000UL ) /* MPU Disable. */

+

+/* CSA manipulation macros. */

+#define portCSA_FCX_MASK					( 0x000FFFFFUL )

+

+/* OS Interrupt and Trap mechanisms. */

+#define portRESTORE_PSW_MASK				( ~( 0x000000FFUL ) )

+#define portSYSCALL_TRAP					( 6 )

+

+/* Each CSA contains 16 words of data. */

+#define portNUM_WORDS_IN_CSA				( 16 )

+

+/* The interrupt enable bit in the PCP_SRC register. */

+#define portENABLE_CPU_INTERRUPT 			( 1U << 12U )

+/*-----------------------------------------------------------*/

+

+/*

+ * Perform any hardware configuration necessary to generate the tick interrupt.

+ */

+static void prvSystemTickHandler( int ) __attribute__((longcall));

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Trap handler for yields.

+ */

+static void prvTrapYield( int iTrapIdentification );

+

+/*

+ * Priority 1 interrupt handler for yields pended from an interrupt.

+ */

+static void prvInterruptYield( int iTrapIdentification );

+

+/*-----------------------------------------------------------*/

+

+/* This reference is required by the save/restore context macros. */

+extern volatile unsigned long *pxCurrentTCB;

+

+/* Precalculate the compare match value at compile time. */

+static const unsigned long ulCompareMatchValue = ( configPERIPHERAL_CLOCK_HZ / configTICK_RATE_HZ );

+

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long *pulUpperCSA = NULL;

+unsigned long *pulLowerCSA = NULL;

+

+	/* 16 Address Registers (4 Address registers are global), 16 Data

+	Registers, and 3 System Registers.

+

+	There are 3 registers that track the CSAs.

+		FCX points to the head of globally free set of CSAs.

+		PCX for the task needs to point to Lower->Upper->NULL arrangement.

+		LCX points to the last free CSA so that corrective action can be taken.

+

+	Need two CSAs to store the context of a task.

+		The upper context contains D8-D15, A10-A15, PSW and PCXI->NULL.

+		The lower context contains D0-D7, A2-A7, A11 and PCXI->UpperContext.

+		The pxCurrentTCB->pxTopOfStack points to the Lower Context RSLCX matching the initial BISR.

+		The Lower Context points to the Upper Context ready for the return from the interrupt handler.

+

+	 The Real stack pointer for the task is stored in the A10 which is restored

+	 with the upper context. */

+

+	/* Have to disable interrupts here because the CSAs are going to be

+	manipulated. */

+	portENTER_CRITICAL();

+	{

+		/* DSync to ensure that buffering is not a problem. */

+		_dsync();

+

+		/* Consume two free CSAs. */

+		pulLowerCSA = portCSA_TO_ADDRESS( _mfcr( $FCX ) );

+		if( NULL != pulLowerCSA )

+		{

+			/* The Lower Links to the Upper. */

+			pulUpperCSA = portCSA_TO_ADDRESS( pulLowerCSA[ 0 ] );

+		}

+

+		/* Check that we have successfully reserved two CSAs. */

+		if( ( NULL != pulLowerCSA ) && ( NULL != pulUpperCSA ) )

+		{

+			/* Remove the two consumed CSAs from the free CSA list. */

+			_disable();

+			_dsync();

+			_mtcr( $FCX, pulUpperCSA[ 0 ] );

+			_isync();

+			_enable();

+		}

+		else

+		{

+			/* Simply trigger a context list depletion trap. */

+			_svlcx();

+		}

+	}

+	portEXIT_CRITICAL();

+

+	/* Clear the upper CSA. */

+	memset( pulUpperCSA, 0, portNUM_WORDS_IN_CSA * sizeof( unsigned long ) );

+

+	/* Upper Context. */

+	pulUpperCSA[ 2 ] = ( unsigned long )pxTopOfStack;		/* A10;	Stack Return aka Stack Pointer */

+	pulUpperCSA[ 1 ] = portSYSTEM_PROGRAM_STATUS_WORD;		/* PSW	*/

+

+	/* Clear the lower CSA. */

+	memset( pulLowerCSA, 0, portNUM_WORDS_IN_CSA * sizeof( unsigned long ) );

+

+	/* Lower Context. */

+	pulLowerCSA[ 8 ] = ( unsigned long ) pvParameters;		/* A4;	Address Type Parameter Register	*/

+	pulLowerCSA[ 1 ] = ( unsigned long ) pxCode;			/* A11;	Return Address aka RA */

+

+	/* PCXI pointing to the Upper context. */

+	pulLowerCSA[ 0 ] = ( portINITIAL_PCXI_UPPER_CONTEXT_WORD | ( unsigned long ) portADDRESS_TO_CSA( pulUpperCSA ) );

+

+	/* Save the link to the CSA in the top of stack. */

+	pxTopOfStack = (unsigned long * ) portADDRESS_TO_CSA( pulLowerCSA );

+

+	/* DSync to ensure that buffering is not a problem. */

+	_dsync();

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+long xPortStartScheduler( void )

+{

+extern void vTrapInstallHandlers( void );

+unsigned long ulMFCR = 0UL;

+unsigned long *pulUpperCSA = NULL;

+unsigned long *pulLowerCSA = NULL;

+

+	/* Interrupts at or below configMAX_SYSCALL_INTERRUPT_PRIORITY are disable

+	when this function is called. */

+

+	/* Set-up the timer interrupt. */

+	prvSetupTimerInterrupt();

+

+	/* Install the Trap Handlers. */

+	vTrapInstallHandlers();

+

+	/* Install the Syscall Handler for yield calls. */

+	if( 0 == _install_trap_handler( portSYSCALL_TRAP, prvTrapYield ) )

+	{

+		/* Failed to install the yield handler, force an assert. */

+		configASSERT( ( ( volatile void * ) NULL ) );

+	}

+

+	/* Enable then install the priority 1 interrupt for pending context

+	switches from an ISR.  See mod_SRC in the TriCore manual. */

+	CPU_SRC0.reg = 	( portENABLE_CPU_INTERRUPT ) | ( configKERNEL_YIELD_PRIORITY );

+	if( 0 == _install_int_handler( configKERNEL_YIELD_PRIORITY, prvInterruptYield, 0 ) )

+	{

+		/* Failed to install the yield handler, force an assert. */

+		configASSERT( ( ( volatile void * ) NULL ) );

+	}

+

+	_disable();

+

+	/* Load the initial SYSCON. */

+	_mtcr( $SYSCON, portINITIAL_SYSCON );

+	_isync();

+

+	/* ENDINIT has already been applied in the 'cstart.c' code. */

+

+	/* Clear the PSW.CDC to enable the use of an RFE without it generating an

+	exception because this code is not genuinely in an exception. */

+	ulMFCR = _mfcr( $PSW );

+	ulMFCR &= portRESTORE_PSW_MASK;

+	_dsync();

+	_mtcr( $PSW, ulMFCR );

+	_isync();

+

+	/* Finally, perform the equivalent of a portRESTORE_CONTEXT() */

+	pulLowerCSA = portCSA_TO_ADDRESS( ( *pxCurrentTCB ) );

+	pulUpperCSA = portCSA_TO_ADDRESS( pulLowerCSA[0] );

+	_dsync();

+	_mtcr( $PCXI, *pxCurrentTCB );

+	_isync();

+	_nop();

+	_rslcx();

+	_nop();

+

+	/* Return to the first task selected to execute. */

+	__asm volatile( "rfe" );

+

+	/* Will not get here. */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	/* Set-up the clock divider. */

+	unlock_wdtcon();

+	{

+		/* Wait until access to Endint protected register is enabled. */

+		while( 0 != ( WDT_CON0.reg & 0x1UL ) );

+

+		/* RMC == 1 so STM Clock == FPI */

+		STM_CLC.reg = ( 1UL << 8 );

+	}

+	lock_wdtcon();

+

+    /* Determine how many bits are used without changing other bits in the CMCON register. */

+	STM_CMCON.reg &= ~( 0x1fUL );

+	STM_CMCON.reg |= ( 0x1fUL - __CLZ( configPERIPHERAL_CLOCK_HZ / configTICK_RATE_HZ ) );

+

+	/* Take into account the current time so a tick doesn't happen immediately. */

+	STM_CMP0.reg = ulCompareMatchValue + STM_TIM0.reg;

+

+	if( 0 != _install_int_handler( configKERNEL_INTERRUPT_PRIORITY, prvSystemTickHandler, 0 ) )

+	{

+		/* Set-up the interrupt. */

+		STM_SRC0.reg = ( configKERNEL_INTERRUPT_PRIORITY | 0x00005000UL );

+

+		/* Enable the Interrupt. */

+		STM_ISRR.reg &= ~( 0x03UL );

+		STM_ISRR.reg |= 0x1UL;

+		STM_ISRR.reg &= ~( 0x07UL );

+		STM_ICR.reg |= 0x1UL;

+	}

+	else

+	{

+		/* Failed to install the Tick Interrupt. */

+		configASSERT( ( ( volatile void * ) NULL ) );

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvSystemTickHandler( int iArg )

+{

+unsigned long ulSavedInterruptMask;

+unsigned long *pxUpperCSA = NULL;

+unsigned long xUpperCSA = 0UL;

+extern volatile unsigned long *pxCurrentTCB;

+

+	/* Just to avoid compiler warnings about unused parameters. */

+	( void ) iArg;

+

+	/* Clear the interrupt source. */

+	STM_ISRR.reg = 1UL;

+

+	/* Reload the Compare Match register for X ticks into the future.

+

+	If critical section or interrupt nesting budgets are exceeded, then

+	it is possible that the calculated next compare match value is in the

+	past.  If this occurs (unlikely), it is possible that the resulting

+	time slippage will exceed a single tick period.  Any adverse effect of

+	this is time bounded by the fact that only the first n bits of the 56 bit

+	STM timer are being used for a compare match, so another compare match

+	will occur after an overflow in just those n bits (not the entire 56 bits).

+	As an example, if the peripheral clock is 75MHz, and the tick rate is 1KHz,

+	a missed tick could result in the next tick interrupt occurring within a

+	time that is 1.7 times the desired period.  The fact that this is greater

+	than a single tick period is an effect of using a timer that cannot be

+	automatically reset, in hardware, by the occurrence of a tick interrupt.

+	Changing the tick source to a timer that has an automatic reset on compare

+	match (such as a GPTA timer) will reduce the maximum possible additional

+	period to exactly 1 times the desired period. */

+	STM_CMP0.reg += ulCompareMatchValue;

+

+	/* Kernel API calls require Critical Sections. */

+	ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		/* Increment the Tick. */

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );

+

+	#if configUSE_PREEMPTION == 1

+	{

+		/* Save the context of a task.

+		The upper context is automatically saved when entering a trap or interrupt.

+		Need to save the lower context as well and copy the PCXI CSA ID into

+		pxCurrentTCB->pxTopOfStack. Only Lower Context CSA IDs may be saved to the

+		TCB of a task.

+

+		Call vTaskSwitchContext to select the next task, note that this changes the

+		value of pxCurrentTCB so that it needs to be reloaded.

+

+		Call vPortSetMPURegisterSetOne to change the MPU mapping for the task

+		that has just been switched in.

+

+		Load the context of the task.

+		Need to restore the lower context by loading the CSA from

+		pxCurrentTCB->pxTopOfStack into PCXI (effectively changing the call stack).

+		In the Interrupt handler post-amble, RSLCX will restore the lower context

+		of the task. RFE will restore the upper context of the task, jump to the

+		return address and restore the previous state of interrupts being

+		enabled/disabled. */

+		_disable();

+		_dsync();

+		xUpperCSA = _mfcr( $PCXI );

+		pxUpperCSA = portCSA_TO_ADDRESS( xUpperCSA );

+		*pxCurrentTCB = pxUpperCSA[ 0 ];

+		vTaskSwitchContext();

+		pxUpperCSA[ 0 ] = *pxCurrentTCB;

+		CPU_SRC0.bits.SETR = 0;

+		_isync();

+	}

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * When a task is deleted, it is yielded permanently until the IDLE task

+ * has an opportunity to reclaim the memory that that task was using.

+ * Typically, the memory used by a task is the TCB and Stack but in the

+ * TriCore this includes the CSAs that were consumed as part of the Call

+ * Stack. These CSAs can only be returned to the Globally Free Pool when

+ * they are not part of the current Call Stack, hence, delaying the

+ * reclamation until the IDLE task is freeing the task's other resources.

+ * This function uses the head of the linked list of CSAs (from when the

+ * task yielded for the last time) and finds the tail (the very bottom of

+ * the call stack) and inserts this list at the head of the Free list,

+ * attaching the existing Free List to the tail of the reclaimed call stack.

+ *

+ * NOTE: the IDLE task needs processing time to complete this function

+ * and in heavily loaded systems, the Free CSAs may be consumed faster

+ * than they can be freed assuming that tasks are being spawned and

+ * deleted frequently.

+ */

+void vPortReclaimCSA( unsigned long *pxTCB )

+{

+unsigned long pxHeadCSA, pxTailCSA, pxFreeCSA;

+unsigned long *pulNextCSA;

+

+	/* A pointer to the first CSA in the list of CSAs consumed by the task is

+	stored in the first element of the tasks TCB structure (where the stack

+	pointer would be on a traditional stack based architecture). */

+	pxHeadCSA = ( *pxTCB ) & portCSA_FCX_MASK;

+

+	/* Mask off everything in the CSA link field other than the address.  If

+	the	address is NULL, then the CSA is not linking anywhere and there is

+	nothing	to do. */

+	pxTailCSA = pxHeadCSA;

+

+	/* Convert the link value to contain just a raw address and store this

+	in a local variable. */

+	pulNextCSA = portCSA_TO_ADDRESS( pxTailCSA );

+

+	/* Iterate over the CSAs that were consumed as part of the task.  The

+	first field in the CSA is the pointer to then next CSA.  Mask off

+	everything in the pointer to the next CSA, other than the link address.

+	If this is NULL, then the CSA currently being pointed to is the last in

+	the chain. */

+	while( 0UL != ( pulNextCSA[ 0 ] & portCSA_FCX_MASK ) )

+	{

+		/* Clear all bits of the pointer to the next in the chain, other

+		than the address bits themselves. */

+		pulNextCSA[ 0 ] = pulNextCSA[ 0 ] & portCSA_FCX_MASK;

+

+		/* Move the pointer to point to the next CSA in the list. */

+		pxTailCSA = pulNextCSA[ 0 ];

+

+		/* Update the local pointer to the CSA. */

+		pulNextCSA = portCSA_TO_ADDRESS( pxTailCSA );

+	}

+

+	_disable();

+	{

+		/* Look up the current free CSA head. */

+		_dsync();

+		pxFreeCSA = _mfcr( $FCX );

+

+		/* Join the current Free onto the Tail of what is being reclaimed. */

+		portCSA_TO_ADDRESS( pxTailCSA )[ 0 ] = pxFreeCSA;

+

+		/* Move the head of the reclaimed into the Free. */

+		_dsync();

+		_mtcr( $FCX, pxHeadCSA );

+		_isync();

+	}

+	_enable();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Nothing to do. Unlikely to want to end. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvTrapYield( int iTrapIdentification )

+{

+unsigned long *pxUpperCSA = NULL;

+unsigned long xUpperCSA = 0UL;

+extern volatile unsigned long *pxCurrentTCB;

+

+	switch( iTrapIdentification )

+	{

+		case portSYSCALL_TASK_YIELD:

+			/* Save the context of a task.

+			The upper context is automatically saved when entering a trap or interrupt.

+			Need to save the lower context as well and copy the PCXI CSA ID into

+			pxCurrentTCB->pxTopOfStack. Only Lower Context CSA IDs may be saved to the

+			TCB of a task.

+

+			Call vTaskSwitchContext to select the next task, note that this changes the

+			value of pxCurrentTCB so that it needs to be reloaded.

+

+			Call vPortSetMPURegisterSetOne to change the MPU mapping for the task

+			that has just been switched in.

+

+			Load the context of the task.

+			Need to restore the lower context by loading the CSA from

+			pxCurrentTCB->pxTopOfStack into PCXI (effectively changing the call stack).

+			In the Interrupt handler post-amble, RSLCX will restore the lower context

+			of the task. RFE will restore the upper context of the task, jump to the

+			return address and restore the previous state of interrupts being

+			enabled/disabled. */

+			_disable();

+			_dsync();

+			xUpperCSA = _mfcr( $PCXI );

+			pxUpperCSA = portCSA_TO_ADDRESS( xUpperCSA );

+			*pxCurrentTCB = pxUpperCSA[ 0 ];

+			vTaskSwitchContext();

+			pxUpperCSA[ 0 ] = *pxCurrentTCB;

+			CPU_SRC0.bits.SETR = 0;

+			_isync();

+			break;

+

+		default:

+			/* Unimplemented trap called. */

+			configASSERT( ( ( volatile void * ) NULL ) );

+			break;

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvInterruptYield( int iId )

+{

+unsigned long *pxUpperCSA = NULL;

+unsigned long xUpperCSA = 0UL;

+extern volatile unsigned long *pxCurrentTCB;

+

+	/* Just to remove compiler warnings. */

+	( void ) iId;

+

+	/* Save the context of a task.

+	The upper context is automatically saved when entering a trap or interrupt.

+	Need to save the lower context as well and copy the PCXI CSA ID into

+	pxCurrentTCB->pxTopOfStack. Only Lower Context CSA IDs may be saved to the

+	TCB of a task.

+

+	Call vTaskSwitchContext to select the next task, note that this changes the

+	value of pxCurrentTCB so that it needs to be reloaded.

+

+	Call vPortSetMPURegisterSetOne to change the MPU mapping for the task

+	that has just been switched in.

+

+	Load the context of the task.

+	Need to restore the lower context by loading the CSA from

+	pxCurrentTCB->pxTopOfStack into PCXI (effectively changing the call stack).

+	In the Interrupt handler post-amble, RSLCX will restore the lower context

+	of the task. RFE will restore the upper context of the task, jump to the

+	return address and restore the previous state of interrupts being

+	enabled/disabled. */

+	_disable();

+	_dsync();

+	xUpperCSA = _mfcr( $PCXI );

+	pxUpperCSA = portCSA_TO_ADDRESS( xUpperCSA );

+	*pxCurrentTCB = pxUpperCSA[ 0 ];

+	vTaskSwitchContext();

+	pxUpperCSA[ 0 ] = *pxCurrentTCB;

+	CPU_SRC0.bits.SETR = 0;

+	_isync();

+}

+/*-----------------------------------------------------------*/

+

+unsigned long uxPortSetInterruptMaskFromISR( void )

+{

+unsigned long uxReturn = 0UL;

+

+	_disable();

+	uxReturn = _mfcr( $ICR );

+	_mtcr( $ICR, ( ( uxReturn & ~portCCPN_MASK ) | configMAX_SYSCALL_INTERRUPT_PRIORITY ) );

+	_isync();

+	_enable();

+

+	/* Return just the interrupt mask bits. */

+	return ( uxReturn & portCCPN_MASK );

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/GCC/TriCore_1782/portmacro.h b/FreeRTOS/Source/portable/GCC/TriCore_1782/portmacro.h
new file mode 100644
index 0000000..66a6d18
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/TriCore_1782/portmacro.h
@@ -0,0 +1,208 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* System Includes. */

+#include <tc1782.h>

+#include <machine/intrinsics.h>

+

+/*-----------------------------------------------------------

+ * 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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*---------------------------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH							( -1 )

+#define portTICK_RATE_MS							( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT							4

+#define portNOP()									__asm volatile( " nop " )

+#define portCRITICAL_NESTING_IN_TCB					1

+#define portRESTORE_FIRST_TASK_PRIORITY_LEVEL		1

+

+

+/*---------------------------------------------------------------------------*/

+

+typedef struct MPU_SETTINGS { unsigned long ulNotUsed; } xMPU_SETTINGS;

+

+/* Define away the instruction from the Restore Context Macro. */

+#define portPRIVILEGE_BIT							0x0UL

+

+#define portCCPN_MASK						( 0x000000FFUL )

+

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()			vTaskEnterCritical()

+#define portEXIT_CRITICAL()				vTaskExitCritical()

+/*---------------------------------------------------------------------------*/

+

+/* CSA Manipulation. */

+#define portCSA_TO_ADDRESS( pCSA )			( ( unsigned long * )( ( ( ( pCSA ) & 0x000F0000 ) << 12 ) | ( ( ( pCSA ) & 0x0000FFFF ) << 6 ) ) )

+#define portADDRESS_TO_CSA( pAddress )		( ( unsigned long )( ( ( ( (unsigned long)( pAddress ) ) & 0xF0000000 ) >> 12 ) | ( ( ( unsigned long )( pAddress ) & 0x003FFFC0 ) >> 6 ) ) )

+/*---------------------------------------------------------------------------*/

+

+#define portYIELD()								_syscall( 0 )

+/* Port Restore is implicit in the platform when the function is returned from the original PSW is automatically replaced. */

+#define portSYSCALL_TASK_YIELD					0

+#define portSYSCALL_RAISE_PRIORITY				1

+/*---------------------------------------------------------------------------*/

+

+/* Critical section management. */

+

+/* Set ICR.CCPN to configMAX_SYSCALL_INTERRUPT_PRIORITY. */

+#define portDISABLE_INTERRUPTS()	{																									\

+										unsigned long ulICR;																			\

+										_disable();																						\

+										ulICR = _mfcr( $ICR ); 		/* Get current ICR value. */										\

+										ulICR &= ~portCCPN_MASK;	/* Clear down mask bits. */											\

+										ulICR |= configMAX_SYSCALL_INTERRUPT_PRIORITY; /* Set mask bits to required priority mask. */	\

+										_mtcr( $ICR, ulICR );		/* Write back updated ICR. */										\

+										_isync();																						\

+										_enable();																						\

+									}

+

+/* Clear ICR.CCPN to allow all interrupt priorities. */

+#define portENABLE_INTERRUPTS()		{																	\

+										unsigned long ulICR;											\

+										_disable();														\

+										ulICR = _mfcr( $ICR );		/* Get current ICR value. */		\

+										ulICR &= ~portCCPN_MASK;	/* Clear down mask bits. */			\

+										_mtcr( $ICR, ulICR );		/* Write back updated ICR. */		\

+										_isync();														\

+										_enable();														\

+									}

+

+/* Set ICR.CCPN to uxSavedMaskValue. */

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedMaskValue ) 	{																						\

+																	unsigned long ulICR;																\

+																	_disable();																			\

+																	ulICR = _mfcr( $ICR );		/* Get current ICR value. */							\

+																	ulICR &= ~portCCPN_MASK;	/* Clear down mask bits. */								\

+																	ulICR |= uxSavedMaskValue;	/* Set mask bits to previously saved mask value. */		\

+																	_mtcr( $ICR, ulICR );		/* Write back updated ICR. */							\

+																	_isync();																			\

+																	_enable();																			\

+																}

+

+

+/* Set ICR.CCPN to configMAX_SYSCALL_INTERRUPT_PRIORITY */

+extern unsigned long uxPortSetInterruptMaskFromISR( void );

+#define portSET_INTERRUPT_MASK_FROM_ISR() 	uxPortSetInterruptMaskFromISR()

+

+/* As this port holds a CSA address in pxTopOfStack, the assert that checks the

+pxTopOfStack alignment is removed. */

+#define portALIGNMENT_ASSERT_pxCurrentTCB ( void )

+

+/* Pend a priority 1 interrupt, which will take care of the context switch. */

+#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) 		if( xHigherPriorityTaskWoken != pdFALSE ) {	CPU_SRC0.bits.SETR = 1; _isync(); }

+

+/*---------------------------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*---------------------------------------------------------------------------*/

+

+/*

+ * Port specific clean up macro required to free the CSAs that were consumed by

+ * a task that has since been deleted.

+ */

+void vPortReclaimCSA( unsigned long *pxTCB );

+#define portCLEAN_UP_TCB( pxTCB )		vPortReclaimCSA( ( unsigned long * ) ( pxTCB ) )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

diff --git a/FreeRTOS/Source/portable/GCC/TriCore_1782/porttrap.c b/FreeRTOS/Source/portable/GCC/TriCore_1782/porttrap.c
new file mode 100644
index 0000000..c2cb2d3
--- /dev/null
+++ b/FreeRTOS/Source/portable/GCC/TriCore_1782/porttrap.c
@@ -0,0 +1,320 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Kernel includes. */

+#include "FreeRTOS.h"

+

+/* Machine includes */

+#include <tc1782.h>

+#include <machine/intrinsics.h>

+#include <machine/cint.h>

+/*---------------------------------------------------------------------------*/

+

+/*

+ * This reference is required by the Save/Restore Context Macros.

+ */

+extern volatile unsigned long *pxCurrentTCB;

+/*-----------------------------------------------------------*/

+

+/*

+ * This file contains base definitions for all of the possible traps in the system.

+ * It is suggested to provide implementations for all of the traps but for

+ * the time being they simply trigger a DEBUG instruction so that it is easy

+ * to see what caused a particular trap.

+ *

+ * Trap Class 6, the SYSCALL, is used exclusively by the operating system.

+ */

+

+/* The Trap Classes. */

+#define portMMU_TRAP										0

+#define portIPT_TRAP										1

+#define portIE_TRAP											2

+#define portCM_TRAP											3

+#define portSBP_TRAP										4

+#define portASSERT_TRAP										5

+#define portNMI_TRAP										7

+

+/* MMU Trap Identifications. */

+#define portTIN_MMU_VIRTUAL_ADDRESS_FILL					0

+#define portTIN_MMU_VIRTUAL_ADDRESS_PROTECTION				1

+

+/* Internal Protection Trap Identifications. */

+#define portTIN_IPT_PRIVILIGED_INSTRUCTION					1

+#define portTIN_IPT_MEMORY_PROTECTION_READ					2

+#define portTIN_IPT_MEMORY_PROTECTION_WRITE					3

+#define portTIN_IPT_MEMORY_PROTECTION_EXECUTION				4

+#define portTIN_IPT_MEMORY_PROTECTION_PERIPHERAL_ACCESS		5

+#define portTIN_IPT_MEMORY_PROTECTION_NULL_ADDRESS			6

+#define portTIN_IPT_MEMORY_PROTECTION_GLOBAL_REGISTER_WRITE_PROTECTION	7

+

+/* Instruction Error Trap Identifications. */

+#define portTIN_IE_ILLEGAL_OPCODE							1

+#define portTIN_IE_UNIMPLEMENTED_OPCODE						2

+#define portTIN_IE_INVALID_OPERAND							3

+#define portTIN_IE_DATA_ADDRESS_ALIGNMENT					4

+#define portTIN_IE_INVALID_LOCAL_MEMORY_ADDRESS				5

+

+/* Context Management Trap Identifications. */

+#define portTIN_CM_FREE_CONTEXT_LIST_DEPLETION				1

+#define portTIN_CM_CALL_DEPTH_OVERFLOW						2

+#define portTIN_CM_CALL_DEPTH_UNDEFLOW						3

+#define portTIN_CM_FREE_CONTEXT_LIST_UNDERFLOW				4

+#define portTIN_CM_CALL_STACK_UNDERFLOW						5

+#define portTIN_CM_CONTEXT_TYPE								6

+#define portTIN_CM_NESTING_ERROR							7

+

+/* System Bus and Peripherals Trap Identifications. */

+#define portTIN_SBP_PROGRAM_FETCH_SYNCHRONOUS_ERROR			1

+#define portTIN_SBP_DATA_ACCESS_SYNCHRONOUS_ERROR			2

+#define portTIN_SBP_DATA_ACCESS_ASYNCHRONOUS_ERROR			3

+#define portTIN_SBP_COPROCESSOR_TRAP_ASYNCHRONOUS_ERROR		4

+#define portTIN_SBP_PROGRAM_MEMORY_INTEGRITY_ERROR			5

+#define portTIN_SBP_DATA_MEMORY_INTEGRITY_ERROR				6

+

+/* Assertion Trap Identifications. */

+#define portTIN_ASSERT_ARITHMETIC_OVERFLOW					1

+#define portTIN_ASSERT_STICKY_ARITHMETIC_OVERFLOW			2

+

+/* Non-maskable Interrupt Trap Identifications. */

+#define portTIN_NMI_NON_MASKABLE_INTERRUPT					0

+/*---------------------------------------------------------------------------*/

+

+void vMMUTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vInternalProtectionTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vInstructionErrorTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vContextManagementTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vSystemBusAndPeripheralsTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vAssertionTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+void vNonMaskableInterruptTrap( int iTrapIdentification ) __attribute__( ( longcall, weak ) );

+/*---------------------------------------------------------------------------*/

+

+void vTrapInstallHandlers( void )

+{

+	if( 0 == _install_trap_handler ( portMMU_TRAP, vMMUTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portIPT_TRAP, vInternalProtectionTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portIE_TRAP, vInstructionErrorTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portCM_TRAP, vContextManagementTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portSBP_TRAP, vSystemBusAndPeripheralsTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portASSERT_TRAP, vAssertionTrap ) )

+	{

+		_debug();

+	}

+

+	if( 0 == _install_trap_handler ( portNMI_TRAP, vNonMaskableInterruptTrap ) )

+	{

+		_debug();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vMMUTrap( int iTrapIdentification )

+{

+	switch( iTrapIdentification )

+	{

+	case portTIN_MMU_VIRTUAL_ADDRESS_FILL:

+	case portTIN_MMU_VIRTUAL_ADDRESS_PROTECTION:

+	default:

+		_debug();

+		break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vInternalProtectionTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_IPT_PRIVILIGED_INSTRUCTION:

+			/* Instruction is not allowed at current execution level, eg DISABLE at User-0. */

+

+		case portTIN_IPT_MEMORY_PROTECTION_READ:

+			/* Load word using invalid address. */

+			

+		case portTIN_IPT_MEMORY_PROTECTION_WRITE:

+			/* Store Word using invalid address. */

+			

+		case portTIN_IPT_MEMORY_PROTECTION_EXECUTION:

+			/* PC jumped to an address outside of the valid range. */

+			

+		case portTIN_IPT_MEMORY_PROTECTION_PERIPHERAL_ACCESS:

+			/* Access to a peripheral denied at current execution level. */

+			

+		case portTIN_IPT_MEMORY_PROTECTION_NULL_ADDRESS:

+			/* NULL Pointer. */

+			

+		case portTIN_IPT_MEMORY_PROTECTION_GLOBAL_REGISTER_WRITE_PROTECTION:

+			/* Tried to modify a global address pointer register. */

+			

+		default:

+		

+			pxCurrentTCB[ 0 ] = _mfcr( $PCXI );

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vInstructionErrorTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_IE_ILLEGAL_OPCODE:

+		case portTIN_IE_UNIMPLEMENTED_OPCODE:

+		case portTIN_IE_INVALID_OPERAND:

+		case portTIN_IE_DATA_ADDRESS_ALIGNMENT:

+		case portTIN_IE_INVALID_LOCAL_MEMORY_ADDRESS:

+		default:

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vContextManagementTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_CM_FREE_CONTEXT_LIST_DEPLETION:

+		case portTIN_CM_CALL_DEPTH_OVERFLOW:

+		case portTIN_CM_CALL_DEPTH_UNDEFLOW:

+		case portTIN_CM_FREE_CONTEXT_LIST_UNDERFLOW:

+		case portTIN_CM_CALL_STACK_UNDERFLOW:

+		case portTIN_CM_CONTEXT_TYPE:

+		case portTIN_CM_NESTING_ERROR:

+		default:

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vSystemBusAndPeripheralsTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_SBP_PROGRAM_FETCH_SYNCHRONOUS_ERROR:

+		case portTIN_SBP_DATA_ACCESS_SYNCHRONOUS_ERROR:

+		case portTIN_SBP_DATA_ACCESS_ASYNCHRONOUS_ERROR:

+		case portTIN_SBP_COPROCESSOR_TRAP_ASYNCHRONOUS_ERROR:

+		case portTIN_SBP_PROGRAM_MEMORY_INTEGRITY_ERROR:

+		case portTIN_SBP_DATA_MEMORY_INTEGRITY_ERROR:

+		default:

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vAssertionTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_ASSERT_ARITHMETIC_OVERFLOW:

+		case portTIN_ASSERT_STICKY_ARITHMETIC_OVERFLOW:

+		default:

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

+

+void vNonMaskableInterruptTrap( int iTrapIdentification )

+{

+	/* Deliberate fall through to default. */

+	switch( iTrapIdentification )

+	{

+		case portTIN_NMI_NON_MASKABLE_INTERRUPT:

+		default:

+			_debug();

+			break;

+	}

+}

+/*---------------------------------------------------------------------------*/

diff --git a/FreeRTOS/Source/portable/IAR/78K0R/ISR_Support.h b/FreeRTOS/Source/portable/IAR/78K0R/ISR_Support.h
new file mode 100644
index 0000000..b7506df
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/78K0R/ISR_Support.h
@@ -0,0 +1,118 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+#include "FreeRTOSConfig.h"

+

+; Variables used by scheduler

+;------------------------------------------------------------------------------

+	EXTERN    pxCurrentTCB

+	EXTERN    usCriticalNesting

+

+;------------------------------------------------------------------------------

+;   portSAVE_CONTEXT MACRO

+;   Saves the context of the general purpose registers, CS and ES (only in far 

+;	memory mode) registers the usCriticalNesting Value and the Stack Pointer

+;   of the active Task onto the task stack

+;------------------------------------------------------------------------------

+portSAVE_CONTEXT MACRO

+

+	PUSH      AX                    ; Save AX Register to stack.

+	PUSH      HL

+#if configMEMORY_MODE == 1

+	MOV       A, CS                 ; Save CS register.

+	XCH       A, X

+	MOV       A, ES                 ; Save ES register.

+	PUSH      AX

+#else

+	MOV       A, CS                 ; Save CS register.

+	PUSH      AX

+#endif

+	PUSH      DE                    ; Save the remaining general purpose registers.

+	PUSH      BC

+	MOVW      AX, usCriticalNesting ; Save the usCriticalNesting value.

+	PUSH      AX	

+	MOVW      AX, pxCurrentTCB 	    ; Save the Stack pointer.

+	MOVW      HL, AX					

+	MOVW      AX, SP					

+	MOVW      [HL], AX					

+	ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   portRESTORE_CONTEXT MACRO

+;   Restores the task Stack Pointer then use this to restore usCriticalNesting,

+;   general purpose registers and the CS and ES (only in far memory mode)

+;   of the selected task from the task stack

+;------------------------------------------------------------------------------

+portRESTORE_CONTEXT MACRO

+	MOVW      AX, pxCurrentTCB	    ; Restore the Stack pointer.

+	MOVW      HL, AX

+	MOVW      AX, [HL]

+	MOVW      SP, AX

+	POP	      AX	                ; Restore usCriticalNesting value.

+	MOVW      usCriticalNesting, AX

+	POP	      BC                    ; Restore the necessary general purpose registers.

+	POP	      DE

+#if configMEMORY_MODE == 1

+	POP       AX                    ; Restore the ES register.

+	MOV       ES, A

+	XCH       A, X                  ; Restore the CS register.

+	MOV       CS, A

+#else

+	POP       AX

+	MOV       CS, A                 ; Restore CS register.

+#endif

+	POP       HL                    ; Restore general purpose register HL.

+	POP       AX                    ; Restore AX.

+	ENDM

+;------------------------------------------------------------------------------

diff --git a/FreeRTOS/Source/portable/IAR/78K0R/port.c b/FreeRTOS/Source/portable/IAR/78K0R/port.c
new file mode 100644
index 0000000..062b691
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/78K0R/port.c
@@ -0,0 +1,264 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* The critical nesting value is initialised to a non zero value to ensure

+interrupts don't accidentally become enabled before the scheduler is started. */

+#define portINITIAL_CRITICAL_NESTING  (( unsigned short ) 10)

+

+/* Initial PSW value allocated to a newly created task.

+ *   1100011000000000

+ *   ||||||||-------------- Fill byte

+ *   |||||||--------------- Carry Flag cleared

+ *   |||||----------------- In-service priority Flags set to low level

+ *   ||||------------------ Register bank Select 0 Flag cleared

+ *   |||------------------- Auxiliary Carry Flag cleared

+ *   ||-------------------- Register bank Select 1 Flag cleared

+ *   |--------------------- Zero Flag set

+ *   ---------------------- Global Interrupt Flag set (enabled)

+ */

+#define portPSW		  (0xc6UL)

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Most ports implement critical sections by placing the interrupt flags on

+the stack before disabling interrupts.  Exiting the critical section is then

+simply a case of popping the flags from the stack.  As 78K0 IAR does not use

+a frame pointer this cannot be done as modifying the stack will clobber all

+the stack variables.  Instead each task maintains a count of the critical

+section nesting depth.  Each time a critical section is entered the count is

+incremented.  Each time a critical section is left the count is decremented -

+with interrupts only being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long *pulLocal;

+

+	#if configMEMORY_MODE == 1

+	{

+		/* Parameters are passed in on the stack, and written using a 32bit value

+		hence a space is left for the second two bytes. */

+		pxTopOfStack--;

+

+		/* Write in the parameter value. */

+		pulLocal =  ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( unsigned long ) pvParameters;

+		pxTopOfStack--;

+

+		/* These values are just spacers.  The return address of the function

+		would normally be written here. */

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xcdcd;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xcdcd;

+		pxTopOfStack--;

+

+		/* The start address / PSW value is also written in as a 32bit value,

+		so leave a space for the second two bytes. */

+		pxTopOfStack--;

+	

+		/* Task function start address combined with the PSW. */

+		pulLocal = ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( ( ( unsigned long ) pxCode ) | ( portPSW << 24UL ) );

+		pxTopOfStack--;

+

+		/* An initial value for the AX register. */

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		/* Task function address is written to the stack first.  As it is

+		written as a 32bit value a space is left on the stack for the second

+		two bytes. */

+		pxTopOfStack--;

+

+		/* Task function start address combined with the PSW. */

+		pulLocal = ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( ( ( unsigned long ) pxCode ) | ( portPSW << 24UL ) );

+		pxTopOfStack--;

+

+		/* The parameter is passed in AX. */

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack--;

+	}

+	#endif

+

+	/* An initial value for the HL register. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+	pxTopOfStack--;

+

+	/* CS and ES registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0F00;

+	pxTopOfStack--;

+

+	/* Finally the remaining general purpose registers DE and BC */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDEDE;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBCBC;

+	pxTopOfStack--;

+

+	/* Finally the critical section nesting count is set to zero when the task

+	first starts. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	vPortStart();

+

+	/* Should not get here as the tasks are now running! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the 78K0R port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	/* Setup channel 5 of the TAU to generate the tick interrupt. */

+

+	/* First the Timer Array Unit has to be enabled. */

+	TAU0EN = 1;

+

+	/* To configure the Timer Array Unit all Channels have to first be stopped. */

+	TT0 = 0xff;

+

+	/* Interrupt of Timer Array Unit Channel 5 is disabled to set the interrupt

+	priority. */

+	TMMK05 = 1;

+

+	/* Clear Timer Array Unit Channel 5 interrupt flag. */	

+	TMIF05 = 0;

+

+	/* Set Timer Array Unit Channel 5 interrupt priority */

+	TMPR005 = 0;

+	TMPR105 = 0;

+

+	/* Set Timer Array Unit Channel 5 Mode as interval timer. */

+	TMR05 = 0x0000;

+

+	/* Set the compare match value according to the tick rate we want. */

+	TDR05 = ( portTickType ) ( configCPU_CLOCK_HZ / configTICK_RATE_HZ );

+

+	/* Set Timer Array Unit Channel 5 output mode */

+	TOM0 &= ~0x0020;

+

+	/* Set Timer Array Unit Channel 5 output level */	

+	TOL0 &= ~0x0020;

+

+	/* Set Timer Array Unit Channel 5 output enable */	

+	TOE0 &= ~0x0020;

+

+	/* Interrupt of Timer Array Unit Channel 5 enabled */

+	TMMK05 = 0;

+

+	/* Start Timer Array Unit Channel 5.*/

+	TS0 |= 0x0020;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/IAR/78K0R/portasm.s26 b/FreeRTOS/Source/portable/IAR/78K0R/portasm.s26
new file mode 100644
index 0000000..fc83b9e
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/78K0R/portasm.s26
@@ -0,0 +1,163 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+#include "ISR_Support.h"

+;------------------------------------------------------------------------------

+

+#if __CORE__ != __78K0R__

+	#error "This file is only for 78K0R Devices"

+#endif

+

+#define CS                    0xFFFFC

+#define ES                    0xFFFFD

+

+; Functions implemented in this file

+;------------------------------------------------------------------------------

+	PUBLIC    vPortYield

+	PUBLIC    vPortStart

+

+; Functions used by scheduler

+;------------------------------------------------------------------------------

+	EXTERN    vTaskSwitchContext

+	EXTERN    vTaskIncrementTick

+

+; Tick ISR Prototype

+;------------------------------------------------------------------------------

+;	EXTERN    ?CL78K0R_V2_L00

+

+	PUBWEAK   `??MD_INTTM05??INTVEC 68`

+	PUBLIC    MD_INTTM05

+

+MD_INTTM05    SYMBOL "MD_INTTM05"

+`??MD_INTTM05??INTVEC 68` SYMBOL "??INTVEC 68", MD_INTTM05

+

+

+

+;------------------------------------------------------------------------------

+;   Yield to another task.  Implemented as a software interrupt.  The return

+;   address and PSW will have been saved to the stack automatically before

+;   this code runs.

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortYield

+;

+;   Output: NONE

+;

+;------------------------------------------------------------------------------

+    RSEG CODE:CODE

+vPortYield:

+	portSAVE_CONTEXT		        ; Save the context of the current task.

+	call      vTaskSwitchContext    ; Call the scheduler to select the next task.

+	portRESTORE_CONTEXT		        ; Restore the context of the next task to run.

+	retb

+

+	

+;------------------------------------------------------------------------------

+;   Restore the context of the first task that is going to run.

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortStart

+;

+;   Output: NONE

+;

+;------------------------------------------------------------------------------	

+    RSEG CODE:CODE

+vPortStart:

+	portRESTORE_CONTEXT	            ; Restore the context of whichever task the ...

+	reti					        ; An interrupt stack frame is used so the task

+                                    ; is started using a RETI instruction.

+

+;------------------------------------------------------------------------------

+;   Perform the necessary steps of the Tick Count Increment and Task Switch

+;   depending on the chosen kernel configuration

+;

+;   Input:  NONE

+;

+;   Call:   ISR

+;

+;   Output: NONE

+;

+;------------------------------------------------------------------------------	

+

+MD_INTTM05:

+

+	portSAVE_CONTEXT		        ; Save the context of the current task.

+	call      vTaskIncrementTick    ; Call the timer tick function.

+#if configUSE_PREEMPTION == 1

+	call      vTaskSwitchContext    ; Call the scheduler to select the next task.

+#endif

+	portRESTORE_CONTEXT		        ; Restore the context of the next task to run.

+	reti

+

+

+

+;	REQUIRE ?CL78K0R_V2_L00

+	COMMON INTVEC:CODE:ROOT(1)      ; Set ISR location to the Interrupt vector table.

+	ORG 68

+`??MD_INTTM05??INTVEC 68`:

+	DW MD_INTTM05

+

+	COMMON INTVEC:CODE:ROOT(1)      ; Set ISR location to the Interrupt vector table.

+	ORG 126

+`??vPortYield??INTVEC 126`:

+	DW vPortYield

+

+									; Set value for the usCriticalNesting.

+	RSEG NEAR_ID:CONST:SORT:NOROOT(1)

+`?<Initializer for usCriticalNesting>`:

+	DW 10

+

+;#endif

+

+      END
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/IAR/78K0R/portmacro.h b/FreeRTOS/Source/portable/IAR/78K0R/portmacro.h
new file mode 100644
index 0000000..030ba2f
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/78K0R/portmacro.h
@@ -0,0 +1,180 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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  unsigned short

+#define portBASE_TYPE   short

+

+#if (configUSE_16_BIT_TICKS==1)

+	typedef unsigned int portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned long portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS() __asm ( "DI" )

+#define portENABLE_INTERRUPTS()	 __asm ( "EI" )

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled ulCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+extern void vPortStart( void );

+#define portYIELD()	__asm( "BRK" )

+#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) if( xHigherPriorityTaskWoken ) vTaskSwitchContext()

+#define portNOP()	__asm( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Hardwware specifics. */

+#define portBYTE_ALIGNMENT	2

+#define portSTACK_GROWTH	( -1 )

+#define portTICK_RATE_MS	( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+

+static __interrupt void P0_isr   (void);

+

+/* --------------------------------------------------------------------------*/

+/* Option-bytes and security ID                                              */

+/* --------------------------------------------------------------------------*/

+#define OPT_BYTES_SIZE     4

+#define SECU_ID_SIZE       10

+#define WATCHDOG_DISABLED  0x00

+#define LVI_ENABLED        0xFE

+#define LVI_DISABLED       0xFF

+#define RESERVED_FF        0xFF

+#define OCD_DISABLED       0x04

+#define OCD_ENABLED        0x81

+#define OCD_ENABLED_ERASE  0x80

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM0/port.c b/FreeRTOS/Source/portable/IAR/ARM_CM0/port.c
new file mode 100644
index 0000000..88b40ed
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM0/port.c
@@ -0,0 +1,221 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM0 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portMIN_INTERRUPT_PRIORITY	( 255UL )

+#define portNVIC_PENDSV_PRI			( portMIN_INTERRUPT_PRIORITY << 16UL )

+#define portNVIC_SYSTICK_PRI		( portMIN_INTERRUPT_PRIORITY << 24UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value 255 should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.3.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 0

+#endif

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortSysTickHandler( void );

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+extern void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack -= 6;	/* LR, R12, R3..R1 */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8; /* R11..R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV and SysTick the lowest priority interrupts. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM0 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;	

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM0/portasm.s b/FreeRTOS/Source/portable/IAR/ARM_CM0/portasm.s
new file mode 100644
index 0000000..b4df256
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM0/portasm.s
@@ -0,0 +1,168 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include <FreeRTOSConfig.h>

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value zero should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.3.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 0

+#endif

+

+	

+	RSEG    CODE:CODE(2)

+	thumb

+

+	EXTERN vPortYieldFromISR

+	EXTERN pxCurrentTCB

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vSetMSP

+	PUBLIC xPortPendSVHandler

+	PUBLIC vPortSVCHandler

+	PUBLIC vPortStartFirstTask

+

+

+/*-----------------------------------------------------------*/

+

+vSetMSP

+	msr msp, r0

+	bx lr

+	

+/*-----------------------------------------------------------*/

+

+xPortPendSVHandler:

+	mrs r0, psp							

+											

+	ldr	r3, =pxCurrentTCB	/* Get the location of the current TCB. */

+	ldr	r2, [r3]						

+											

+	subs r0, r0, #32		/* Make space for the remaining low registers. */

+	str r0, [r2]			/* Save the new top of stack. */

+	stmia r0!, {r4-r7}		/* Store the low registers that are not saved automatically. */

+	mov r4, r8				/* Store the high registers. */

+	mov r5, r9							

+	mov r6, r10							

+	mov r7, r11							

+	stmia r0!, {r4-r7}              	

+											

+	push {r3, r14}						

+	cpsid i								

+	bl vTaskSwitchContext				

+	cpsie i								

+	pop {r2, r3}			/* lr goes in r3. r2 now holds tcb pointer. */

+											

+	ldr r1, [r2]						

+	ldr r0, [r1]			/* The first item in pxCurrentTCB is the task top of stack. */

+	adds r0, r0, #16		/* Move to the high registers. */

+	ldmia r0!, {r4-r7}		/* Pop the high registers. */

+	mov r8, r4							

+	mov r9, r5							

+	mov r10, r6							

+	mov r11, r7							

+											

+	msr psp, r0				/* Remember the new top of stack for the task. */

+											

+	subs r0, r0, #32		/* Go back for the low registers that are not automatically restored. */

+	ldmia r0!, {r4-r7}		/* Pop low registers.  */

+											

+	bx r3								

+

+/*-----------------------------------------------------------*/

+

+vPortSVCHandler;

+	ldr	r3, =pxCurrentTCB	/* Restore the context. */

+	ldr r1, [r3]			/* Get the pxCurrentTCB address. */

+	ldr r0, [r1]			/* The first item in pxCurrentTCB is the task top of stack. */

+	adds r0, r0, #16		/* Move to the high registers. */

+	ldmia r0!, {r4-r7}		/* Pop the high registers. */

+	mov r8, r4						

+	mov r9, r5						

+	mov r10, r6						

+	mov r11, r7						

+										

+	msr psp, r0				/* Remember the new top of stack for the task. */

+										

+	subs r0, r0, #32		/* Go back for the low registers that are not automatically restored. */

+	ldmia r0!, {r4-r7}		/* Pop low registers.  */

+	mov r1, r14				/* OR R14 with 0x0d. */

+	movs r0, #0x0d					

+	orrs r1, r0						

+	bx r1							

+

+/*-----------------------------------------------------------*/

+

+vPortStartFirstTask

+	movs r0, #0x00 	 		/* Locate the top of stack. */

+	ldr r0, [r0] 		

+	msr msp, r0		 		/* Set the msp back to the start of the stack. */

+	cpsie i			 		/* Globally enable interrupts. */

+	svc 0			 		/* System call to start first task. */

+	nop				

+	

+	END

+	
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM0/portmacro.h b/FreeRTOS/Source/portable/IAR/ARM_CM0/portmacro.h
new file mode 100644
index 0000000..5ada831
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM0/portmacro.h
@@ -0,0 +1,144 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()				__asm volatile( "cpsid i" )

+#define portENABLE_INTERRUPTS()					__asm volatile( "cpsie i" )

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portDISABLE_INTERRUPTS()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portENABLE_INTERRUPTS();(void)x

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM3/port.c b/FreeRTOS/Source/portable/IAR/ARM_CM3/port.c
new file mode 100644
index 0000000..44f3ac8
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM3/port.c
@@ -0,0 +1,226 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM3 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#if configMAX_SYSCALL_INTERRUPT_PRIORITY == 0

+	#error configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value 255 should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.3.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 0

+#endif

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortSysTickHandler( void );

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+extern void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV and SysTick the lowest priority interrupts. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM3 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;	

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM3/portasm.s b/FreeRTOS/Source/portable/IAR/ARM_CM3/portasm.s
new file mode 100644
index 0000000..c9e0bb3
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM3/portasm.s
@@ -0,0 +1,168 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include <FreeRTOSConfig.h>

+

+/* For backward compatibility, ensure configKERNEL_INTERRUPT_PRIORITY is

+defined.  The value zero should also ensure backward compatibility.

+FreeRTOS.org versions prior to V4.3.0 did not include this definition. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 0

+#endif

+

+	

+	RSEG    CODE:CODE(2)

+	thumb

+

+	EXTERN vPortYieldFromISR

+	EXTERN pxCurrentTCB

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vSetMSP

+	PUBLIC xPortPendSVHandler

+	PUBLIC vPortSetInterruptMask

+	PUBLIC vPortClearInterruptMask

+	PUBLIC vPortSVCHandler

+	PUBLIC vPortStartFirstTask

+

+

+/*-----------------------------------------------------------*/

+

+vSetMSP

+	msr msp, r0

+	bx lr

+	

+/*-----------------------------------------------------------*/

+

+xPortPendSVHandler:

+	mrs r0, psp						

+	ldr	r3, =pxCurrentTCB			/* Get the location of the current TCB. */

+	ldr	r2, [r3]						

+

+	stmdb r0!, {r4-r11}				/* Save the remaining registers. */

+	str r0, [r2]					/* Save the new top of stack into the first member of the TCB. */

+

+	stmdb sp!, {r3, r14}

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0

+	bl vTaskSwitchContext			

+	mov r0, #0

+	msr basepri, r0

+	ldmia sp!, {r3, r14}

+

+	ldr r1, [r3]					

+	ldr r0, [r1]					/* The first item in pxCurrentTCB is the task top of stack. */

+	ldmia r0!, {r4-r11}				/* Pop the registers. */

+	msr psp, r0						

+	bx r14							

+

+

+/*-----------------------------------------------------------*/

+

+vPortSetInterruptMask:

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr BASEPRI, r0

+

+	bx r14

+	

+/*-----------------------------------------------------------*/

+

+vPortClearInterruptMask:

+	/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+	http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+	mov r0, #0

+	msr BASEPRI, r0

+

+	bx r14

+

+/*-----------------------------------------------------------*/

+

+vPortSVCHandler;

+	ldr	r3, =pxCurrentTCB

+	ldr r1, [r3]

+	ldr r0, [r1]

+	ldmia r0!, {r4-r11}

+	msr psp, r0

+	mov r0, #0

+	msr	basepri, r0

+	orr r14, r14, #13

+	bx r14

+

+/*-----------------------------------------------------------*/

+

+vPortStartFirstTask

+	/* Use the NVIC offset register to locate the stack. */

+	ldr r0, =0xE000ED08

+	ldr r0, [r0]

+	ldr r0, [r0]

+	/* Set the msp back to the start of the stack. */

+	msr msp, r0

+	/* Call SVC to start the first task. */

+	cpsie i

+	svc 0

+

+	END

+	
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM3/portmacro.h b/FreeRTOS/Source/portable/IAR/ARM_CM3/portmacro.h
new file mode 100644
index 0000000..939b640
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM3/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+extern void vPortSetInterruptMask( void );

+extern void vPortClearInterruptMask( void );

+

+#define portDISABLE_INTERRUPTS()	vPortSetInterruptMask()

+#define portENABLE_INTERRUPTS()		vPortClearInterruptMask()

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;vPortSetInterruptMask()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	vPortClearInterruptMask();(void)x

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM4F/port.c b/FreeRTOS/Source/portable/IAR/ARM_CM4F/port.c
new file mode 100644
index 0000000..1ca5e68
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM4F/port.c
@@ -0,0 +1,251 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM4F port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#ifndef __ARMVFP__

+	#error This port can only be used when the project options are configured to enable hardware floating point support.

+#endif

+

+#if configMAX_SYSCALL_INTERRUPT_PRIORITY == 0

+	#error configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long * ) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long * ) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long * ) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long * ) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to manipulate the VFP. */

+#define portFPCCR					( ( volatile unsigned long * ) 0xe000ef34 ) /* Floating point context control register. */

+#define portASPEN_AND_LSPEN_BITS	( 0x3UL << 30UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+#define portINITIAL_EXEC_RETURN		( 0xfffffffd )

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortSysTickHandler( void );

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+extern void vPortStartFirstTask( void );

+

+/*

+ * Functions defined in portasm.s to enable the VFP.

+ */

+extern void vPortEnableVFP( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	

+	/* Offset added to account for the way the MCU uses the stack on entry/exit

+	of interrupts, and to ensure alignment. */

+	pxTopOfStack--;

+		

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	

+	/* Save code space by skipping register initialisation. */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+

+	/* A save method is being used that requires each task to maintain its

+	own exec return value. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_EXEC_RETURN;

+

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+	

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV and SysTick the lowest priority interrupts. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Ensure the VFP is enabled - it should be anyway. */

+	vPortEnableVFP();

+	

+	/* Lazy save always. */

+	*( portFPCCR ) |= portASPEN_AND_LSPEN_BITS;

+	

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM4F port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;	

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM4F/portasm.s b/FreeRTOS/Source/portable/IAR/ARM_CM4F/portasm.s
new file mode 100644
index 0000000..26eb626
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM4F/portasm.s
@@ -0,0 +1,188 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include <FreeRTOSConfig.h>

+

+	RSEG    CODE:CODE(2)

+	thumb

+

+	EXTERN pxCurrentTCB

+	EXTERN vTaskSwitchContext

+

+	PUBLIC xPortPendSVHandler

+	PUBLIC vPortSetInterruptMask

+	PUBLIC vPortClearInterruptMask

+	PUBLIC vPortSVCHandler

+	PUBLIC vPortStartFirstTask

+	PUBLIC vPortEnableVFP

+

+

+/*-----------------------------------------------------------*/

+

+xPortPendSVHandler:

+	mrs r0, psp						

+	

+	/* Get the location of the current TCB. */

+	ldr	r3, =pxCurrentTCB			

+	ldr	r2, [r3]						

+

+	/* Is the task using the FPU context?  If so, push high vfp registers. */

+	tst r14, #0x10

+	it eq

+	vstmdbeq r0!, {s16-s31}

+

+	/* Save the core registers. */

+	stmdb r0!, {r4-r11, r14}				

+	

+	/* Save the new top of stack into the first member of the TCB. */

+	str r0, [r2]

+	

+	stmdb sp!, {r3, r14}

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0

+	bl vTaskSwitchContext			

+	mov r0, #0

+	msr basepri, r0

+	ldmia sp!, {r3, r14}

+

+	/* The first item in pxCurrentTCB is the task top of stack. */

+	ldr r1, [r3]	

+	ldr r0, [r1]

+	

+	/* Pop the core registers. */

+	ldmia r0!, {r4-r11, r14}

+

+	/* Is the task using the FPU context?  If so, pop the high vfp registers 

+	too. */

+	tst r14, #0x10

+	it eq

+	vldmiaeq r0!, {s16-s31}

+	

+	msr psp, r0						

+	bx r14							

+

+

+/*-----------------------------------------------------------*/

+

+vPortSetInterruptMask:

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr BASEPRI, r0

+

+	bx r14

+	

+/*-----------------------------------------------------------*/

+

+vPortClearInterruptMask:

+	/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+	http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+	mov r0, #0

+	msr BASEPRI, r0

+

+	bx r14

+

+/*-----------------------------------------------------------*/

+

+vPortSVCHandler:

+	/* Get the location of the current TCB. */

+	ldr	r3, =pxCurrentTCB

+	ldr r1, [r3]

+	ldr r0, [r1]

+	/* Pop the core registers. */

+	ldmia r0!, {r4-r11, r14}

+	msr psp, r0

+	mov r0, #0

+	msr	basepri, r0	

+	bx r14

+

+/*-----------------------------------------------------------*/

+

+vPortStartFirstTask:

+	/* Use the NVIC offset register to locate the stack. */

+	ldr r0, =0xE000ED08

+	ldr r0, [r0]

+	ldr r0, [r0]

+	/* Set the msp back to the start of the stack. */

+	msr msp, r0

+	/* Call SVC to start the first task. */

+	cpsie i

+	svc 0

+

+/*-----------------------------------------------------------*/

+

+vPortEnableVFP:

+	/* The FPU enable bits are in the CPACR. */

+	ldr.w r0, =0xE000ED88

+	ldr	r1, [r0]

+	

+	/* Enable CP10 and CP11 coprocessors, then save back. */

+	orr	r1, r1, #( 0xf << 20 )

+	str r1, [r0]

+	bx	r14	

+	

+

+

+	END

+	

diff --git a/FreeRTOS/Source/portable/IAR/ARM_CM4F/portmacro.h b/FreeRTOS/Source/portable/IAR/ARM_CM4F/portmacro.h
new file mode 100644
index 0000000..b88474d
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ARM_CM4F/portmacro.h
@@ -0,0 +1,153 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+extern void vPortSetInterruptMask( void );

+extern void vPortClearInterruptMask( void );

+

+#define portDISABLE_INTERRUPTS()	vPortSetInterruptMask()

+#define portENABLE_INTERRUPTS()		vPortClearInterruptMask()

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;vPortSetInterruptMask()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	vPortClearInterruptMask();(void)x

+

+/* There are an uneven number of items on the initial stack, so 

+portALIGNMENT_ASSERT_pxCurrentTCB() will trigger false positive asserts. */

+#define portALIGNMENT_ASSERT_pxCurrentTCB ( void )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/ATMega323/port.c b/FreeRTOS/Source/portable/IAR/ATMega323/port.c
new file mode 100644
index 0000000..a990f96
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ATMega323/port.c
@@ -0,0 +1,378 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include <stdlib.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the AVR/IAR port.

+ *----------------------------------------------------------*/

+

+/* Start tasks with interrupts enables. */

+#define portFLAGS_INT_ENABLED					( ( portSTACK_TYPE ) 0x80 )

+

+/* Hardware constants for timer 1. */

+#define portCLEAR_COUNTER_ON_MATCH				( ( unsigned char ) 0x08 )

+#define portPRESCALE_64							( ( unsigned char ) 0x03 )

+#define portCLOCK_PRESCALER						( ( unsigned long ) 64 )

+#define portCOMPARE_MATCH_A_INTERRUPT_ENABLE	( ( unsigned char ) 0x10 )

+

+/* The number of bytes used on the hardware stack by the task start address. */

+#define portBYTES_USED_BY_RETURN_ADDRESS		( 2 )

+/*-----------------------------------------------------------*/

+

+/* Stores the critical section nesting.  This must not be initialised to 0.

+It will be initialised when a task starts. */

+#define portNO_CRITICAL_NESTING					( ( unsigned portBASE_TYPE ) 0 )

+unsigned portBASE_TYPE uxCriticalNesting = 0x50;

+

+

+/*

+ * Perform hardware setup to enable ticks from timer 1, compare match A.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * The IAR compiler does not have full support for inline assembler, so

+ * these are defined in the portmacro assembler file.

+ */

+extern void vPortYieldFromTick( void );

+extern void vPortStart( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned short usAddress;

+portSTACK_TYPE *pxTopOfHardwareStack;

+

+	/* Place a few bytes of known values on the bottom of the stack.

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x11;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack--;

+

+	/* Remember where the top of the hardware stack is - this is required

+	below. */

+	pxTopOfHardwareStack = pxTopOfStack;

+

+

+	/* Simulate how the stack would look after a call to vPortYield(). */

+

+	/*lint -e950 -e611 -e923 Lint doesn't like this much - but nothing I can do about it. */

+

+

+

+	/* The IAR compiler requires two stacks per task.  First there is the

+	hardware call stack which uses the AVR stack pointer.  Second there is the

+	software stack (local variables, parameter passing, etc.) which uses the

+	AVR Y register.

+	

+	This function places both stacks within the memory block passed in as the

+	first parameter.  The hardware stack is placed at the bottom of the memory

+	block.  A gap is then left for the hardware stack to grow.  Next the software

+	stack is placed.  The amount of space between the software and hardware

+	stacks is defined by configCALL_STACK_SIZE.

+

+

+

+	The first part of the stack is the hardware stack.  Place the start

+	address of the task on the hardware stack. */

+	usAddress = ( unsigned short ) pxCode;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	usAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+

+	/* Leave enough space for the hardware stack before starting the software

+	stack.  The '- 2' is because we have already used two spaces for the

+	address of the start of the task. */

+	pxTopOfStack -= ( configCALL_STACK_SIZE - 2 );

+

+

+

+	/* Next simulate the stack as if after a call to portSAVE_CONTEXT().

+	portSAVE_CONTEXT places the flags on the stack immediately after r0

+	to ensure the interrupts get disabled as soon as possible, and so ensuring

+	the stack use is minimal should a context switch interrupt occur. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00;	/* R0 */

+	pxTopOfStack--;

+	*pxTopOfStack = portFLAGS_INT_ENABLED;

+	pxTopOfStack--;

+

+	/* Next place the address of the hardware stack.  This is required so

+	the AVR stack pointer can be restored to point to the hardware stack. */

+	pxTopOfHardwareStack -= portBYTES_USED_BY_RETURN_ADDRESS;

+	usAddress = ( unsigned short ) pxTopOfHardwareStack;

+

+	/* SPL */

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	/* SPH */

+	usAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+

+

+

+	/* Now the remaining registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01;	/* R1 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02;	/* R2 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03;	/* R3 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04;	/* R4 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05;	/* R5 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06;	/* R6 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07;	/* R7 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08;	/* R8 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09;	/* R9 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10;	/* R10 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11;	/* R11 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12;	/* R12 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x13;	/* R13 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x14;	/* R14 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x15;	/* R15 */

+	pxTopOfStack--;

+

+	/* Place the parameter on the stack in the expected location. */

+	usAddress = ( unsigned short ) pvParameters;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	usAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( usAddress & ( unsigned short ) 0x00ff );

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x18;	/* R18 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x19;	/* R19 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x20;	/* R20 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x21;	/* R21 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22;	/* R22 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x23;	/* R23 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x24;	/* R24 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x25;	/* R25 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x26;	/* R26 X */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x27;	/* R27 */

+	pxTopOfStack--;

+

+	/* The Y register is not stored as it is used as the software stack and

+	gets saved into the task control block. */

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x30;	/* R30 Z */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x031;	/* R31 */

+

+	pxTopOfStack--;

+	*pxTopOfStack = portNO_CRITICAL_NESTING;	/* Critical nesting is zero when the task starts. */

+

+	/*lint +e950 +e611 +e923 */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run.

+	Normally we would just call portRESTORE_CONTEXT() here, but as the IAR

+	compiler does not fully support inline assembler we have to make a call.*/

+	vPortStart();

+

+	/* Should not get here! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the AVR port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup timer 1 compare match A to generate a tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+unsigned long ulCompareMatch;

+unsigned char ucHighByte, ucLowByte;

+

+	/* Using 16bit timer 1 to generate the tick.  Correct fuses must be

+	selected for the configCPU_CLOCK_HZ clock. */

+

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* We only have 16 bits so have to scale to get our required tick rate. */

+	ulCompareMatch /= portCLOCK_PRESCALER;

+

+	/* Adjust for correct value. */

+	ulCompareMatch -= ( unsigned long ) 1;

+

+	/* Setup compare match value for compare match A.  Interrupts are disabled

+	before this is called so we need not worry here. */

+	ucLowByte = ( unsigned char ) ( ulCompareMatch & ( unsigned long ) 0xff );

+	ulCompareMatch >>= 8;

+	ucHighByte = ( unsigned char ) ( ulCompareMatch & ( unsigned long ) 0xff );

+	OCR1AH = ucHighByte;

+	OCR1AL = ucLowByte;

+

+	/* Setup clock source and compare match behaviour. */

+	ucLowByte = portCLEAR_COUNTER_ON_MATCH | portPRESCALE_64;

+	TCCR1B = ucLowByte;

+

+	/* Enable the interrupt - this is okay as interrupt are currently globally

+	disabled. */

+	TIMSK |= portCOMPARE_MATCH_A_INTERRUPT_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 1

+

+	/*

+	 * Tick ISR for preemptive scheduler.  We can use a __task attribute as

+	 * the context is saved at the start of vPortYieldFromTick().  The tick

+	 * count is incremented after the context is saved.

+	 */

+	__task void SIG_OUTPUT_COMPARE1A( void )

+	{

+		vPortYieldFromTick();

+		asm( "reti" );

+	}

+	

+#else

+

+	/*

+	 * Tick ISR for the cooperative scheduler.  All this does is increment the

+	 * tick count.  We don't need to switch context, this can only be done by

+	 * manual calls to taskYIELD();

+	 *

+	 * THE INTERRUPT VECTOR IS POPULATED IN portmacro.s90.  DO NOT INSTALL

+	 * IT HERE USING THE USUAL PRAGMA.

+	 */		

+	__interrupt void SIG_OUTPUT_COMPARE1A( void )

+	{

+		vTaskIncrementTick();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == portNO_CRITICAL_NESTING )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+

+	

diff --git a/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.h b/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.h
new file mode 100644
index 0000000..10e00ae
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.h
@@ -0,0 +1,146 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.2.3

+

+	+ portCPU_CLOSK_HZ definition changed to 8MHz base 10, previously it

+	  base 16.

+*/

+

+#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		int

+#define portSTACK_TYPE	unsigned portCHAR

+#define portBASE_TYPE	portCHAR

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* Critical section management. */

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portENTER_CRITICAL()	vPortEnterCritical()

+#define portEXIT_CRITICAL()		vPortExitCritical()

+

+#define portDISABLE_INTERRUPTS()	asm( "cli" )

+#define portENABLE_INTERRUPTS()		asm( "sei" )

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			1

+#define portNOP()					asm( "nop" )

+/*-----------------------------------------------------------*/

+

+/* Kernel utilities. */

+void vPortYield( void );

+#define portYIELD()	vPortYield()

+

+#ifdef IAR_MEGA_AVR

+	#define outb( PORT, VALUE ) PORT = VALUE

+#endif

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.s90 b/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.s90
new file mode 100644
index 0000000..750a54f
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/ATMega323/portmacro.s90
@@ -0,0 +1,268 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+#include <iom323.h>

+

+; Declare all extern symbols here - including any ISRs that are referenced in

+; the vector table.

+

+; ISR functions

+; -------------

+EXTERN SIG_OUTPUT_COMPARE1A

+EXTERN SIG_UART_RECV

+EXTERN SIG_UART_DATA

+

+

+; Functions used by scheduler

+; ---------------------------

+EXTERN vTaskSwitchContext

+EXTERN pxCurrentTCB

+EXTERN vTaskIncrementTick

+EXTERN uxCriticalNesting

+

+; Functions implemented in this file

+; ----------------------------------

+PUBLIC vPortYield

+PUBLIC vPortYieldFromTick

+PUBLIC vPortStart

+

+

+; Interrupt vector table.

+; -----------------------

+;

+; For simplicity the RTOS tick interrupt routine uses the __task keyword.

+; As the IAR compiler does not permit a function to be declared using both

+; __task and __interrupt, the use of __task necessitates that the interrupt

+; vector table be setup manually.

+;

+; To write an ISR, implement the ISR function using the __interrupt keyword

+; but do not install the interrupt using the "#pragma vector=ABC" method.

+; Instead manually place the name of the ISR in the vector table using an

+; ORG and jmp instruction as demonstrated below.

+; You will also have to add an EXTERN statement at the top of the file.

+

+	ASEG

+

+

+	ORG TIMER1_COMPA_vect				; Vector address

+		jmp SIG_OUTPUT_COMPARE1A		; ISR

+

+	ORG USART_RXC_vect					; Vector address

+		jmp SIG_UART_RECV				; ISR

+

+	ORG USART_UDRE_vect					; Vector address

+		jmp SIG_UART_DATA				; ISR

+

+	

+	RSEG CODE

+

+

+

+; Saving and Restoring a Task Context and Task Switching

+; ------------------------------------------------------

+;

+; The IAR compiler does not fully support inline assembler, so saving and

+; restoring a task context has to be written in an asm file.

+;

+; vPortYield() and vPortYieldFromTick() are usually written in C.  Doing

+; so in this case would required calls to be made to portSAVE_CONTEXT() and

+; portRESTORE_CONTEXT().  This is dis-advantageous as the context switch

+; function would require two extra jump and return instructions over the

+; WinAVR equivalent.

+;

+; To avoid this I have opted to implement both vPortYield() and

+; vPortYieldFromTick() in this assembly file.  For convenience

+; portSAVE_CONTEXT and portRESTORE_CONTEXT are implemented as macros.

+

+portSAVE_CONTEXT MACRO

+	st	-y, r0			; First save the r0 register - we need to use this.

+	in	r0, SREG		; Obtain the SREG value so we can disable interrupts...

+	cli					; ... as soon as possible.

+	st	-y, r0			; Store the SREG as it was before we disabled interrupts.

+

+	in	r0, SPL			; Next store the hardware stack pointer.  The IAR...

+	st	-y, r0			; ... compiler uses the hardware stack as a call stack ...

+	in	r0, SPH			; ...  only.

+	st	-y, r0

+

+	st	-y, r1			; Now store the rest of the registers.  Dont store the ...

+	st	-y, r2			; ... the Y register here as it is used as the software

+	st	-y, r3			; stack pointer and will get saved into the TCB.

+	st	-y, r4

+	st	-y, r5

+	st	-y, r6

+	st	-y, r7

+	st	-y, r8

+	st	-y, r9

+	st	-y, r10

+	st	-y, r11

+	st	-y, r12

+	st	-y, r13

+	st	-y, r14

+	st	-y, r15

+	st	-y, r16

+	st	-y, r17

+	st	-y, r18

+	st	-y, r19

+	st	-y, r20

+	st	-y, r21

+	st	-y, r22

+	st	-y, r23

+	st	-y, r24

+	st	-y, r25

+	st	-y, r26

+	st	-y, r27

+	st	-y, r30

+	st	-y, r31

+	lds r0, uxCriticalNesting

+	st	-y, r0					; Store the critical nesting counter.

+

+	lds	r26, pxCurrentTCB		; Finally save the software stack pointer (Y ...

+	lds	r27, pxCurrentTCB + 1	; ... register) into the TCB.

+	st	x+, r28

+	st	x+, r29

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+	lds	r26, pxCurrentTCB

+	lds	r27, pxCurrentTCB + 1	; Restore the software stack pointer from ...

+	ld	r28, x+					; the TCB into the software stack pointer (...

+	ld	r29, x+					; ... the Y register).

+

+	ld	r0, y+

+	sts	uxCriticalNesting, r0

+	ld	r31, y+					; Restore the registers down to R0.  The Y

+	ld	r30, y+					; register is missing from this list as it

+	ld	r27, y+					; has already been restored.

+	ld	r26, y+

+	ld	r25, y+

+	ld	r24, y+

+	ld	r23, y+

+	ld	r22, y+

+	ld	r21, y+

+	ld	r20, y+

+	ld	r19, y+

+	ld	r18, y+

+	ld	r17, y+

+	ld	r16, y+

+	ld	r15, y+

+	ld	r14, y+

+	ld	r13, y+

+	ld	r12, y+

+	ld	r11, y+

+	ld	r10, y+

+	ld	r9, y+

+	ld	r8, y+

+	ld	r7, y+

+	ld	r6, y+

+	ld	r5, y+

+	ld	r4, y+

+	ld	r3, y+

+	ld	r2, y+

+	ld	r1, y+

+

+	ld	r0, y+					; The next thing on the stack is the ...

+	out	SPH, r0					; ... hardware stack pointer.

+	ld	r0, y+

+	out	SPL, r0

+

+	ld	r0, y+					; Next there is the SREG register.

+	out SREG, r0

+

+	ld	r0, y+					; Finally we have finished with r0, so restore r0.

+	

+	ENDM

+

+

+

+; vPortYield() and vPortYieldFromTick()

+; -------------------------------------

+;

+; Manual and preemptive context switch functions respectively.

+; The IAR compiler does not fully support inline assembler,

+; so these are implemented here rather than the more usually

+; place of within port.c.

+

+vPortYield:

+	portSAVE_CONTEXT			; Save the context of the current task.

+	call vTaskSwitchContext		; Call the scheduler.

+	portRESTORE_CONTEXT			; Restore the context of whichever task the ...

+	ret							; ... scheduler decided should run.

+

+vPortYieldFromTick:

+	portSAVE_CONTEXT			; Save the context of the current task.

+	call vTaskIncrementTick		; Call the timer tick function.

+	call vTaskSwitchContext		; Call the scheduler.

+	portRESTORE_CONTEXT			; Restore the context of whichever task the ...

+	ret							; ... scheduler decided should run.

+

+; vPortStart()

+; ------------

+;

+; Again due to the lack of inline assembler, this is required

+; to get access to the portRESTORE_CONTEXT macro.

+

+vPortStart:

+	portRESTORE_CONTEXT

+	ret

+

+

+; Just a filler for unused interrupt vectors.

+vNoISR:

+	reti

+

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/AVR32_UC3/exception.s82 b/FreeRTOS/Source/portable/IAR/AVR32_UC3/exception.s82
new file mode 100644
index 0000000..2df712c
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AVR32_UC3/exception.s82
@@ -0,0 +1,310 @@
+/*This file is prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief Exception and interrupt vectors.

+ *

+ * This file maps all events supported by an AVR32UC.

+ *

+ * - Compiler:           IAR EWAVR32

+ * - Supported devices:  All AVR32UC devices with an INTC module can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ ******************************************************************************/

+

+/* Copyright (c) 2007, Atmel Corporation All rights reserved.

+ *

+ * Redistribution and use in source and binary forms, with or without

+ * modification, are permitted provided that the following conditions are met:

+ *

+ * 1. Redistributions of source code must retain the above copyright notice,

+ * this list of conditions and the following disclaimer.

+ *

+ * 2. Redistributions in binary form must reproduce the above copyright notice,

+ * this list of conditions and the following disclaimer in the documentation

+ * and/or other materials provided with the distribution.

+ *

+ * 3. The name of ATMEL may not be used to endorse or promote products derived

+ * from this software without specific prior written permission.

+ *

+ * THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED

+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND

+ * SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT,

+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES

+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;

+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND

+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT

+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF

+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+ */

+

+

+#include <avr32/io.h>

+#include "intc.h"

+

+

+//! @{

+//! \verbatim

+

+

+// Start of Exception Vector Table.

+

+  // EVBA must be aligned with a power of two strictly greater than the EVBA-

+  // relative offset of the last vector.

+  COMMON  EVTAB:CODE:ROOT(9)

+

+

+  // Force EVBA initialization.

+  EXTERN  ??init_EVBA

+  REQUIRE ??init_EVBA

+

+  // Export symbol.

+  PUBLIC  ??EVBA

+  PUBLIC  _evba

+??EVBA:

+_evba:

+

+        ORG 0x000

+        // Unrecoverable Exception.

+_handle_Unrecoverable_Exception:

+        rjmp $

+

+        ORG 0x004

+        // TLB Multiple Hit: UNUSED IN AVR32UC.

+_handle_TLB_Multiple_Hit:

+        rjmp $

+

+        ORG 0x008

+        // Bus Error Data Fetch.

+_handle_Bus_Error_Data_Fetch:

+        rjmp $

+

+        ORG 0x00C

+         // Bus Error Instruction Fetch.

+_handle_Bus_Error_Instruction_Fetch:

+        rjmp $

+

+        ORG 0x010

+        // NMI.

+_handle_NMI:

+        rjmp $

+

+        ORG 0x014

+        // Instruction Address.

+_handle_Instruction_Address:

+        rjmp $

+

+        ORG 0x018

+        // ITLB Protection.

+_handle_ITLB_Protection:

+        rjmp $

+

+        ORG 0x01C

+        // Breakpoint.

+_handle_Breakpoint:

+        rjmp $

+

+        ORG 0x020

+        // Illegal Opcode.

+_handle_Illegal_Opcode:

+        rjmp $

+

+        ORG 0x024

+        // Unimplemented Instruction.

+_handle_Unimplemented_Instruction:

+        rjmp $

+

+        ORG 0x028

+        // Privilege Violation.

+_handle_Privilege_Violation:

+        rjmp $

+

+        ORG 0x02C

+        // Floating-Point: UNUSED IN AVR32UC.

+_handle_Floating_Point:

+        rjmp $

+

+        ORG 0x030

+        // Coprocessor Absent: UNUSED IN AVR32UC.

+_handle_Coprocessor_Absent:

+        rjmp $

+

+        ORG 0x034

+        // Data Address (Read).

+_handle_Data_Address_Read:

+        rjmp $

+

+        ORG 0x038

+        // Data Address (Write).

+_handle_Data_Address_Write:

+        rjmp $

+

+        ORG 0x03C

+        // DTLB Protection (Read).

+_handle_DTLB_Protection_Read:

+        rjmp $

+

+        ORG 0x040

+        // DTLB Protection (Write).

+_handle_DTLB_Protection_Write:

+        rjmp $

+

+        ORG 0x044

+        // DTLB Modified: UNUSED IN AVR32UC.

+_handle_DTLB_Modified:

+        rjmp $

+

+        ORG 0x050

+        // ITLB Miss: UNUSED IN AVR32UC.

+_handle_ITLB_Miss:

+        rjmp $

+

+        ORG 0x060

+        // DTLB Miss (Read): UNUSED IN AVR32UC.

+_handle_DTLB_Miss_Read:

+        rjmp $

+

+        ORG 0x070

+        // DTLB Miss (Write): UNUSED IN AVR32UC.

+_handle_DTLB_Miss_Write:

+        rjmp $

+

+        ORG 0x100

+        // Supervisor Call.

+_handle_Supervisor_Call:

+        lddpc   pc, __SCALLYield

+

+

+// Interrupt support.

+// The interrupt controller must provide the offset address relative to EVBA.

+// Important note:

+//   All interrupts call a C function named _get_interrupt_handler.

+//   This function will read group and interrupt line number to then return in

+//   R12 a pointer to a user-provided interrupt handler.

+

+  ALIGN 2

+

+_int0:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 110b

+  brlo    _int0_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int0_normal:

+#endif

+  mov     r12, 0  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  mcall   __get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int1:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 110b

+  brlo    _int1_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int1_normal:

+#endif

+  mov     r12, 1  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  mcall   __get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int2:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 110b

+  brlo    _int2_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int2_normal:

+#endif

+  mov     r12, 2  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  mcall   __get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+_int3:

+  // R8-R12, LR, PC and SR are automatically pushed onto the system stack by the

+  // CPU upon interrupt entry.

+#if 1 // B1832: interrupt stack changed to exception stack if exception is detected.

+  mfsr    r12, AVR32_SR

+  bfextu  r12, r12, AVR32_SR_M0_OFFSET, AVR32_SR_M0_SIZE + AVR32_SR_M1_SIZE + AVR32_SR_M2_SIZE

+  cp.w    r12, 110b

+  brlo    _int3_normal

+  lddsp   r12, sp[0 * 4]

+  stdsp   sp[6 * 4], r12

+  lddsp   r12, sp[1 * 4]

+  stdsp   sp[7 * 4], r12

+  lddsp   r12, sp[3 * 4]

+  sub     sp, -6 * 4

+  rete

+_int3_normal:

+#endif

+  mov     r12, 3  // Pass the int_lev parameter to the _get_interrupt_handler function.

+  mcall   __get_interrupt_handler

+  cp.w    r12, 0  // Get the pointer to the interrupt handler returned by the function.

+  movne   pc, r12 // If this was not a spurious interrupt (R12 != NULL), jump to the handler.

+  rete            // If this was a spurious interrupt (R12 == NULL), return from event handler.

+

+

+// Constant data area.

+

+  ALIGN 2

+

+  // Import symbols.

+  EXTERN  SCALLYield

+  EXTERN  _get_interrupt_handler

+__SCALLYield:

+  DC32  SCALLYield

+__get_interrupt_handler:

+  DC32  _get_interrupt_handler

+

+  // Values to store in the interrupt priority registers for the various interrupt priority levels.

+  // The interrupt priority registers contain the interrupt priority level and

+  // the EVBA-relative interrupt vector offset.

+  PUBLIC  ipr_val

+ipr_val:

+  DC32  (INT0 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int0 - _evba),\

+        (INT1 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int1 - _evba),\

+        (INT2 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int2 - _evba),\

+        (INT3 << AVR32_INTC_IPR0_INTLEV_OFFSET) | (_int3 - _evba)

+

+

+  END

+

+

+//! \endverbatim

+//! @}

diff --git a/FreeRTOS/Source/portable/IAR/AVR32_UC3/port.c b/FreeRTOS/Source/portable/IAR/AVR32_UC3/port.c
new file mode 100644
index 0000000..c9affd3
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AVR32_UC3/port.c
@@ -0,0 +1,445 @@
+/*This file has been prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief FreeRTOS port source for AVR32 UC3.

+ *

+ * - Compiler:           IAR EWAVR32

+ * - Supported devices:  All AVR32 devices can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ *****************************************************************************/

+

+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* AVR32 UC3 includes. */

+#include <avr32/io.h>

+#include <intrinsics.h>

+#include "gpio.h"

+

+#if configDBG

+	#include "usart.h"

+#endif

+

+#if( configTICK_USE_TC==1 )

+	#include "tc.h"

+#endif

+

+

+/* Constants required to setup the task context. */

+#define portINITIAL_SR            ( ( portSTACK_TYPE ) 0x00400000 ) /* AVR32 : [M2:M0]=001 I1M=0 I0M=0, GM=0 */

+#define portINSTRUCTION_SIZE      ( ( portSTACK_TYPE ) 0 )

+

+/* Each task maintains its own critical nesting variable. */

+#define portNO_CRITICAL_NESTING   ( ( unsigned long ) 0 )

+volatile unsigned long ulCriticalNesting = 9999UL;

+

+#if( configTICK_USE_TC==0 )

+	static void prvScheduleNextTick( void );

+#else

+	static void prvClearTcInt( void );

+#endif

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Low-level initialization routine called during startup, before the main

+ * function.

+ */

+int __low_level_init(void)

+{

+	#if configHEAP_INIT

+		#pragma segment = "HEAP"

+		portBASE_TYPE *pxMem;

+	#endif

+

+	/* Enable exceptions. */

+	ENABLE_ALL_EXCEPTIONS();

+

+	/* Initialize interrupt handling. */

+	INTC_init_interrupts();

+

+	#if configHEAP_INIT

+	{

+		/* Initialize the heap used by malloc. */

+		for( pxMem = __segment_begin( "HEAP" ); pxMem < ( portBASE_TYPE * ) __segment_end( "HEAP" ); )

+		{

+			*pxMem++ = 0xA5A5A5A5;

+		}

+	}

+	#endif

+

+	/* Code section present if and only if the debug trace is activated. */

+	#if configDBG

+	{

+		static const gpio_map_t DBG_USART_GPIO_MAP =

+		{

+			{ configDBG_USART_RX_PIN, configDBG_USART_RX_FUNCTION },

+			{ configDBG_USART_TX_PIN, configDBG_USART_TX_FUNCTION }

+		};

+

+		static const usart_options_t DBG_USART_OPTIONS =

+		{

+			.baudrate = configDBG_USART_BAUDRATE,

+			.charlength = 8,

+			.paritytype = USART_NO_PARITY,

+			.stopbits = USART_1_STOPBIT,

+			.channelmode = USART_NORMAL_CHMODE

+		};

+

+		/* Initialize the USART used for the debug trace with the configured parameters. */

+		extern volatile avr32_usart_t *volatile stdio_usart_base;

+		stdio_usart_base = configDBG_USART;

+		gpio_enable_module( DBG_USART_GPIO_MAP,

+		                    sizeof( DBG_USART_GPIO_MAP ) / sizeof( DBG_USART_GPIO_MAP[0] ) );

+		usart_init_rs232(configDBG_USART, &DBG_USART_OPTIONS, configCPU_CLOCK_HZ);

+	}

+	#endif

+

+	/* Request initialization of data segments. */

+	return 1;

+}

+/*-----------------------------------------------------------*/

+

+/* Added as there is no such function in FreeRTOS. */

+void *pvPortRealloc( void *pv, size_t xWantedSize )

+{

+void *pvReturn;

+

+	vTaskSuspendAll();

+	{

+		pvReturn = realloc( pv, xWantedSize );

+	}

+	xTaskResumeAll();

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+/* The cooperative scheduler requires a normal IRQ service routine to

+simply increment the system tick. */

+/* The preemptive scheduler is defined as "naked" as the full context is saved

+on entry as part of the context switch. */

+#pragma shadow_registers = full   // Naked.

+static void vTick( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT_OS_INT();

+

+	#if( configTICK_USE_TC==1 )

+		/* Clear the interrupt flag. */

+		prvClearTcInt();

+	#else

+		/* Schedule the COUNT&COMPARE match interrupt in (configCPU_CLOCK_HZ/configTICK_RATE_HZ)

+		clock cycles from now. */

+		prvScheduleNextTick();

+	#endif

+

+	/* Because FreeRTOS is not supposed to run with nested interrupts, put all OS

+	calls in a critical section . */

+	portENTER_CRITICAL();

+		vTaskIncrementTick();

+	portEXIT_CRITICAL();

+

+	/* Restore the context of the "elected task". */

+	portRESTORE_CONTEXT_OS_INT();

+}

+/*-----------------------------------------------------------*/

+

+#pragma shadow_registers = full   // Naked.

+void SCALLYield( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT_SCALL();

+	vTaskSwitchContext();

+	portRESTORE_CONTEXT_SCALL();

+}

+/*-----------------------------------------------------------*/

+

+/* The code generated by the GCC compiler uses the stack in different ways at

+different optimisation levels.  The interrupt flags can therefore not always

+be saved to the stack.  Instead the critical section nesting level is stored

+in a variable, which is then saved as part of the stack context. */

+#pragma optimize = no_inline

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts */

+	portDISABLE_INTERRUPTS();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	 directly.  Increment ulCriticalNesting to keep a count of how many times

+	 portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+#pragma optimize = no_inline

+void vPortExitCritical( void )

+{

+	if(ulCriticalNesting > portNO_CRITICAL_NESTING)

+	{

+		ulCriticalNesting--;

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable all interrupt/exception. */

+			portENABLE_INTERRUPTS();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* When the task starts, it will expect to find the function parameter in R12. */

+	pxTopOfStack--;

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x08080808;					/* R8 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x09090909;					/* R9 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x0A0A0A0A;					/* R10 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x0B0B0B0B;					/* R11 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) pvParameters;					/* R12 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xDEADBEEF;					/* R14/LR */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE; /* R15/PC */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) portINITIAL_SR;				/* SR */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xFF0000FF;					/* R0 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x01010101;					/* R1 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x02020202;					/* R2 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x03030303;					/* R3 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x04040404;					/* R4 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x05050505;					/* R5 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x06060606;					/* R6 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x07070707;					/* R7 */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_NESTING;			/* ulCriticalNesting */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	portRESTORE_CONTEXT();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the AVR32 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/* Schedule the COUNT&COMPARE match interrupt in (configCPU_CLOCK_HZ/configTICK_RATE_HZ)

+clock cycles from now. */

+#if( configTICK_USE_TC==0 )

+	static void prvScheduleFirstTick(void)

+	{

+		unsigned long lCycles;

+

+		lCycles = Get_system_register(AVR32_COUNT);

+		lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		// If lCycles ends up to be 0, make it 1 so that the COMPARE and exception

+		// generation feature does not get disabled.

+		if(0 == lCycles)

+		{

+			lCycles++;

+		}

+		Set_system_register(AVR32_COMPARE, lCycles);

+	}

+	

+	#pragma optimize = no_inline

+	static void prvScheduleNextTick(void)

+	{

+		unsigned long lCycles, lCount;

+

+		lCycles = Get_system_register(AVR32_COMPARE);

+		lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		// If lCycles ends up to be 0, make it 1 so that the COMPARE and exception

+		// generation feature does not get disabled.

+		if(0 == lCycles)

+		{

+			lCycles++;

+		}

+		lCount = Get_system_register(AVR32_COUNT);

+		if( lCycles < lCount )

+		{		// We missed a tick, recover for the next.

+			lCycles += (configCPU_CLOCK_HZ/configTICK_RATE_HZ);

+		}

+		Set_system_register(AVR32_COMPARE, lCycles);

+	}

+#else

+	#pragma optimize = no_inline

+	static void prvClearTcInt(void)

+	{

+		AVR32_TC.channel[configTICK_TC_CHANNEL].sr;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt(void)

+{

+	#if( configTICK_USE_TC==1 )

+

+		volatile avr32_tc_t *tc = &AVR32_TC;

+

+		// Options for waveform genration.

+		tc_waveform_opt_t waveform_opt =

+		{

+		.channel  = configTICK_TC_CHANNEL,             /* Channel selection. */

+

+		.bswtrg   = TC_EVT_EFFECT_NOOP,                /* Software trigger effect on TIOB. */

+		.beevt    = TC_EVT_EFFECT_NOOP,                /* External event effect on TIOB. */

+		.bcpc     = TC_EVT_EFFECT_NOOP,                /* RC compare effect on TIOB. */

+		.bcpb     = TC_EVT_EFFECT_NOOP,                /* RB compare effect on TIOB. */

+

+		.aswtrg   = TC_EVT_EFFECT_NOOP,                /* Software trigger effect on TIOA. */

+		.aeevt    = TC_EVT_EFFECT_NOOP,                /* External event effect on TIOA. */

+		.acpc     = TC_EVT_EFFECT_NOOP,                /* RC compare effect on TIOA: toggle. */

+		.acpa     = TC_EVT_EFFECT_NOOP,                /* RA compare effect on TIOA: toggle (other possibilities are none, set and clear). */

+

+		.wavsel   = TC_WAVEFORM_SEL_UP_MODE_RC_TRIGGER,/* Waveform selection: Up mode without automatic trigger on RC compare. */

+		.enetrg   = FALSE,                             /* External event trigger enable. */

+		.eevt     = 0,                                 /* External event selection. */

+		.eevtedg  = TC_SEL_NO_EDGE,                    /* External event edge selection. */

+		.cpcdis   = FALSE,                             /* Counter disable when RC compare. */

+		.cpcstop  = FALSE,                             /* Counter clock stopped with RC compare. */

+

+		.burst    = FALSE,                             /* Burst signal selection. */

+		.clki     = FALSE,                             /* Clock inversion. */

+		.tcclks   = TC_CLOCK_SOURCE_TC2                /* Internal source clock 2. */

+		};

+

+		tc_interrupt_t tc_interrupt =

+		{

+			.etrgs=0,

+			.ldrbs=0,

+			.ldras=0,

+			.cpcs =1,

+			.cpbs =0,

+			.cpas =0,

+			.lovrs=0,

+			.covfs=0,

+		};

+

+	#endif

+

+	/* Disable all interrupt/exception. */

+	portDISABLE_INTERRUPTS();

+

+	/* Register the compare interrupt handler to the interrupt controller and

+	enable the compare interrupt. */

+

+	#if( configTICK_USE_TC==1 )

+	{

+		INTC_register_interrupt((__int_handler)&vTick, configTICK_TC_IRQ, INT0);

+

+		/* Initialize the timer/counter. */

+		tc_init_waveform(tc, &waveform_opt);

+

+		/* Set the compare triggers.

+		Remember TC counter is 16-bits, so counting second is not possible!

+		That's why we configure it to count ms. */

+		tc_write_rc( tc, configTICK_TC_CHANNEL, ( configPBA_CLOCK_HZ / 4) / configTICK_RATE_HZ );

+

+		tc_configure_interrupts( tc, configTICK_TC_CHANNEL, &tc_interrupt );

+

+		/* Start the timer/counter. */

+		tc_start(tc, configTICK_TC_CHANNEL);

+	}

+	#else

+	{

+		INTC_register_interrupt((__int_handler)&vTick, AVR32_CORE_COMPARE_IRQ, INT0);

+		prvScheduleFirstTick();

+	}

+	#endif

+}

diff --git a/FreeRTOS/Source/portable/IAR/AVR32_UC3/portmacro.h b/FreeRTOS/Source/portable/IAR/AVR32_UC3/portmacro.h
new file mode 100644
index 0000000..da8c9f2
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AVR32_UC3/portmacro.h
@@ -0,0 +1,688 @@
+/*This file has been prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief FreeRTOS port header for AVR32 UC3.

+ *

+ * - Compiler:           IAR EWAVR32

+ * - Supported devices:  All AVR32 devices can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ *****************************************************************************/

+

+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+#include <avr32/io.h>

+#include "intc.h"

+#include "compiler.h"

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+

+/* Type definitions. */

+#define portCHAR        char

+#define portFLOAT       float

+#define portDOUBLE      double

+#define portLONG        long

+#define portSHORT       short

+#define portSTACK_TYPE  unsigned portLONG

+#define portBASE_TYPE   portLONG

+

+#define TASK_DELAY_MS(x)   ( (x)        /portTICK_RATE_MS )

+#define TASK_DELAY_S(x)    ( (x)*1000   /portTICK_RATE_MS )

+#define TASK_DELAY_MIN(x)  ( (x)*60*1000/portTICK_RATE_MS )

+

+#define configTICK_TC_IRQ             ATPASTE2(AVR32_TC_IRQ, configTICK_TC_CHANNEL)

+

+#if( configUSE_16_BIT_TICKS == 1 )

+  typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+  typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH      ( -1 )

+#define portTICK_RATE_MS      ( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT       4

+#define portNOP()             {__asm__ __volatile__ ("nop");}

+/*-----------------------------------------------------------*/

+

+

+/*-----------------------------------------------------------*/

+

+/* INTC-specific. */

+#define DISABLE_ALL_EXCEPTIONS()    Disable_global_exception()

+#define ENABLE_ALL_EXCEPTIONS()     Enable_global_exception()

+

+#define DISABLE_ALL_INTERRUPTS()    Disable_global_interrupt()

+#define ENABLE_ALL_INTERRUPTS()     Enable_global_interrupt()

+

+#define DISABLE_INT_LEVEL(int_lev)  Disable_interrupt_level(int_lev)

+#define ENABLE_INT_LEVEL(int_lev)   Enable_interrupt_level(int_lev)

+

+

+/*

+ * Debug trace.

+ * Activated if and only if configDBG is nonzero.

+ * Prints a formatted string to stdout.

+ * The current source file name and line number are output with a colon before

+ * the formatted string.

+ * A carriage return and a linefeed are appended to the output.

+ * stdout is redirected to the USART configured by configDBG_USART.

+ * The parameters are the same as for the standard printf function.

+ * There is no return value.

+ * SHALL NOT BE CALLED FROM WITHIN AN INTERRUPT as fputs and printf use malloc,

+ * which is interrupt-unsafe with the current __malloc_lock and __malloc_unlock.

+ */

+#if configDBG

+	#define portDBG_TRACE(...)												\

+	{																		\

+	  fputs(__FILE__ ":" ASTRINGZ(__LINE__) ": ", stdout);					\

+	  printf(__VA_ARGS__);													\

+	  fputs("\r\n", stdout);												\

+	}

+#else

+	#define portDBG_TRACE(...)

+#endif

+

+

+/* Critical section management. */

+#define portDISABLE_INTERRUPTS()  DISABLE_ALL_INTERRUPTS()

+#define portENABLE_INTERRUPTS()   ENABLE_ALL_INTERRUPTS()

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()      vPortEnterCritical();

+#define portEXIT_CRITICAL()       vPortExitCritical();

+

+

+/* Added as there is no such function in FreeRTOS. */

+extern void *pvPortRealloc( void *pv, size_t xSize );

+/*-----------------------------------------------------------*/

+

+

+/*=============================================================================================*/

+

+/*

+ * Restore Context for cases other than INTi.

+ */

+#define portRESTORE_CONTEXT()																\

+{																							\

+  extern volatile unsigned portLONG ulCriticalNesting;										\

+  extern volatile void *volatile pxCurrentTCB;												\

+																							\

+  __asm__ __volatile__ (																	\

+    /* Set SP to point to new stack */														\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")												\n\t"\

+    "ld.w    r0, r8[0]																		\n\t"\

+    "ld.w    sp, r0[0]																		\n\t"\

+																							\

+    /* Restore ulCriticalNesting variable */												\

+    "ld.w    r0, sp++																		\n\t"\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")										\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")										\n\t"\

+    "st.w    r8[0], r0																		\n\t"\

+																							\

+    /* Restore R0..R7 */																	\

+    "ldm     sp++, r0-r7																	\n\t"\

+    /* R0-R7 should not be used below this line */											\

+    /* Skip PC and SR (will do it at the end) */											\

+    "sub     sp, -2*4																		\n\t"\

+    /* Restore R8..R12 and LR */															\

+    "ldm     sp++, r8-r12, lr																\n\t"\

+    /* Restore SR */																		\

+    "ld.w    r0, sp[-8*4]																	\n\t" /* R0 is modified, is restored later. */\

+    "mtsr    "ASTRINGZ(AVR32_SR)", r0														\n\t"\

+    /* Restore r0 */																		\

+    "ld.w    r0, sp[-9*4]																	\n\t"\

+    /* Restore PC */																		\

+    "ld.w    pc, sp[-7*4]" /* Get PC from stack - PC is the 7th register saved */			\

+  );																						\

+																							\

+  /* Force import of global symbols from assembly */										\

+  ulCriticalNesting;																		\

+  pxCurrentTCB;																				\

+}

+

+

+/*

+ * portSAVE_CONTEXT_INT() and portRESTORE_CONTEXT_INT(): for INT0..3 exceptions.

+ * portSAVE_CONTEXT_SCALL() and portRESTORE_CONTEXT_SCALL(): for the scall exception.

+ *

+ * Had to make different versions because registers saved on the system stack

+ * are not the same between INT0..3 exceptions and the scall exception.

+ */

+

+// Task context stack layout:

+  // R8  (*)

+  // R9  (*)

+  // R10 (*)

+  // R11 (*)

+  // R12 (*)

+  // R14/LR (*)

+  // R15/PC (*)

+  // SR (*)

+  // R0

+  // R1

+  // R2

+  // R3

+  // R4

+  // R5

+  // R6

+  // R7

+  // ulCriticalNesting

+// (*) automatically done for INT0..INT3, but not for SCALL

+

+/*

+ * The ISR used for the scheduler tick depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+#if configUSE_PREEMPTION == 0

+

+/*

+ * portSAVE_CONTEXT_OS_INT() for OS Tick exception.

+ */

+#define portSAVE_CONTEXT_OS_INT()															\

+{																							\

+  /* Save R0..R7 */																			\

+  __asm__ __volatile__ ("stm     --sp, r0-r7");												\

+																							\

+  /* With the cooperative scheduler, as there is no context switch by interrupt, */			\

+  /* there is also no context save. */														\

+}

+

+/*

+ * portRESTORE_CONTEXT_OS_INT() for Tick exception.

+ */

+#define portRESTORE_CONTEXT_OS_INT()														\

+{																							\

+  __asm__ __volatile__ (																	\

+    /* Restore R0..R7 */																	\

+    "ldm     sp++, r0-r7																	\n\t"\

+																							\

+    /* With the cooperative scheduler, as there is no context switch by interrupt, */		\

+    /* there is also no context restore. */													\

+    "rete"																					\

+  );																						\

+}

+

+#else

+

+/*

+ * portSAVE_CONTEXT_OS_INT() for OS Tick exception.

+ */

+#define portSAVE_CONTEXT_OS_INT()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* When we come here */																			\

+  /* Registers R8..R12, LR, PC and SR had already been pushed to system stack */					\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Save R0..R7 */																				\

+    "stm     --sp, r0-r7																			\n\t"\

+																									\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */										\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    --sp, r0																				\n\t"\

+																									\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */	\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+    /* level and allow other lower interrupt level to occur). */									\

+    /* In this case we don't want to do a task switch because we don't know what the stack */		\

+    /* currently looks like (we don't know what the interrupted interrupt handler was doing). */	\

+    /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */		\

+    /* will just be restoring the interrupt handler, no way!!! */									\

+    /* So, since we won't do a vTaskSwitchContext(), it's of no use to save SP. */					\

+    "ld.w    r0, sp[9*4]																			\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																			\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																					\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_INT_SKIP_SAVE_CONTEXT_"ASTRINGZ(__LINE__)"										\n\t"\

+																									\

+    /* Store SP in the first member of the structure pointed to by pxCurrentTCB */					\

+    /* NOTE: we don't enter a critical section here because all interrupt handlers */				\

+    /* MUST perform a SAVE_CONTEXT/RESTORE_CONTEXT in the same way as */							\

+    /* portSAVE_CONTEXT_OS_INT/port_RESTORE_CONTEXT_OS_INT if they call OS functions. */			\

+    /* => all interrupt handlers must use portENTER_SWITCHING_ISR/portEXIT_SWITCHING_ISR. */		\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    r0[0], sp																				\n"\

+																									\

+    "LABEL_INT_SKIP_SAVE_CONTEXT_"ASTRINGZ(__LINE__)":"												\

+  );																								\

+}

+

+/*

+ * portRESTORE_CONTEXT_OS_INT() for Tick exception.

+ */

+#define portRESTORE_CONTEXT_OS_INT()																\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */		\

+  /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+  /* level and allow other lower interrupt level to occur). */										\

+  /* In this case we don't want to do a task switch because we don't know what the stack */			\

+  /* currently looks like (we don't know what the interrupted interrupt handler was doing). */		\

+  /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */			\

+  /* will just be restoring the interrupt handler, no way!!! */										\

+  __asm__ __volatile__ (																			\

+    "ld.w    r0, sp[9*4]																			\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																			\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																					\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_INT_SKIP_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)										\

+  );																								\

+																									\

+  /* Else */																						\

+  /* because it is here safe, always call vTaskSwitchContext() since an OS tick occurred. */		\

+  /* A critical section has to be used here because vTaskSwitchContext handles FreeRTOS linked lists. */\

+  portENTER_CRITICAL();																				\

+  vTaskSwitchContext();																				\

+  portEXIT_CRITICAL();																				\

+																									\

+  /* Restore all registers */																		\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Set SP to point to new stack */																\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "ld.w    sp, r0[0]																				\n"\

+																									\

+    "LABEL_INT_SKIP_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)":											\n\t"\

+																									\

+    /* Restore ulCriticalNesting variable */														\

+    "ld.w    r0, sp++																				\n\t"\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "st.w    r8[0], r0																				\n\t"\

+																									\

+    /* Restore R0..R7 */																			\

+    "ldm     sp++, r0-r7																			\n\t"\

+																									\

+    /* Now, the stack should be R8..R12, LR, PC and SR */											\

+    "rete"																							\

+  );																								\

+																									\

+  /* Force import of global symbols from assembly */												\

+  ulCriticalNesting;																				\

+  pxCurrentTCB;																						\

+}

+

+#endif

+

+

+/*

+ * portSAVE_CONTEXT_SCALL() for SupervisorCALL exception.

+ *

+ * NOTE: taskYIELD()(== SCALL) MUST NOT be called in a mode > supervisor mode.

+ *

+ */

+#define portSAVE_CONTEXT_SCALL()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* Warning: the stack layout after SCALL doesn't match the one after an interrupt. */				\

+  /* If SR[M2:M0] == 001 */																			\

+  /*    PC and SR are on the stack.  */																\

+  /* Else (other modes) */																			\

+  /*    Nothing on the stack. */																	\

+																									\

+  /* WARNING NOTE: the else case cannot happen as it is strictly forbidden to call */				\

+  /* vTaskDelay() and vTaskDelayUntil() OS functions (that result in a taskYield()) */				\

+  /* in an interrupt|exception handler. */															\

+																									\

+  __asm__ __volatile__ (																			\

+    /* in order to save R0-R7 */																	\

+    "sub     sp, 6*4																				\n\t"\

+    /* Save R0..R7 */																				\

+    "stm     --sp, r0-r7																			\n\t"\

+																									\

+    /* in order to save R8-R12 and LR */															\

+    /* do not use SP if interrupts occurs, SP must be left at bottom of stack */					\

+    "sub     r7, sp,-16*4																			\n\t"\

+    /* Copy PC and SR in other places in the stack. */												\

+    "ld.w    r0, r7[-2*4]																			\n\t" /* Read SR */\

+    "st.w    r7[-8*4], r0																			\n\t" /* Copy SR */\

+    "ld.w    r0, r7[-1*4]																			\n\t" /* Read PC */\

+    "st.w    r7[-7*4], r0																			\n\t" /* Copy PC */\

+																									\

+    /* Save R8..R12 and LR on the stack. */															\

+    "stm     --r7, r8-r12, lr																		\n\t"\

+																									\

+    /* Arriving here we have the following stack organizations: */									\

+    /* R8..R12, LR, PC, SR, R0..R7. */																\

+																									\

+    /* Now we can finalize the save. */																\

+																									\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */										\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    --sp, r0"																				\

+  );																								\

+																									\

+  /* Disable the its which may cause a context switch (i.e. cause a change of */					\

+  /* pxCurrentTCB). */																				\

+  /* Basically, all accesses to the pxCurrentTCB structure should be put in a */					\

+  /* critical section because it is a global structure. */											\

+  portENTER_CRITICAL();																				\

+																									\

+  /* Store SP in the first member of the structure pointed to by pxCurrentTCB */					\

+  __asm__ __volatile__ (																			\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    r0[0], sp"																				\

+  );																								\

+}

+

+/*

+ * portRESTORE_CONTEXT() for SupervisorCALL exception.

+ */

+#define portRESTORE_CONTEXT_SCALL()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* Restore all registers */																		\

+																									\

+  /* Set SP to point to new stack */																\

+  __asm__ __volatile__ (																			\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "ld.w    sp, r0[0]"																				\

+  );																								\

+																									\

+  /* Leave pxCurrentTCB variable access critical section */											\

+  portEXIT_CRITICAL();																				\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Restore ulCriticalNesting variable */														\

+    "ld.w    r0, sp++																				\n\t"\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "st.w    r8[0], r0																				\n\t"\

+																									\

+    /* skip PC and SR */																			\

+    /* do not use SP if interrupts occurs, SP must be left at bottom of stack */					\

+    "sub     r7, sp, -10*4																			\n\t"\

+    /* Restore r8-r12 and LR */																		\

+    "ldm     r7++, r8-r12, lr																		\n\t"\

+																									\

+    /* RETS will take care of the extra PC and SR restore. */										\

+    /* So, we have to prepare the stack for this. */												\

+    "ld.w    r0, r7[-8*4]																			\n\t" /* Read SR */\

+    "st.w    r7[-2*4], r0																			\n\t" /* Copy SR */\

+    "ld.w    r0, r7[-7*4]																			\n\t" /* Read PC */\

+    "st.w    r7[-1*4], r0																			\n\t" /* Copy PC */\

+																									\

+    /* Restore R0..R7 */																			\

+    "ldm     sp++, r0-r7																			\n\t"\

+																									\

+    "sub     sp, -6*4																				\n\t"\

+																									\

+    "rets"																							\

+  );																								\

+																									\

+  /* Force import of global symbols from assembly */												\

+  ulCriticalNesting;																				\

+  pxCurrentTCB;																						\

+}

+

+

+/*

+ * The ISR used depends on whether the cooperative or

+ * the preemptive scheduler is being used.

+ */

+#if configUSE_PREEMPTION == 0

+

+/*

+ * ISR entry and exit macros.  These are only required if a task switch

+ * is required from the ISR.

+ */

+#define portENTER_SWITCHING_ISR()																	\

+{																									\

+  /* Save R0..R7 */																					\

+  __asm__ __volatile__ ("stm     --sp, r0-r7");														\

+																									\

+  /* With the cooperative scheduler, as there is no context switch by interrupt, */					\

+  /* there is also no context save. */																\

+}

+

+/*

+ * Input parameter: in R12, boolean. Perform a vTaskSwitchContext() if 1

+ */

+#define portEXIT_SWITCHING_ISR()																	\

+{																									\

+  __asm__ __volatile__ (																			\

+    /* Restore R0..R7 */																			\

+    "ldm     sp++, r0-r7																			\n\t"\

+																									\

+    /* With the cooperative scheduler, as there is no context switch by interrupt, */				\

+    /* there is also no context restore. */															\

+    "rete"																							\

+  );																								\

+}

+

+#else

+

+/*

+ * ISR entry and exit macros.  These are only required if a task switch

+ * is required from the ISR.

+ */

+#define portENTER_SWITCHING_ISR()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  /* When we come here */																			\

+  /* Registers R8..R12, LR, PC and SR had already been pushed to system stack */					\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Save R0..R7 */																				\

+    "stm     --sp, r0-r7																			\n\t"\

+																									\

+    /* Save ulCriticalNesting variable  - R0 is overwritten */										\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    --sp, r0																				\n\t"\

+																									\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */	\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+    /* level and allow other lower interrupt level to occur). */									\

+    /* In this case we don't want to do a task switch because we don't know what the stack */		\

+    /* currently looks like (we don't know what the interrupted interrupt handler was doing). */	\

+    /* Saving SP in pxCurrentTCB and then later restoring it (thinking restoring the task) */		\

+    /* will just be restoring the interrupt handler, no way!!! */									\

+    /* So, since we won't do a vTaskSwitchContext(), it's of no use to save SP. */					\

+    "ld.w    r0, sp[9*4]																			\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																			\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																					\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_ISR_SKIP_SAVE_CONTEXT_"ASTRINGZ(__LINE__)"										\n\t"\

+																									\

+    /* Store SP in the first member of the structure pointed to by pxCurrentTCB */					\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "st.w    r0[0], sp																				\n"\

+																									\

+    "LABEL_ISR_SKIP_SAVE_CONTEXT_"ASTRINGZ(__LINE__)":"												\

+  );																								\

+}

+

+

+/*

+ * Input parameter: in R12, boolean. Perform a vTaskSwitchContext() if 1

+ */

+#define portEXIT_SWITCHING_ISR()																	\

+{																									\

+  extern volatile unsigned portLONG ulCriticalNesting;												\

+  extern volatile void *volatile pxCurrentTCB;														\

+																									\

+  __asm__ __volatile__ (																			\

+    /* Check if INT0 or higher were being handled (case where the OS tick interrupted another */	\

+    /* interrupt handler (which was of a higher priority level but decided to lower its priority */	\

+    /* level and allow other lower interrupt level to occur). */									\

+    /* In this case it's of no use to switch context and restore a new SP because we purposedly */	\

+    /* did not previously save SP in its TCB. */													\

+    "ld.w    r0, sp[9*4]																			\n\t" /* Read SR in stack */\

+    "bfextu  r0, r0, 22, 3																			\n\t" /* Extract the mode bits to R0. */\

+    "cp.w    r0, 1																					\n\t" /* Compare the mode bits with supervisor mode(b'001) */\

+    "brhi    LABEL_ISR_SKIP_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)"									\n\t"\

+																									\

+    /* If a switch is required then we just need to call */											\

+    /* vTaskSwitchContext() as the context has already been */										\

+    /* saved. */																					\

+    "cp.w    r12, 1																					\n\t" /* Check if Switch context is required. */\

+    "brne    LABEL_ISR_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)":C"										\

+  );																								\

+																									\

+  /* A critical section has to be used here because vTaskSwitchContext handles FreeRTOS linked lists. */\

+  portENTER_CRITICAL();																				\

+  vTaskSwitchContext();																				\

+  portEXIT_CRITICAL();																				\

+																									\

+  __asm__ __volatile__ (																			\

+    "LABEL_ISR_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)":												\n\t"\

+    /* Restore the context of which ever task is now the highest */									\

+    /* priority that is ready to run. */															\

+																									\

+    /* Restore all registers */																		\

+																									\

+    /* Set SP to point to new stack */																\

+    "mov     r8, LWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(pxCurrentTCB)")														\n\t"\

+    "ld.w    r0, r8[0]																				\n\t"\

+    "ld.w    sp, r0[0]																				\n"\

+																									\

+    "LABEL_ISR_SKIP_RESTORE_CONTEXT_"ASTRINGZ(__LINE__)":											\n\t"\

+																									\

+    /* Restore ulCriticalNesting variable */														\

+    "ld.w    r0, sp++																				\n\t"\

+    "mov     r8, LWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "orh     r8, HWRD("ASTRINGZ(ulCriticalNesting)")												\n\t"\

+    "st.w    r8[0], r0																				\n\t"\

+																									\

+    /* Restore R0..R7 */																			\

+    "ldm     sp++, r0-r7																			\n\t"\

+																									\

+    /* Now, the stack should be R8..R12, LR, PC and SR  */											\

+    "rete"																							\

+  );																								\

+																									\

+  /* Force import of global symbols from assembly */												\

+  ulCriticalNesting;																				\

+  pxCurrentTCB;																						\

+}

+

+#endif

+

+

+#define portYIELD()                 {__asm__ __volatile__ ("scall");}

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

diff --git a/FreeRTOS/Source/portable/IAR/AVR32_UC3/read.c b/FreeRTOS/Source/portable/IAR/AVR32_UC3/read.c
new file mode 100644
index 0000000..925c196
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AVR32_UC3/read.c
@@ -0,0 +1,93 @@
+/*This file is prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief System-specific implementation of the \ref __read function used by

+          the standard library.

+ *

+ * - Compiler:           IAR EWAVR32

+ * - Supported devices:  All AVR32 devices with a USART module can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ ******************************************************************************/

+

+/* Copyright (c) 2007, Atmel Corporation All rights reserved.

+ *

+ * Redistribution and use in source and binary forms, with or without

+ * modification, are permitted provided that the following conditions are met:

+ *

+ * 1. Redistributions of source code must retain the above copyright notice,

+ * this list of conditions and the following disclaimer.

+ *

+ * 2. Redistributions in binary form must reproduce the above copyright notice,

+ * this list of conditions and the following disclaimer in the documentation

+ * and/or other materials provided with the distribution.

+ *

+ * 3. The name of ATMEL may not be used to endorse or promote products derived

+ * from this software without specific prior written permission.

+ *

+ * THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED

+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND

+ * SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT,

+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES

+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;

+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND

+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT

+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF

+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+ */

+

+

+#include <yfuns.h>

+#include <avr32/io.h>

+#include "usart.h"

+

+

+_STD_BEGIN

+

+

+#pragma module_name = "?__read"

+

+

+extern volatile avr32_usart_t *volatile stdio_usart_base;

+

+

+/*! \brief Reads a number of bytes, at most \a size, into the memory area

+ *         pointed to by \a buffer.

+ *

+ * \param handle File handle to read from.

+ * \param buffer Pointer to buffer to write read bytes to.

+ * \param size Number of bytes to read.

+ *

+ * \return The number of bytes read, \c 0 at the end of the file, or

+ *         \c _LLIO_ERROR on failure.

+ */

+size_t __read(int handle, unsigned char *buffer, size_t size)

+{

+  int nChars = 0;

+

+  // This implementation only reads from stdin.

+  // For all other file handles, it returns failure.

+  if (handle != _LLIO_STDIN)

+  {

+    return _LLIO_ERROR;

+  }

+

+  for (; size > 0; --size)

+  {

+    int c = usart_getchar(stdio_usart_base);

+    if (c < 0)

+      break;

+

+    *buffer++ = c;

+    ++nChars;

+  }

+

+  return nChars;

+}

+

+

+_STD_END

diff --git a/FreeRTOS/Source/portable/IAR/AVR32_UC3/write.c b/FreeRTOS/Source/portable/IAR/AVR32_UC3/write.c
new file mode 100644
index 0000000..7dc8a71
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AVR32_UC3/write.c
@@ -0,0 +1,103 @@
+/*This file is prepared for Doxygen automatic documentation generation.*/

+/*! \file *********************************************************************

+ *

+ * \brief System-specific implementation of the \ref __write function used by

+          the standard library.

+ *

+ * - Compiler:           IAR EWAVR32

+ * - Supported devices:  All AVR32 devices with a USART module can be used.

+ * - AppNote:

+ *

+ * \author               Atmel Corporation: http://www.atmel.com \n

+ *                       Support and FAQ: http://support.atmel.no/

+ *

+ ******************************************************************************/

+

+/* Copyright (c) 2007, Atmel Corporation All rights reserved.

+ *

+ * Redistribution and use in source and binary forms, with or without

+ * modification, are permitted provided that the following conditions are met:

+ *

+ * 1. Redistributions of source code must retain the above copyright notice,

+ * this list of conditions and the following disclaimer.

+ *

+ * 2. Redistributions in binary form must reproduce the above copyright notice,

+ * this list of conditions and the following disclaimer in the documentation

+ * and/or other materials provided with the distribution.

+ *

+ * 3. The name of ATMEL may not be used to endorse or promote products derived

+ * from this software without specific prior written permission.

+ *

+ * THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED

+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND

+ * SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT,

+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES

+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;

+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND

+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT

+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF

+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+ */

+

+

+#include <yfuns.h>

+#include <avr32/io.h>

+#include "usart.h"

+

+

+_STD_BEGIN

+

+

+#pragma module_name = "?__write"

+

+

+//! Pointer to the base of the USART module instance to use for stdio.

+__no_init volatile avr32_usart_t *volatile stdio_usart_base;

+

+

+/*! \brief Writes a number of bytes, at most \a size, from the memory area

+ *         pointed to by \a buffer.

+ *

+ * If \a buffer is zero then \ref __write performs flushing of internal buffers,

+ * if any. In this case, \a handle can be \c -1 to indicate that all handles

+ * should be flushed.

+ *

+ * \param handle File handle to write to.

+ * \param buffer Pointer to buffer to read bytes to write from.

+ * \param size Number of bytes to write.

+ *

+ * \return The number of bytes written, or \c _LLIO_ERROR on failure.

+ */

+size_t __write(int handle, const unsigned char *buffer, size_t size)

+{

+  size_t nChars = 0;

+

+  if (buffer == 0)

+  {

+    // This means that we should flush internal buffers.

+    return 0;

+  }

+

+  // This implementation only writes to stdout and stderr.

+  // For all other file handles, it returns failure.

+  if (handle != _LLIO_STDOUT && handle != _LLIO_STDERR)

+  {

+    return _LLIO_ERROR;

+  }

+

+  for (; size != 0; --size)

+  {

+    if (usart_putchar(stdio_usart_base, *buffer++) < 0)

+    {

+      return _LLIO_ERROR;

+    }

+

+    ++nChars;

+  }

+

+  return nChars;

+}

+

+

+_STD_END

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64.h
new file mode 100644
index 0000000..8f9ddb4
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64.h
@@ -0,0 +1,1914 @@
+// ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+// ----------------------------------------------------------------------------

+//  The software is delivered "AS IS" without warranty or condition of any

+//  kind, either express, implied or statutory. This includes without

+//  limitation any warranty or condition with respect to merchantability or

+//  fitness for any particular purpose, or against the infringements of

+//  intellectual property rights of others.

+// ----------------------------------------------------------------------------

+// File Name           : AT91SAM7S64.h

+// Object              : AT91SAM7S64 definitions

+// Generated           : AT91 SW Application Group  07/16/2004 (07:43:08)

+// 

+// CVS Reference       : /AT91SAM7S64.pl/1.12/Mon Jul 12 13:02:30 2004//

+// CVS Reference       : /SYSC_SAM7Sxx.pl/1.5/Mon Jul 12 16:22:12 2004//

+// CVS Reference       : /MC_SAM02.pl/1.3/Wed Mar 10 08:37:04 2004//

+// CVS Reference       : /UDP_1765B.pl/1.3/Fri Aug  2 14:45:38 2002//

+// CVS Reference       : /AIC_1796B.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//

+// CVS Reference       : /lib_pmc_SAM.h/1.6/Tue Apr 27 13:53:52 2004//

+// CVS Reference       : /PIO_1725D.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//

+// CVS Reference       : /DBGU_1754A.pl/1.4/Fri Jan 31 12:18:24 2003//

+// CVS Reference       : /US_1739C.pl/1.2/Mon Jul 12 17:26:24 2004//

+// CVS Reference       : /SPI2.pl/1.2/Fri Oct 17 08:13:40 2003//

+// CVS Reference       : /SSC_1762A.pl/1.2/Fri Nov  8 13:26:40 2002//

+// CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+// CVS Reference       : /TWI_1761B.pl/1.4/Fri Feb  7 10:30:08 2003//

+// CVS Reference       : /PDC_1734B.pl/1.2/Thu Nov 21 16:38:24 2002//

+// CVS Reference       : /ADC_SAM.pl/1.7/Fri Oct 17 08:12:38 2003//

+// CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+// ----------------------------------------------------------------------------

+

+#ifndef AT91SAM7S64_H

+#define AT91SAM7S64_H

+

+typedef volatile unsigned int AT91_REG;// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+typedef struct _AT91S_SYSC {

+	AT91_REG	 SYSC_AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 SYSC_AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 SYSC_AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 SYSC_AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 SYSC_AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 SYSC_AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 SYSC_AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 SYSC_AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SYSC_AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 SYSC_AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 SYSC_AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 SYSC_AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 SYSC_AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 SYSC_AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 SYSC_AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 SYSC_AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 SYSC_AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 SYSC_AIC_FFSR; 	// Fast Forcing Status Register

+	AT91_REG	 Reserved2[45]; 	// 

+	AT91_REG	 SYSC_DBGU_CR; 	// Control Register

+	AT91_REG	 SYSC_DBGU_MR; 	// Mode Register

+	AT91_REG	 SYSC_DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 SYSC_DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SYSC_DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 SYSC_DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 SYSC_DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 SYSC_DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 SYSC_DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved3[7]; 	// 

+	AT91_REG	 SYSC_DBGU_C1R; 	// Chip ID1 Register

+	AT91_REG	 SYSC_DBGU_C2R; 	// Chip ID2 Register

+	AT91_REG	 SYSC_DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved4[45]; 	// 

+	AT91_REG	 SYSC_DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 SYSC_DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 SYSC_DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SYSC_DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 SYSC_DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SYSC_DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SYSC_DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SYSC_DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SYSC_DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SYSC_DBGU_PTSR; 	// PDC Transfer Status Register

+	AT91_REG	 Reserved5[54]; 	// 

+	AT91_REG	 SYSC_PIOA_PER; 	// PIO Enable Register

+	AT91_REG	 SYSC_PIOA_PDR; 	// PIO Disable Register

+	AT91_REG	 SYSC_PIOA_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved6[1]; 	// 

+	AT91_REG	 SYSC_PIOA_OER; 	// Output Enable Register

+	AT91_REG	 SYSC_PIOA_ODR; 	// Output Disable Registerr

+	AT91_REG	 SYSC_PIOA_OSR; 	// Output Status Register

+	AT91_REG	 Reserved7[1]; 	// 

+	AT91_REG	 SYSC_PIOA_IFER; 	// Input Filter Enable Register

+	AT91_REG	 SYSC_PIOA_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 SYSC_PIOA_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved8[1]; 	// 

+	AT91_REG	 SYSC_PIOA_SODR; 	// Set Output Data Register

+	AT91_REG	 SYSC_PIOA_CODR; 	// Clear Output Data Register

+	AT91_REG	 SYSC_PIOA_ODSR; 	// Output Data Status Register

+	AT91_REG	 SYSC_PIOA_PDSR; 	// Pin Data Status Register

+	AT91_REG	 SYSC_PIOA_IER; 	// Interrupt Enable Register

+	AT91_REG	 SYSC_PIOA_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SYSC_PIOA_IMR; 	// Interrupt Mask Register

+	AT91_REG	 SYSC_PIOA_ISR; 	// Interrupt Status Register

+	AT91_REG	 SYSC_PIOA_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 SYSC_PIOA_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 SYSC_PIOA_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved9[1]; 	// 

+	AT91_REG	 SYSC_PIOA_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 SYSC_PIOA_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 SYSC_PIOA_PPUSR; 	// Pad Pull-up Status Register

+	AT91_REG	 Reserved10[1]; 	// 

+	AT91_REG	 SYSC_PIOA_ASR; 	// Select A Register

+	AT91_REG	 SYSC_PIOA_BSR; 	// Select B Register

+	AT91_REG	 SYSC_PIOA_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved11[9]; 	// 

+	AT91_REG	 SYSC_PIOA_OWER; 	// Output Write Enable Register

+	AT91_REG	 SYSC_PIOA_OWDR; 	// Output Write Disable Register

+	AT91_REG	 SYSC_PIOA_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved12[469]; 	// 

+	AT91_REG	 SYSC_PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 SYSC_PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 SYSC_PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved13[1]; 	// 

+	AT91_REG	 SYSC_PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 SYSC_PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 SYSC_PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved14[1]; 	// 

+	AT91_REG	 SYSC_PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 SYSC_PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved15[1]; 	// 

+	AT91_REG	 SYSC_PMC_PLLR; 	// PLL Register

+	AT91_REG	 SYSC_PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved16[3]; 	// 

+	AT91_REG	 SYSC_PMC_PCKR[8]; 	// Programmable Clock Register

+	AT91_REG	 SYSC_PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SYSC_PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SYSC_PMC_SR; 	// Status Register

+	AT91_REG	 SYSC_PMC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved17[36]; 	// 

+	AT91_REG	 SYSC_RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 SYSC_RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 SYSC_RSTC_RMR; 	// Reset Mode Register

+	AT91_REG	 Reserved18[5]; 	// 

+	AT91_REG	 SYSC_RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 SYSC_RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 SYSC_RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 SYSC_RTTC_RTSR; 	// Real-time Status Register

+	AT91_REG	 SYSC_PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 SYSC_PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 SYSC_PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 SYSC_PITC_PIIR; 	// Period Interval Image Register

+	AT91_REG	 SYSC_WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 SYSC_WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 SYSC_WDTC_WDSR; 	// Watchdog Status Register

+	AT91_REG	 Reserved19[5]; 	// 

+	AT91_REG	 SYSC_SYSC_VRPM; 	// Voltage Regulator Power Mode Register

+} AT91S_SYSC, *AT91PS_SYSC;

+

+// -------- VRPM : (SYSC Offset: 0xd60) Voltage Regulator Power Mode Register -------- 

+#define AT91C_SYSC_PSTDBY     ((unsigned int) 0x1 <<  0) // (SYSC) Voltage Regulator Power Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+typedef struct _AT91S_AIC {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+} AT91S_AIC, *AT91PS_AIC;

+

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR       ((unsigned int) 0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               ((unsigned int) 0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              ((unsigned int) 0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE     ((unsigned int) 0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_LEVEL_SENSITIVE  ((unsigned int) 0x0 <<  5) // (AIC) Internal Sources Code Label Level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_EDGE_TRIGGERED   ((unsigned int) 0x1 <<  5) // (AIC) Internal Sources Code Label Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_HIGH_LEVEL       ((unsigned int) 0x2 <<  5) // (AIC) External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_POSITIVE_EDGE    ((unsigned int) 0x3 <<  5) // (AIC) External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ        ((unsigned int) 0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ        ((unsigned int) 0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT    ((unsigned int) 0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK    ((unsigned int) 0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+typedef struct _AT91S_DBGU {

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved0[7]; 	// 

+	AT91_REG	 DBGU_C1R; 	// Chip ID1 Register

+	AT91_REG	 DBGU_C2R; 	// Chip ID2 Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved1[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+} AT91S_DBGU, *AT91PS_DBGU;

+

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX        ((unsigned int) 0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX        ((unsigned int) 0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN         ((unsigned int) 0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS        ((unsigned int) 0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN         ((unsigned int) 0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS        ((unsigned int) 0x1 <<  7) // (DBGU) Transmitter Disable

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR          ((unsigned int) 0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 ((unsigned int) 0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  ((unsigned int) 0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                ((unsigned int) 0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 ((unsigned int) 0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 ((unsigned int) 0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           ((unsigned int) 0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE       ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY        ((unsigned int) 0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY        ((unsigned int) 0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX        ((unsigned int) 0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX        ((unsigned int) 0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE         ((unsigned int) 0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME        ((unsigned int) 0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE         ((unsigned int) 0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY      ((unsigned int) 0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE       ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF       ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX      ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX      ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST  ((unsigned int) 0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral Data Controller

+// *****************************************************************************

+typedef struct _AT91S_PDC {

+	AT91_REG	 PDC_RPR; 	// Receive Pointer Register

+	AT91_REG	 PDC_RCR; 	// Receive Counter Register

+	AT91_REG	 PDC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 PDC_TCR; 	// Transmit Counter Register

+	AT91_REG	 PDC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 PDC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 PDC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 PDC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 PDC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 PDC_PTSR; 	// PDC Transfer Status Register

+} AT91S_PDC, *AT91PS_PDC;

+

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN       ((unsigned int) 0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS      ((unsigned int) 0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN       ((unsigned int) 0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS      ((unsigned int) 0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+typedef struct _AT91S_PIO {

+	AT91_REG	 PIO_PER; 	// PIO Enable Register

+	AT91_REG	 PIO_PDR; 	// PIO Disable Register

+	AT91_REG	 PIO_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PIO_OER; 	// Output Enable Register

+	AT91_REG	 PIO_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIO_OSR; 	// Output Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PIO_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIO_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIO_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PIO_SODR; 	// Set Output Data Register

+	AT91_REG	 PIO_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIO_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIO_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIO_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIO_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIO_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIO_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIO_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIO_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIO_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved3[1]; 	// 

+	AT91_REG	 PIO_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIO_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIO_PPUSR; 	// Pad Pull-up Status Register

+	AT91_REG	 Reserved4[1]; 	// 

+	AT91_REG	 PIO_ASR; 	// Select A Register

+	AT91_REG	 PIO_BSR; 	// Select B Register

+	AT91_REG	 PIO_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved5[9]; 	// 

+	AT91_REG	 PIO_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIO_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIO_OWSR; 	// Output Write Status Register

+} AT91S_PIO, *AT91PS_PIO;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+typedef struct _AT91S_CKGR {

+	AT91_REG	 CKGR_MOR; 	// Main Oscillator Register

+	AT91_REG	 CKGR_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 CKGR_PLLR; 	// PLL Register

+} AT91S_CKGR, *AT91PS_CKGR;

+

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN     ((unsigned int) 0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS  ((unsigned int) 0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT    ((unsigned int) 0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF      ((unsigned int) 0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY    ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV        ((unsigned int) 0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    ((unsigned int) 0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               ((unsigned int) 0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT   ((unsigned int) 0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT        ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL        ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV     ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+typedef struct _AT91S_PMC {

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved3[3]; 	// 

+	AT91_REG	 PMC_PCKR[8]; 	// Programmable Clock Register

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+} AT91S_PMC, *AT91PS_PMC;

+

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK         ((unsigned int) 0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP         ((unsigned int) 0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0        ((unsigned int) 0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1        ((unsigned int) 0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2        ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3        ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS         ((unsigned int) 0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             ((unsigned int) 0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             ((unsigned int) 0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              ((unsigned int) 0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES        ((unsigned int) 0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  ((unsigned int) 0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                ((unsigned int) 0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                ((unsigned int) 0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                ((unsigned int) 0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               ((unsigned int) 0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               ((unsigned int) 0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               ((unsigned int) 0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS       ((unsigned int) 0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK        ((unsigned int) 0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY      ((unsigned int) 0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY     ((unsigned int) 0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY     ((unsigned int) 0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY     ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY     ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RSTC {

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+} AT91S_RSTC, *AT91PS_RSTC;

+

+// -------- SYSC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_SYSC_PROCRST    ((unsigned int) 0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_SYSC_ICERST     ((unsigned int) 0x1 <<  1) // (RSTC) ICE Interface Reset

+#define AT91C_SYSC_PERRST     ((unsigned int) 0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_SYSC_EXTRST     ((unsigned int) 0x1 <<  3) // (RSTC) External Reset

+#define AT91C_SYSC_KEY        ((unsigned int) 0xFF << 24) // (RSTC) Password

+// -------- SYSC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_SYSC_URSTS      ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_SYSC_BODSTS     ((unsigned int) 0x1 <<  1) // (RSTC) Brown-out Detection Status

+#define AT91C_SYSC_RSTTYP     ((unsigned int) 0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_SYSC_RSTTYP_POWERUP              ((unsigned int) 0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_SYSC_RSTTYP_WATCHDOG             ((unsigned int) 0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_SYSC_RSTTYP_SOFTWARE             ((unsigned int) 0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_SYSC_RSTTYP_USER                 ((unsigned int) 0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_SYSC_RSTTYP_BROWNOUT             ((unsigned int) 0x5 <<  8) // (RSTC) Brown-out Reset.

+#define AT91C_SYSC_NRSTL      ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_SYSC_SRCMP      ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- SYSC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_SYSC_URSTEN     ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_SYSC_URSTIEN    ((unsigned int) 0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_SYSC_ERSTL      ((unsigned int) 0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_SYSC_BODIEN     ((unsigned int) 0x1 << 16) // (RSTC) Brown-out Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RTTC {

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+} AT91S_RTTC, *AT91PS_RTTC;

+

+// -------- SYSC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_SYSC_RTPRES     ((unsigned int) 0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_SYSC_ALMIEN     ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_SYSC_RTTINCIEN  ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_SYSC_RTTRST     ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- SYSC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_SYSC_ALMV       ((unsigned int) 0x0 <<  0) // (RTTC) Alarm Value

+// -------- SYSC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_SYSC_CRTV       ((unsigned int) 0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- SYSC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_SYSC_ALMS       ((unsigned int) 0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_SYSC_RTTINC     ((unsigned int) 0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PITC {

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+} AT91S_PITC, *AT91PS_PITC;

+

+// -------- SYSC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_SYSC_PIV        ((unsigned int) 0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_SYSC_PITEN      ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_SYSC_PITIEN     ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- SYSC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_SYSC_PITS       ((unsigned int) 0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- SYSC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_SYSC_CPIV       ((unsigned int) 0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_SYSC_PICNT      ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- SYSC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_WDTC {

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+} AT91S_WDTC, *AT91PS_WDTC;

+

+// -------- SYSC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_SYSC_WDRSTT     ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Restart

+// -------- SYSC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_SYSC_WDV        ((unsigned int) 0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_SYSC_WDFIEN     ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_SYSC_WDRSTEN    ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_SYSC_WDRPROC    ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_SYSC_WDDIS      ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_SYSC_WDD        ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_SYSC_WDDBGHLT   ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_SYSC_WDIDLEHLT  ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- SYSC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_SYSC_WDUNF      ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_SYSC_WDERR      ((unsigned int) 0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_MC {

+	AT91_REG	 MC_RCR; 	// MC Remap Control Register

+	AT91_REG	 MC_ASR; 	// MC Abort Status Register

+	AT91_REG	 MC_AASR; 	// MC Abort Address Status Register

+	AT91_REG	 Reserved0[21]; 	// 

+	AT91_REG	 MC_FMR; 	// MC Flash Mode Register

+	AT91_REG	 MC_FCR; 	// MC Flash Command Register

+	AT91_REG	 MC_FSR; 	// MC Flash Status Register

+} AT91S_MC, *AT91PS_MC;

+

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB          ((unsigned int) 0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD       ((unsigned int) 0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD       ((unsigned int) 0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ        ((unsigned int) 0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 ((unsigned int) 0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                ((unsigned int) 0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 ((unsigned int) 0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP       ((unsigned int) 0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                ((unsigned int) 0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                ((unsigned int) 0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                ((unsigned int) 0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0         ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1         ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0       ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1       ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY         ((unsigned int) 0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE        ((unsigned int) 0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE        ((unsigned int) 0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP         ((unsigned int) 0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS          ((unsigned int) 0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 ((unsigned int) 0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 ((unsigned int) 0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 ((unsigned int) 0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 ((unsigned int) 0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN         ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD         ((unsigned int) 0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         ((unsigned int) 0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN        ((unsigned int) 0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY          ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY     ((unsigned int) 0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0       ((unsigned int) 0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1       ((unsigned int) 0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2       ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3       ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4       ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5       ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6       ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7       ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0       ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1       ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2       ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3       ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4       ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5       ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6       ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7       ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8       ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9       ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10      ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11      ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12      ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13      ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14      ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15      ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+typedef struct _AT91S_SPI {

+	AT91_REG	 SPI_CR; 	// Control Register

+	AT91_REG	 SPI_MR; 	// Mode Register

+	AT91_REG	 SPI_RDR; 	// Receive Data Register

+	AT91_REG	 SPI_TDR; 	// Transmit Data Register

+	AT91_REG	 SPI_SR; 	// Status Register

+	AT91_REG	 SPI_IER; 	// Interrupt Enable Register

+	AT91_REG	 SPI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SPI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91_REG	 SPI_CSR[4]; 	// Chip Select Register

+	AT91_REG	 Reserved1[48]; 	// 

+	AT91_REG	 SPI_RPR; 	// Receive Pointer Register

+	AT91_REG	 SPI_RCR; 	// Receive Counter Register

+	AT91_REG	 SPI_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SPI_TCR; 	// Transmit Counter Register

+	AT91_REG	 SPI_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SPI_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SPI_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SPI_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SPI_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SPI_PTSR; 	// PDC Transfer Status Register

+} AT91S_SPI, *AT91PS_SPI;

+

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN       ((unsigned int) 0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS      ((unsigned int) 0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST       ((unsigned int) 0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER    ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR        ((unsigned int) 0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS          ((unsigned int) 0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                ((unsigned int) 0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             ((unsigned int) 0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC      ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV        ((unsigned int) 0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS     ((unsigned int) 0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB         ((unsigned int) 0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS         ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD          ((unsigned int) 0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD          ((unsigned int) 0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF        ((unsigned int) 0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE        ((unsigned int) 0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF        ((unsigned int) 0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES       ((unsigned int) 0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX       ((unsigned int) 0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX       ((unsigned int) 0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF      ((unsigned int) 0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE      ((unsigned int) 0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR        ((unsigned int) 0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY     ((unsigned int) 0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS      ((unsigned int) 0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL        ((unsigned int) 0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA       ((unsigned int) 0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT       ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS        ((unsigned int) 0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    ((unsigned int) 0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    ((unsigned int) 0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   ((unsigned int) 0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   ((unsigned int) 0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   ((unsigned int) 0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   ((unsigned int) 0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   ((unsigned int) 0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   ((unsigned int) 0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   ((unsigned int) 0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR        ((unsigned int) 0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS       ((unsigned int) 0xFF << 16) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBCT      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+typedef struct _AT91S_ADC {

+	AT91_REG	 ADC_CR; 	// ADC Control Register

+	AT91_REG	 ADC_MR; 	// ADC Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 ADC_CHER; 	// ADC Channel Enable Register

+	AT91_REG	 ADC_CHDR; 	// ADC Channel Disable Register

+	AT91_REG	 ADC_CHSR; 	// ADC Channel Status Register

+	AT91_REG	 ADC_SR; 	// ADC Status Register

+	AT91_REG	 ADC_LCDR; 	// ADC Last Converted Data Register

+	AT91_REG	 ADC_IER; 	// ADC Interrupt Enable Register

+	AT91_REG	 ADC_IDR; 	// ADC Interrupt Disable Register

+	AT91_REG	 ADC_IMR; 	// ADC Interrupt Mask Register

+	AT91_REG	 ADC_CDR0; 	// ADC Channel Data Register 0

+	AT91_REG	 ADC_CDR1; 	// ADC Channel Data Register 1

+	AT91_REG	 ADC_CDR2; 	// ADC Channel Data Register 2

+	AT91_REG	 ADC_CDR3; 	// ADC Channel Data Register 3

+	AT91_REG	 ADC_CDR4; 	// ADC Channel Data Register 4

+	AT91_REG	 ADC_CDR5; 	// ADC Channel Data Register 5

+	AT91_REG	 ADC_CDR6; 	// ADC Channel Data Register 6

+	AT91_REG	 ADC_CDR7; 	// ADC Channel Data Register 7

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 ADC_RPR; 	// Receive Pointer Register

+	AT91_REG	 ADC_RCR; 	// Receive Counter Register

+	AT91_REG	 ADC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 ADC_TCR; 	// Transmit Counter Register

+	AT91_REG	 ADC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 ADC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 ADC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 ADC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 ADC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 ADC_PTSR; 	// PDC Transfer Status Register

+} AT91S_ADC, *AT91PS_ADC;

+

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST       ((unsigned int) 0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START       ((unsigned int) 0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN       ((unsigned int) 0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  ((unsigned int) 0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   ((unsigned int) 0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL      ((unsigned int) 0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                ((unsigned int) 0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                ((unsigned int) 0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                ((unsigned int) 0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                ((unsigned int) 0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                ((unsigned int) 0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                ((unsigned int) 0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  ((unsigned int) 0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES      ((unsigned int) 0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               ((unsigned int) 0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                ((unsigned int) 0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP       ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          ((unsigned int) 0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL     ((unsigned int) 0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP     ((unsigned int) 0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM       ((unsigned int) 0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0         ((unsigned int) 0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1         ((unsigned int) 0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2         ((unsigned int) 0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3         ((unsigned int) 0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4         ((unsigned int) 0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5         ((unsigned int) 0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6         ((unsigned int) 0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7         ((unsigned int) 0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0        ((unsigned int) 0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1        ((unsigned int) 0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2        ((unsigned int) 0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3        ((unsigned int) 0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4        ((unsigned int) 0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5        ((unsigned int) 0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6        ((unsigned int) 0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7        ((unsigned int) 0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0       ((unsigned int) 0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1       ((unsigned int) 0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2       ((unsigned int) 0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3       ((unsigned int) 0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4       ((unsigned int) 0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5       ((unsigned int) 0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6       ((unsigned int) 0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7       ((unsigned int) 0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY        ((unsigned int) 0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE       ((unsigned int) 0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX       ((unsigned int) 0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF      ((unsigned int) 0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA       ((unsigned int) 0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA        ((unsigned int) 0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_SSC {

+	AT91_REG	 SSC_CR; 	// Control Register

+	AT91_REG	 SSC_CMR; 	// Clock Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SSC_RCMR; 	// Receive Clock ModeRegister

+	AT91_REG	 SSC_RFMR; 	// Receive Frame Mode Register

+	AT91_REG	 SSC_TCMR; 	// Transmit Clock Mode Register

+	AT91_REG	 SSC_TFMR; 	// Transmit Frame Mode Register

+	AT91_REG	 SSC_RHR; 	// Receive Holding Register

+	AT91_REG	 SSC_THR; 	// Transmit Holding Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 SSC_RSHR; 	// Receive Sync Holding Register

+	AT91_REG	 SSC_TSHR; 	// Transmit Sync Holding Register

+	AT91_REG	 SSC_RC0R; 	// Receive Compare 0 Register

+	AT91_REG	 SSC_RC1R; 	// Receive Compare 1 Register

+	AT91_REG	 SSC_SR; 	// Status Register

+	AT91_REG	 SSC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SSC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SSC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved2[44]; 	// 

+	AT91_REG	 SSC_RPR; 	// Receive Pointer Register

+	AT91_REG	 SSC_RCR; 	// Receive Counter Register

+	AT91_REG	 SSC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SSC_TCR; 	// Transmit Counter Register

+	AT91_REG	 SSC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SSC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SSC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SSC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SSC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SSC_PTSR; 	// PDC Transfer Status Register

+} AT91S_SSC, *AT91PS_SSC;

+

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN        ((unsigned int) 0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS       ((unsigned int) 0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN        ((unsigned int) 0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS       ((unsigned int) 0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST       ((unsigned int) 0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS         ((unsigned int) 0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  ((unsigned int) 0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   ((unsigned int) 0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   ((unsigned int) 0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO         ((unsigned int) 0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 ((unsigned int) 0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            ((unsigned int) 0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              ((unsigned int) 0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI         ((unsigned int) 0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_CKG         ((unsigned int) 0x3 <<  6) // (SSC) Receive/Transmit Clock Gating Selection

+#define 	AT91C_SSC_CKG_NONE                 ((unsigned int) 0x0 <<  6) // (SSC) Receive/Transmit Clock Gating: None, continuous clock

+#define 	AT91C_SSC_CKG_LOW                  ((unsigned int) 0x1 <<  6) // (SSC) Receive/Transmit Clock enabled only if RF Low

+#define 	AT91C_SSC_CKG_HIGH                 ((unsigned int) 0x2 <<  6) // (SSC) Receive/Transmit Clock enabled only if RF High

+#define AT91C_SSC_START       ((unsigned int) 0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            ((unsigned int) 0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   ((unsigned int) 0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               ((unsigned int) 0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              ((unsigned int) 0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              ((unsigned int) 0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              ((unsigned int) 0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             ((unsigned int) 0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              ((unsigned int) 0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    ((unsigned int) 0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STOP        ((unsigned int) 0x1 << 12) // (SSC) Receive Stop Selection

+#define AT91C_SSC_STTOUT      ((unsigned int) 0x1 << 15) // (SSC) Receive/Transmit Start Output Selection

+#define AT91C_SSC_STTDLY      ((unsigned int) 0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD      ((unsigned int) 0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN      ((unsigned int) 0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP        ((unsigned int) 0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF        ((unsigned int) 0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB       ((unsigned int) 0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN       ((unsigned int) 0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS        ((unsigned int) 0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 ((unsigned int) 0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             ((unsigned int) 0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             ((unsigned int) 0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  ((unsigned int) 0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 ((unsigned int) 0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               ((unsigned int) 0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE      ((unsigned int) 0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF      ((unsigned int) 0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN       ((unsigned int) 0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY       ((unsigned int) 0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY     ((unsigned int) 0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX       ((unsigned int) 0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE      ((unsigned int) 0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY       ((unsigned int) 0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN       ((unsigned int) 0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX       ((unsigned int) 0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF      ((unsigned int) 0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_CP0         ((unsigned int) 0x1 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_CP1         ((unsigned int) 0x1 <<  9) // (SSC) Compare 1

+#define AT91C_SSC_TXSYN       ((unsigned int) 0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN       ((unsigned int) 0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA       ((unsigned int) 0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA       ((unsigned int) 0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+typedef struct _AT91S_USART {

+	AT91_REG	 US_CR; 	// Control Register

+	AT91_REG	 US_MR; 	// Mode Register

+	AT91_REG	 US_IER; 	// Interrupt Enable Register

+	AT91_REG	 US_IDR; 	// Interrupt Disable Register

+	AT91_REG	 US_IMR; 	// Interrupt Mask Register

+	AT91_REG	 US_CSR; 	// Channel Status Register

+	AT91_REG	 US_RHR; 	// Receiver Holding Register

+	AT91_REG	 US_THR; 	// Transmitter Holding Register

+	AT91_REG	 US_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 US_RTOR; 	// Receiver Time-out Register

+	AT91_REG	 US_TTGR; 	// Transmitter Time-guard Register

+	AT91_REG	 Reserved0[5]; 	// 

+	AT91_REG	 US_FIDI; 	// FI_DI_Ratio Register

+	AT91_REG	 US_NER; 	// Nb Errors Register

+	AT91_REG	 US_XXR; 	// XON_XOFF Register

+	AT91_REG	 US_IF; 	// IRDA_FILTER Register

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 US_RPR; 	// Receive Pointer Register

+	AT91_REG	 US_RCR; 	// Receive Counter Register

+	AT91_REG	 US_TPR; 	// Transmit Pointer Register

+	AT91_REG	 US_TCR; 	// Transmit Counter Register

+	AT91_REG	 US_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 US_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 US_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 US_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 US_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 US_PTSR; 	// PDC Transfer Status Register

+} AT91S_USART, *AT91PS_USART;

+

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTSTA       ((unsigned int) 0x1 <<  8) // (USART) Reset Status Bits

+#define AT91C_US_STTBRK       ((unsigned int) 0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK       ((unsigned int) 0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO        ((unsigned int) 0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA        ((unsigned int) 0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT        ((unsigned int) 0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK      ((unsigned int) 0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO        ((unsigned int) 0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN        ((unsigned int) 0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS       ((unsigned int) 0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN        ((unsigned int) 0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS       ((unsigned int) 0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE       ((unsigned int) 0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               ((unsigned int) 0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                ((unsigned int) 0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                ((unsigned int) 0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                ((unsigned int) 0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            ((unsigned int) 0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            ((unsigned int) 0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 ((unsigned int) 0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                ((unsigned int) 0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS         ((unsigned int) 0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                ((unsigned int) 0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                ((unsigned int) 0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 ((unsigned int) 0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  ((unsigned int) 0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL         ((unsigned int) 0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               ((unsigned int) 0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               ((unsigned int) 0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               ((unsigned int) 0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               ((unsigned int) 0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC         ((unsigned int) 0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP       ((unsigned int) 0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                ((unsigned int) 0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               ((unsigned int) 0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                ((unsigned int) 0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF         ((unsigned int) 0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9        ((unsigned int) 0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO         ((unsigned int) 0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER         ((unsigned int) 0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK        ((unsigned int) 0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK       ((unsigned int) 0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER     ((unsigned int) 0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER       ((unsigned int) 0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK        ((unsigned int) 0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT      ((unsigned int) 0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION    ((unsigned int) 0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK         ((unsigned int) 0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC         ((unsigned int) 0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC        ((unsigned int) 0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC        ((unsigned int) 0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC        ((unsigned int) 0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI           ((unsigned int) 0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR          ((unsigned int) 0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD          ((unsigned int) 0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS          ((unsigned int) 0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+typedef struct _AT91S_TWI {

+	AT91_REG	 TWI_CR; 	// Control Register

+	AT91_REG	 TWI_MMR; 	// Master Mode Register

+	AT91_REG	 TWI_SMR; 	// Slave Mode Register

+	AT91_REG	 TWI_IADR; 	// Internal Address Register

+	AT91_REG	 TWI_CWGR; 	// Clock Waveform Generator Register

+	AT91_REG	 Reserved0[3]; 	// 

+	AT91_REG	 TWI_SR; 	// Status Register

+	AT91_REG	 TWI_IER; 	// Interrupt Enable Register

+	AT91_REG	 TWI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TWI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TWI_RHR; 	// Receive Holding Register

+	AT91_REG	 TWI_THR; 	// Transmit Holding Register

+} AT91S_TWI, *AT91PS_TWI;

+

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START       ((unsigned int) 0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP        ((unsigned int) 0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN        ((unsigned int) 0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS       ((unsigned int) 0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SVEN        ((unsigned int) 0x1 <<  4) // (TWI) TWI Slave Transfer Enabled

+#define AT91C_TWI_SVDIS       ((unsigned int) 0x1 <<  5) // (TWI) TWI Slave Transfer Disabled

+#define AT91C_TWI_SWRST       ((unsigned int) 0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ      ((unsigned int) 0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   ((unsigned int) 0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               ((unsigned int) 0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               ((unsigned int) 0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               ((unsigned int) 0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD       ((unsigned int) 0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR        ((unsigned int) 0x7F << 16) // (TWI) Device Address

+// -------- TWI_SMR : (TWI Offset: 0x8) TWI Slave Mode Register -------- 

+#define AT91C_TWI_SADR        ((unsigned int) 0x7F << 16) // (TWI) Slave Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV       ((unsigned int) 0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV       ((unsigned int) 0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV       ((unsigned int) 0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP      ((unsigned int) 0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY       ((unsigned int) 0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY       ((unsigned int) 0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_SVREAD      ((unsigned int) 0x1 <<  3) // (TWI) Slave Read

+#define AT91C_TWI_SVACC       ((unsigned int) 0x1 <<  4) // (TWI) Slave Access

+#define AT91C_TWI_GCACC       ((unsigned int) 0x1 <<  5) // (TWI) General Call Access

+#define AT91C_TWI_OVRE        ((unsigned int) 0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE        ((unsigned int) 0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK        ((unsigned int) 0x1 <<  8) // (TWI) Not Acknowledged

+#define AT91C_TWI_ARBLST      ((unsigned int) 0x1 <<  9) // (TWI) Arbitration Lost

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_TC {

+	AT91_REG	 TC_CCR; 	// Channel Control Register

+	AT91_REG	 TC_CMR; 	// Channel Mode Register (Capture Mode / Waveform Mode)

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TC_CV; 	// Counter Value

+	AT91_REG	 TC_RA; 	// Register A

+	AT91_REG	 TC_RB; 	// Register B

+	AT91_REG	 TC_RC; 	// Register C

+	AT91_REG	 TC_SR; 	// Status Register

+	AT91_REG	 TC_IER; 	// Interrupt Enable Register

+	AT91_REG	 TC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TC_IMR; 	// Interrupt Mask Register

+} AT91S_TC, *AT91PS_TC;

+

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN        ((unsigned int) 0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS       ((unsigned int) 0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG        ((unsigned int) 0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS         ((unsigned int) 0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     ((unsigned int) 0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     ((unsigned int) 0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     ((unsigned int) 0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     ((unsigned int) 0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     ((unsigned int) 0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  ((unsigned int) 0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  ((unsigned int) 0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  ((unsigned int) 0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI         ((unsigned int) 0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST        ((unsigned int) 0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 ((unsigned int) 0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  ((unsigned int) 0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  ((unsigned int) 0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  ((unsigned int) 0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_LDBDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_CPCDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_ETRGEDG      ((unsigned int) 0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG      ((unsigned int) 0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_ABETRG       ((unsigned int) 0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_EEVT         ((unsigned int) 0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_NONE                 ((unsigned int) 0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_RISING               ((unsigned int) 0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_FALLING              ((unsigned int) 0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_BOTH                 ((unsigned int) 0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ENETRG       ((unsigned int) 0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL      ((unsigned int) 0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   ((unsigned int) 0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               ((unsigned int) 0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              ((unsigned int) 0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          ((unsigned int) 0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG       ((unsigned int) 0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE         ((unsigned int) 0x1 << 15) // (TC) 

+#define AT91C_TC_LDRA         ((unsigned int) 0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               ((unsigned int) 0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              ((unsigned int) 0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 ((unsigned int) 0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPA         ((unsigned int) 0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  ((unsigned int) 0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                ((unsigned int) 0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               ((unsigned int) 0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRB         ((unsigned int) 0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 ((unsigned int) 0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               ((unsigned int) 0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              ((unsigned int) 0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 ((unsigned int) 0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC         ((unsigned int) 0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 ((unsigned int) 0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  ((unsigned int) 0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                ((unsigned int) 0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               ((unsigned int) 0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_AEEVT        ((unsigned int) 0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 ((unsigned int) 0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  ((unsigned int) 0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                ((unsigned int) 0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               ((unsigned int) 0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG       ((unsigned int) 0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 ((unsigned int) 0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  ((unsigned int) 0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                ((unsigned int) 0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               ((unsigned int) 0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB         ((unsigned int) 0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 ((unsigned int) 0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  ((unsigned int) 0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                ((unsigned int) 0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               ((unsigned int) 0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC         ((unsigned int) 0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 ((unsigned int) 0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  ((unsigned int) 0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                ((unsigned int) 0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               ((unsigned int) 0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT        ((unsigned int) 0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 ((unsigned int) 0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  ((unsigned int) 0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                ((unsigned int) 0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               ((unsigned int) 0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG       ((unsigned int) 0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 ((unsigned int) 0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  ((unsigned int) 0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                ((unsigned int) 0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               ((unsigned int) 0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS        ((unsigned int) 0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS        ((unsigned int) 0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS         ((unsigned int) 0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS         ((unsigned int) 0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS         ((unsigned int) 0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS        ((unsigned int) 0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS        ((unsigned int) 0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRCS        ((unsigned int) 0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_ETRGS        ((unsigned int) 0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA        ((unsigned int) 0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB        ((unsigned int) 0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+typedef struct _AT91S_TCB {

+	AT91S_TC	 TCB_TC0; 	// TC Channel 0

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91S_TC	 TCB_TC1; 	// TC Channel 1

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91S_TC	 TCB_TC2; 	// TC Channel 2

+	AT91_REG	 Reserved2[4]; 	// 

+	AT91_REG	 TCB_BCR; 	// TC Block Control Register

+	AT91_REG	 TCB_BMR; 	// TC Block Mode Register

+} AT91S_TCB, *AT91PS_TCB;

+

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC        ((unsigned int) 0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S     ((unsigned int) 0x1 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                ((unsigned int) 0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 ((unsigned int) 0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                ((unsigned int) 0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                ((unsigned int) 0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S     ((unsigned int) 0x1 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                ((unsigned int) 0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 ((unsigned int) 0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                ((unsigned int) 0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                ((unsigned int) 0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S     ((unsigned int) 0x1 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                ((unsigned int) 0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 ((unsigned int) 0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                ((unsigned int) 0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA2                ((unsigned int) 0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC_CH {

+	AT91_REG	 PWMC_CMR; 	// Channel Mode Register

+	AT91_REG	 PWMC_CDTYR; 	// Channel Duty Cycle Register

+	AT91_REG	 PWMC_CPRDR; 	// Channel Period Register

+	AT91_REG	 PWMC_CCNTR; 	// Channel Counter Register

+	AT91_REG	 PWMC_CUPDR; 	// Channel Update Register

+	AT91_REG	 PWMC_Reserved[3]; 	// Reserved

+} AT91S_PWMC_CH, *AT91PS_PWMC_CH;

+

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE       ((unsigned int) 0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  ((unsigned int) 0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 ((unsigned int) 0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 ((unsigned int) 0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG       ((unsigned int) 0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL       ((unsigned int) 0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD        ((unsigned int) 0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC {

+	AT91_REG	 PWMC_MR; 	// PWMC Mode Register

+	AT91_REG	 PWMC_ENA; 	// PWMC Enable Register

+	AT91_REG	 PWMC_DIS; 	// PWMC Disable Register

+	AT91_REG	 PWMC_SR; 	// PWMC Status Register

+	AT91_REG	 PWMC_IER; 	// PWMC Interrupt Enable Register

+	AT91_REG	 PWMC_IDR; 	// PWMC Interrupt Disable Register

+	AT91_REG	 PWMC_IMR; 	// PWMC Interrupt Mask Register

+	AT91_REG	 PWMC_ISR; 	// PWMC Interrupt Status Register

+	AT91_REG	 Reserved0[55]; 	// 

+	AT91_REG	 PWMC_VR; 	// PWMC Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_PWMC_CH	 PWMC_CH[32]; 	// PWMC Channel 0

+} AT91S_PWMC, *AT91PS_PWMC;

+

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA       ((unsigned int) 0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA       ((unsigned int) 0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  ((unsigned int) 0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB       ((unsigned int) 0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB       ((unsigned int) 0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  ((unsigned int) 0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0      ((unsigned int) 0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1      ((unsigned int) 0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2      ((unsigned int) 0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3      ((unsigned int) 0x1 <<  3) // (PWMC) Channel ID 3

+#define AT91C_PWMC_CHID4      ((unsigned int) 0x1 <<  4) // (PWMC) Channel ID 4

+#define AT91C_PWMC_CHID5      ((unsigned int) 0x1 <<  5) // (PWMC) Channel ID 5

+#define AT91C_PWMC_CHID6      ((unsigned int) 0x1 <<  6) // (PWMC) Channel ID 6

+#define AT91C_PWMC_CHID7      ((unsigned int) 0x1 <<  7) // (PWMC) Channel ID 7

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+typedef struct _AT91S_UDP {

+	AT91_REG	 UDP_NUM; 	// Frame Number Register

+	AT91_REG	 UDP_GLBSTATE; 	// Global State Register

+	AT91_REG	 UDP_FADDR; 	// Function Address Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 UDP_IER; 	// Interrupt Enable Register

+	AT91_REG	 UDP_IDR; 	// Interrupt Disable Register

+	AT91_REG	 UDP_IMR; 	// Interrupt Mask Register

+	AT91_REG	 UDP_ISR; 	// Interrupt Status Register

+	AT91_REG	 UDP_ICR; 	// Interrupt Clear Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 UDP_RSTEP; 	// Reset Endpoint Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 UDP_CSR[8]; 	// Endpoint Control and Status Register

+	AT91_REG	 UDP_FDR[8]; 	// Endpoint FIFO Data Register

+} AT91S_UDP, *AT91PS_UDP;

+

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM     ((unsigned int) 0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR     ((unsigned int) 0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK      ((unsigned int) 0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN      ((unsigned int) 0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG       ((unsigned int) 0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_RMWUPE      ((unsigned int) 0x1 <<  2) // (UDP) Remote Wake Up Enable

+#define AT91C_UDP_RSMINPR     ((unsigned int) 0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD        ((unsigned int) 0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN         ((unsigned int) 0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0      ((unsigned int) 0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1      ((unsigned int) 0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2      ((unsigned int) 0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3      ((unsigned int) 0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4      ((unsigned int) 0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5      ((unsigned int) 0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_EPINT6      ((unsigned int) 0x1 <<  6) // (UDP) Endpoint 6 Interrupt

+#define AT91C_UDP_EPINT7      ((unsigned int) 0x1 <<  7) // (UDP) Endpoint 7 Interrupt

+#define AT91C_UDP_RXSUSP      ((unsigned int) 0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM       ((unsigned int) 0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM      ((unsigned int) 0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT      ((unsigned int) 0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP      ((unsigned int) 0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES   ((unsigned int) 0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0         ((unsigned int) 0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1         ((unsigned int) 0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2         ((unsigned int) 0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3         ((unsigned int) 0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4         ((unsigned int) 0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5         ((unsigned int) 0x1 <<  5) // (UDP) Reset Endpoint 5

+#define AT91C_UDP_EP6         ((unsigned int) 0x1 <<  6) // (UDP) Reset Endpoint 6

+#define AT91C_UDP_EP7         ((unsigned int) 0x1 <<  7) // (UDP) Reset Endpoint 7

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP      ((unsigned int) 0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0 ((unsigned int) 0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP     ((unsigned int) 0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR    ((unsigned int) 0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY    ((unsigned int) 0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL  ((unsigned int) 0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1 ((unsigned int) 0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR         ((unsigned int) 0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE      ((unsigned int) 0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 ((unsigned int) 0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              ((unsigned int) 0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             ((unsigned int) 0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              ((unsigned int) 0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               ((unsigned int) 0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              ((unsigned int) 0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               ((unsigned int) 0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE       ((unsigned int) 0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS       ((unsigned int) 0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT   ((unsigned int) 0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7S64

+// *****************************************************************************

+// ========== Register definition for SYSC peripheral ========== 

+#define AT91C_SYSC_SYSC_VRPM ((AT91_REG *) 	0xFFFFFD60) // (SYSC) Voltage Regulator Power Mode Register

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_ICCR  ((AT91_REG *) 	0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_IECR  ((AT91_REG *) 	0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_SMR   ((AT91_REG *) 	0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_ISCR  ((AT91_REG *) 	0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_EOICR ((AT91_REG *) 	0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_DCR   ((AT91_REG *) 	0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_FFER  ((AT91_REG *) 	0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_SVR   ((AT91_REG *) 	0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_SPU   ((AT91_REG *) 	0xFFFFF134) // (AIC) Spurious Vector Register

+#define AT91C_AIC_FFDR  ((AT91_REG *) 	0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_FVR   ((AT91_REG *) 	0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_FFSR  ((AT91_REG *) 	0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_IMR   ((AT91_REG *) 	0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_ISR   ((AT91_REG *) 	0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IVR   ((AT91_REG *) 	0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_IDCR  ((AT91_REG *) 	0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_CISR  ((AT91_REG *) 	0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IPR   ((AT91_REG *) 	0xFFFFF10C) // (AIC) Interrupt Pending Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_C2R  ((AT91_REG *) 	0xFFFFF244) // (DBGU) Chip ID2 Register

+#define AT91C_DBGU_THR  ((AT91_REG *) 	0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_CSR  ((AT91_REG *) 	0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_IDR  ((AT91_REG *) 	0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_MR   ((AT91_REG *) 	0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_FNTR ((AT91_REG *) 	0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_C1R  ((AT91_REG *) 	0xFFFFF240) // (DBGU) Chip ID1 Register

+#define AT91C_DBGU_BRGR ((AT91_REG *) 	0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_RHR  ((AT91_REG *) 	0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IMR  ((AT91_REG *) 	0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_IER  ((AT91_REG *) 	0xFFFFF208) // (DBGU) Interrupt Enable Register

+#define AT91C_DBGU_CR   ((AT91_REG *) 	0xFFFFF200) // (DBGU) Control Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TNCR ((AT91_REG *) 	0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+#define AT91C_DBGU_RNCR ((AT91_REG *) 	0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR ((AT91_REG *) 	0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR ((AT91_REG *) 	0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_RCR  ((AT91_REG *) 	0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_TCR  ((AT91_REG *) 	0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RPR  ((AT91_REG *) 	0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_TPR  ((AT91_REG *) 	0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RNPR ((AT91_REG *) 	0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR ((AT91_REG *) 	0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_IMR  ((AT91_REG *) 	0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_IER  ((AT91_REG *) 	0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_OWDR ((AT91_REG *) 	0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_ISR  ((AT91_REG *) 	0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_PPUDR ((AT91_REG *) 	0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_MDSR ((AT91_REG *) 	0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_MDER ((AT91_REG *) 	0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PER  ((AT91_REG *) 	0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_PSR  ((AT91_REG *) 	0xFFFFF408) // (PIOA) PIO Status Register

+#define AT91C_PIOA_OER  ((AT91_REG *) 	0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_BSR  ((AT91_REG *) 	0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_PPUER ((AT91_REG *) 	0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_MDDR ((AT91_REG *) 	0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_PDR  ((AT91_REG *) 	0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_ODR  ((AT91_REG *) 	0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_IFDR ((AT91_REG *) 	0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_ABSR ((AT91_REG *) 	0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_ASR  ((AT91_REG *) 	0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_PPUSR ((AT91_REG *) 	0xFFFFF468) // (PIOA) Pad Pull-up Status Register

+#define AT91C_PIOA_ODSR ((AT91_REG *) 	0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_SODR ((AT91_REG *) 	0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_IFSR ((AT91_REG *) 	0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_IFER ((AT91_REG *) 	0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_OSR  ((AT91_REG *) 	0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_IDR  ((AT91_REG *) 	0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_PDSR ((AT91_REG *) 	0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_CODR ((AT91_REG *) 	0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_OWSR ((AT91_REG *) 	0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_OWER ((AT91_REG *) 	0xFFFFF4A0) // (PIOA) Output Write Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_PLLR ((AT91_REG *) 	0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR ((AT91_REG *) 	0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+#define AT91C_CKGR_MOR  ((AT91_REG *) 	0xFFFFFC20) // (CKGR) Main Oscillator Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_SCSR  ((AT91_REG *) 	0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_SCER  ((AT91_REG *) 	0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR   ((AT91_REG *) 	0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IDR   ((AT91_REG *) 	0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_PCDR  ((AT91_REG *) 	0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCDR  ((AT91_REG *) 	0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_SR    ((AT91_REG *) 	0xFFFFFC68) // (PMC) Status Register

+#define AT91C_PMC_IER   ((AT91_REG *) 	0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_MCKR  ((AT91_REG *) 	0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_MOR   ((AT91_REG *) 	0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PCER  ((AT91_REG *) 	0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCSR  ((AT91_REG *) 	0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_PLLR  ((AT91_REG *) 	0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_MCFR  ((AT91_REG *) 	0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_PCKR  ((AT91_REG *) 	0xFFFFFC40) // (PMC) Programmable Clock Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RSR  ((AT91_REG *) 	0xFFFFFD04) // (RSTC) Reset Status Register

+#define AT91C_RSTC_RMR  ((AT91_REG *) 	0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RCR  ((AT91_REG *) 	0xFFFFFD00) // (RSTC) Reset Control Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR ((AT91_REG *) 	0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTAR ((AT91_REG *) 	0xFFFFFD24) // (RTTC) Real-time Alarm Register

+#define AT91C_RTTC_RTVR ((AT91_REG *) 	0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTMR ((AT91_REG *) 	0xFFFFFD20) // (RTTC) Real-time Mode Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIIR ((AT91_REG *) 	0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PISR ((AT91_REG *) 	0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIVR ((AT91_REG *) 	0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PIMR ((AT91_REG *) 	0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDMR ((AT91_REG *) 	0xFFFFFD44) // (WDTC) Watchdog Mode Register

+#define AT91C_WDTC_WDSR ((AT91_REG *) 	0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDCR ((AT91_REG *) 	0xFFFFFD40) // (WDTC) Watchdog Control Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_FCR    ((AT91_REG *) 	0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_ASR    ((AT91_REG *) 	0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_FSR    ((AT91_REG *) 	0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR    ((AT91_REG *) 	0xFFFFFF60) // (MC) MC Flash Mode Register

+#define AT91C_MC_AASR   ((AT91_REG *) 	0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_RCR    ((AT91_REG *) 	0xFFFFFF00) // (MC) MC Remap Control Register

+// ========== Register definition for PDC_SPI peripheral ========== 

+#define AT91C_SPI_PTCR  ((AT91_REG *) 	0xFFFE0120) // (PDC_SPI) PDC Transfer Control Register

+#define AT91C_SPI_TNPR  ((AT91_REG *) 	0xFFFE0118) // (PDC_SPI) Transmit Next Pointer Register

+#define AT91C_SPI_RNPR  ((AT91_REG *) 	0xFFFE0110) // (PDC_SPI) Receive Next Pointer Register

+#define AT91C_SPI_TPR   ((AT91_REG *) 	0xFFFE0108) // (PDC_SPI) Transmit Pointer Register

+#define AT91C_SPI_RPR   ((AT91_REG *) 	0xFFFE0100) // (PDC_SPI) Receive Pointer Register

+#define AT91C_SPI_PTSR  ((AT91_REG *) 	0xFFFE0124) // (PDC_SPI) PDC Transfer Status Register

+#define AT91C_SPI_TNCR  ((AT91_REG *) 	0xFFFE011C) // (PDC_SPI) Transmit Next Counter Register

+#define AT91C_SPI_RNCR  ((AT91_REG *) 	0xFFFE0114) // (PDC_SPI) Receive Next Counter Register

+#define AT91C_SPI_TCR   ((AT91_REG *) 	0xFFFE010C) // (PDC_SPI) Transmit Counter Register

+#define AT91C_SPI_RCR   ((AT91_REG *) 	0xFFFE0104) // (PDC_SPI) Receive Counter Register

+// ========== Register definition for SPI peripheral ========== 

+#define AT91C_SPI_CSR   ((AT91_REG *) 	0xFFFE0030) // (SPI) Chip Select Register

+#define AT91C_SPI_IDR   ((AT91_REG *) 	0xFFFE0018) // (SPI) Interrupt Disable Register

+#define AT91C_SPI_SR    ((AT91_REG *) 	0xFFFE0010) // (SPI) Status Register

+#define AT91C_SPI_RDR   ((AT91_REG *) 	0xFFFE0008) // (SPI) Receive Data Register

+#define AT91C_SPI_CR    ((AT91_REG *) 	0xFFFE0000) // (SPI) Control Register

+#define AT91C_SPI_IMR   ((AT91_REG *) 	0xFFFE001C) // (SPI) Interrupt Mask Register

+#define AT91C_SPI_IER   ((AT91_REG *) 	0xFFFE0014) // (SPI) Interrupt Enable Register

+#define AT91C_SPI_TDR   ((AT91_REG *) 	0xFFFE000C) // (SPI) Transmit Data Register

+#define AT91C_SPI_MR    ((AT91_REG *) 	0xFFFE0004) // (SPI) Mode Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTCR  ((AT91_REG *) 	0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR  ((AT91_REG *) 	0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_RNPR  ((AT91_REG *) 	0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_TPR   ((AT91_REG *) 	0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RPR   ((AT91_REG *) 	0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_PTSR  ((AT91_REG *) 	0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_TNCR  ((AT91_REG *) 	0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNCR  ((AT91_REG *) 	0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_TCR   ((AT91_REG *) 	0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_RCR   ((AT91_REG *) 	0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_IMR   ((AT91_REG *) 	0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+#define AT91C_ADC_CDR4  ((AT91_REG *) 	0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR2  ((AT91_REG *) 	0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR0  ((AT91_REG *) 	0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR7  ((AT91_REG *) 	0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR1  ((AT91_REG *) 	0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_CDR3  ((AT91_REG *) 	0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR5  ((AT91_REG *) 	0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_MR    ((AT91_REG *) 	0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_CDR6  ((AT91_REG *) 	0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_CR    ((AT91_REG *) 	0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CHER  ((AT91_REG *) 	0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR  ((AT91_REG *) 	0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_IER   ((AT91_REG *) 	0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_SR    ((AT91_REG *) 	0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CHDR  ((AT91_REG *) 	0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_IDR   ((AT91_REG *) 	0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_LCDR  ((AT91_REG *) 	0xFFFD8020) // (ADC) ADC Last Converted Data Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_PTCR  ((AT91_REG *) 	0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TNPR  ((AT91_REG *) 	0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_RNPR  ((AT91_REG *) 	0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TPR   ((AT91_REG *) 	0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_RPR   ((AT91_REG *) 	0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_PTSR  ((AT91_REG *) 	0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+#define AT91C_SSC_TNCR  ((AT91_REG *) 	0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RNCR  ((AT91_REG *) 	0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TCR   ((AT91_REG *) 	0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR   ((AT91_REG *) 	0xFFFD4104) // (PDC_SSC) Receive Counter Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RFMR  ((AT91_REG *) 	0xFFFD4014) // (SSC) Receive Frame Mode Register

+#define AT91C_SSC_CMR   ((AT91_REG *) 	0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_IDR   ((AT91_REG *) 	0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_SR    ((AT91_REG *) 	0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_RC0R  ((AT91_REG *) 	0xFFFD4038) // (SSC) Receive Compare 0 Register

+#define AT91C_SSC_RSHR  ((AT91_REG *) 	0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_RHR   ((AT91_REG *) 	0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_TCMR  ((AT91_REG *) 	0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_RCMR  ((AT91_REG *) 	0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_CR    ((AT91_REG *) 	0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR   ((AT91_REG *) 	0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_IER   ((AT91_REG *) 	0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_RC1R  ((AT91_REG *) 	0xFFFD403C) // (SSC) Receive Compare 1 Register

+#define AT91C_SSC_TSHR  ((AT91_REG *) 	0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_THR   ((AT91_REG *) 	0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_TFMR  ((AT91_REG *) 	0xFFFD401C) // (SSC) Transmit Frame Mode Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_PTSR  ((AT91_REG *) 	0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNCR  ((AT91_REG *) 	0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_RNCR  ((AT91_REG *) 	0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_TCR   ((AT91_REG *) 	0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_RCR   ((AT91_REG *) 	0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_PTCR  ((AT91_REG *) 	0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TNPR  ((AT91_REG *) 	0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RNPR  ((AT91_REG *) 	0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_TPR   ((AT91_REG *) 	0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+#define AT91C_US1_RPR   ((AT91_REG *) 	0xFFFC4100) // (PDC_US1) Receive Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_XXR   ((AT91_REG *) 	0xFFFC4048) // (US1) XON_XOFF Register

+#define AT91C_US1_RHR   ((AT91_REG *) 	0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_IMR   ((AT91_REG *) 	0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_IER   ((AT91_REG *) 	0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_CR    ((AT91_REG *) 	0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_RTOR  ((AT91_REG *) 	0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_THR   ((AT91_REG *) 	0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_CSR   ((AT91_REG *) 	0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR   ((AT91_REG *) 	0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_FIDI  ((AT91_REG *) 	0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_BRGR  ((AT91_REG *) 	0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_TTGR  ((AT91_REG *) 	0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_IF    ((AT91_REG *) 	0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER   ((AT91_REG *) 	0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_MR    ((AT91_REG *) 	0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_PTCR  ((AT91_REG *) 	0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_TNPR  ((AT91_REG *) 	0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR  ((AT91_REG *) 	0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TPR   ((AT91_REG *) 	0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RPR   ((AT91_REG *) 	0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_PTSR  ((AT91_REG *) 	0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR  ((AT91_REG *) 	0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_RNCR  ((AT91_REG *) 	0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+#define AT91C_US0_TCR   ((AT91_REG *) 	0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_RCR   ((AT91_REG *) 	0xFFFC0104) // (PDC_US0) Receive Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_TTGR  ((AT91_REG *) 	0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_BRGR  ((AT91_REG *) 	0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_RHR   ((AT91_REG *) 	0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IMR   ((AT91_REG *) 	0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_NER   ((AT91_REG *) 	0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_RTOR  ((AT91_REG *) 	0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_XXR   ((AT91_REG *) 	0xFFFC0048) // (US0) XON_XOFF Register

+#define AT91C_US0_FIDI  ((AT91_REG *) 	0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_CR    ((AT91_REG *) 	0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IER   ((AT91_REG *) 	0xFFFC0008) // (US0) Interrupt Enable Register

+#define AT91C_US0_IF    ((AT91_REG *) 	0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_MR    ((AT91_REG *) 	0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_IDR   ((AT91_REG *) 	0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_CSR   ((AT91_REG *) 	0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_THR   ((AT91_REG *) 	0xFFFC001C) // (US0) Transmitter Holding Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_RHR   ((AT91_REG *) 	0xFFFB8030) // (TWI) Receive Holding Register

+#define AT91C_TWI_IDR   ((AT91_REG *) 	0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_SR    ((AT91_REG *) 	0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_CWGR  ((AT91_REG *) 	0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_SMR   ((AT91_REG *) 	0xFFFB8008) // (TWI) Slave Mode Register

+#define AT91C_TWI_CR    ((AT91_REG *) 	0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_THR   ((AT91_REG *) 	0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IMR   ((AT91_REG *) 	0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_IER   ((AT91_REG *) 	0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_IADR  ((AT91_REG *) 	0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR   ((AT91_REG *) 	0xFFFB8004) // (TWI) Master Mode Register

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_IMR   ((AT91_REG *) 	0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_IER   ((AT91_REG *) 	0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_RC    ((AT91_REG *) 	0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_RA    ((AT91_REG *) 	0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_CMR   ((AT91_REG *) 	0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_IDR   ((AT91_REG *) 	0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_SR    ((AT91_REG *) 	0xFFFA00A0) // (TC2) Status Register

+#define AT91C_TC2_RB    ((AT91_REG *) 	0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_CV    ((AT91_REG *) 	0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_CCR   ((AT91_REG *) 	0xFFFA0080) // (TC2) Channel Control Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_IMR   ((AT91_REG *) 	0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_IER   ((AT91_REG *) 	0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_RC    ((AT91_REG *) 	0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_RA    ((AT91_REG *) 	0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_CMR   ((AT91_REG *) 	0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_IDR   ((AT91_REG *) 	0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR    ((AT91_REG *) 	0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_RB    ((AT91_REG *) 	0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CV    ((AT91_REG *) 	0xFFFA0050) // (TC1) Counter Value

+#define AT91C_TC1_CCR   ((AT91_REG *) 	0xFFFA0040) // (TC1) Channel Control Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_IMR   ((AT91_REG *) 	0xFFFA002C) // (TC0) Interrupt Mask Register

+#define AT91C_TC0_IER   ((AT91_REG *) 	0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RC    ((AT91_REG *) 	0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RA    ((AT91_REG *) 	0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_CMR   ((AT91_REG *) 	0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IDR   ((AT91_REG *) 	0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_SR    ((AT91_REG *) 	0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RB    ((AT91_REG *) 	0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CV    ((AT91_REG *) 	0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_CCR   ((AT91_REG *) 	0xFFFA0000) // (TC0) Channel Control Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR   ((AT91_REG *) 	0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR   ((AT91_REG *) 	0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_CH3_CUPDR ((AT91_REG *) 	0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_CH3_CPRDR ((AT91_REG *) 	0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_CH3_CMR   ((AT91_REG *) 	0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+#define AT91C_CH3_Reserved ((AT91_REG *) 	0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_CH3_CCNTR ((AT91_REG *) 	0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_CH3_CDTYR ((AT91_REG *) 	0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_CH2_CUPDR ((AT91_REG *) 	0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_CH2_CPRDR ((AT91_REG *) 	0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_CH2_CMR   ((AT91_REG *) 	0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_CH2_Reserved ((AT91_REG *) 	0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_CH2_CCNTR ((AT91_REG *) 	0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_CH2_CDTYR ((AT91_REG *) 	0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_CH1_CUPDR ((AT91_REG *) 	0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_CH1_CPRDR ((AT91_REG *) 	0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_CH1_CMR   ((AT91_REG *) 	0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+#define AT91C_CH1_Reserved ((AT91_REG *) 	0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_CH1_CCNTR ((AT91_REG *) 	0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_CH1_CDTYR ((AT91_REG *) 	0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_CH0_CUPDR ((AT91_REG *) 	0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_CH0_CPRDR ((AT91_REG *) 	0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_CH0_CMR   ((AT91_REG *) 	0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_CH0_Reserved ((AT91_REG *) 	0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_CH0_CCNTR ((AT91_REG *) 	0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+#define AT91C_CH0_CDTYR ((AT91_REG *) 	0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_VR   ((AT91_REG *) 	0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR  ((AT91_REG *) 	0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_IDR  ((AT91_REG *) 	0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_SR   ((AT91_REG *) 	0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_ENA  ((AT91_REG *) 	0xFFFCC004) // (PWMC) PWMC Enable Register

+#define AT91C_PWMC_IMR  ((AT91_REG *) 	0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR   ((AT91_REG *) 	0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_DIS  ((AT91_REG *) 	0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER  ((AT91_REG *) 	0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_ISR   ((AT91_REG *) 	0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_IDR   ((AT91_REG *) 	0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_GLBSTATE ((AT91_REG *) 	0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_FDR   ((AT91_REG *) 	0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_CSR   ((AT91_REG *) 	0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_RSTEP ((AT91_REG *) 	0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_ICR   ((AT91_REG *) 	0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_IMR   ((AT91_REG *) 	0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_IER   ((AT91_REG *) 	0xFFFB0010) // (UDP) Interrupt Enable Register

+#define AT91C_UDP_FADDR ((AT91_REG *) 	0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM   ((AT91_REG *) 	0xFFFB0000) // (UDP) Frame Number Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_PIO_PA0        ((unsigned int) 1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_PWM0     ((unsigned int) AT91C_PIO_PA0) //  PWM Channel 0

+#define AT91C_PA0_TIOA0    ((unsigned int) AT91C_PIO_PA0) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA1        ((unsigned int) 1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_PWM1     ((unsigned int) AT91C_PIO_PA1) //  PWM Channel 1

+#define AT91C_PA1_TIOB0    ((unsigned int) AT91C_PIO_PA1) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA10       ((unsigned int) 1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_DTXD     ((unsigned int) AT91C_PIO_PA10) //  DBGU Debug Transmit Data

+#define AT91C_PA10_NPCS2    ((unsigned int) AT91C_PIO_PA10) //  SPI Peripheral Chip Select 2

+#define AT91C_PIO_PA11       ((unsigned int) 1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_NPCS0    ((unsigned int) AT91C_PIO_PA11) //  SPI Peripheral Chip Select 0

+#define AT91C_PA11_PWM0     ((unsigned int) AT91C_PIO_PA11) //  PWM Channel 0

+#define AT91C_PIO_PA12       ((unsigned int) 1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_MISO     ((unsigned int) AT91C_PIO_PA12) //  SPI Master In Slave

+#define AT91C_PA12_PWM1     ((unsigned int) AT91C_PIO_PA12) //  PWM Channel 1

+#define AT91C_PIO_PA13       ((unsigned int) 1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_MOSI     ((unsigned int) AT91C_PIO_PA13) //  SPI Master Out Slave

+#define AT91C_PA13_PWM2     ((unsigned int) AT91C_PIO_PA13) //  PWM Channel 2

+#define AT91C_PIO_PA14       ((unsigned int) 1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_SPCK     ((unsigned int) AT91C_PIO_PA14) //  SPI Serial Clock

+#define AT91C_PA14_PWM3     ((unsigned int) AT91C_PIO_PA14) //  PWM Channel 3

+#define AT91C_PIO_PA15       ((unsigned int) 1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_TF       ((unsigned int) AT91C_PIO_PA15) //  SSC Transmit Frame Sync

+#define AT91C_PA15_TIOA1    ((unsigned int) AT91C_PIO_PA15) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA16       ((unsigned int) 1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_TK       ((unsigned int) AT91C_PIO_PA16) //  SSC Transmit Clock

+#define AT91C_PA16_TIOB1    ((unsigned int) AT91C_PIO_PA16) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA17       ((unsigned int) 1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_TD       ((unsigned int) AT91C_PIO_PA17) //  SSC Transmit data

+#define AT91C_PA17_PCK1     ((unsigned int) AT91C_PIO_PA17) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA18       ((unsigned int) 1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_RD       ((unsigned int) AT91C_PIO_PA18) //  SSC Receive Data

+#define AT91C_PA18_PCK2     ((unsigned int) AT91C_PIO_PA18) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA19       ((unsigned int) 1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_RK       ((unsigned int) AT91C_PIO_PA19) //  SSC Receive Clock

+#define AT91C_PA19_FIQ      ((unsigned int) AT91C_PIO_PA19) //  AIC Fast Interrupt Input

+#define AT91C_PIO_PA2        ((unsigned int) 1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_PWM2     ((unsigned int) AT91C_PIO_PA2) //  PWM Channel 2

+#define AT91C_PA2_SCK0     ((unsigned int) AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PIO_PA20       ((unsigned int) 1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_RF       ((unsigned int) AT91C_PIO_PA20) //  SSC Receive Frame Sync

+#define AT91C_PA20_IRQ0     ((unsigned int) AT91C_PIO_PA20) //  External Interrupt 0

+#define AT91C_PIO_PA21       ((unsigned int) 1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_RXD1     ((unsigned int) AT91C_PIO_PA21) //  USART 1 Receive Data

+#define AT91C_PA21_PCK1     ((unsigned int) AT91C_PIO_PA21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA22       ((unsigned int) 1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TXD1     ((unsigned int) AT91C_PIO_PA22) //  USART 1 Transmit Data

+#define AT91C_PA22_NPCS3    ((unsigned int) AT91C_PIO_PA22) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA23       ((unsigned int) 1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_SCK1     ((unsigned int) AT91C_PIO_PA23) //  USART 1 Serial Clock

+#define AT91C_PA23_PWM0     ((unsigned int) AT91C_PIO_PA23) //  PWM Channel 0

+#define AT91C_PIO_PA24       ((unsigned int) 1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RTS1     ((unsigned int) AT91C_PIO_PA24) //  USART 1 Ready To Send

+#define AT91C_PA24_PWM1     ((unsigned int) AT91C_PIO_PA24) //  PWM Channel 1

+#define AT91C_PIO_PA25       ((unsigned int) 1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_CTS1     ((unsigned int) AT91C_PIO_PA25) //  USART 1 Clear To Send

+#define AT91C_PA25_PWM2     ((unsigned int) AT91C_PIO_PA25) //  PWM Channel 2

+#define AT91C_PIO_PA26       ((unsigned int) 1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_DCD1     ((unsigned int) AT91C_PIO_PA26) //  USART 1 Data Carrier Detect

+#define AT91C_PA26_TIOA2    ((unsigned int) AT91C_PIO_PA26) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA27       ((unsigned int) 1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DTR1     ((unsigned int) AT91C_PIO_PA27) //  USART 1 Data Terminal ready

+#define AT91C_PA27_TIOB2    ((unsigned int) AT91C_PIO_PA27) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA28       ((unsigned int) 1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DSR1     ((unsigned int) AT91C_PIO_PA28) //  USART 1 Data Set ready

+#define AT91C_PA28_TCLK1    ((unsigned int) AT91C_PIO_PA28) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PA29       ((unsigned int) 1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_RI1      ((unsigned int) AT91C_PIO_PA29) //  USART 1 Ring Indicator

+#define AT91C_PA29_TCLK2    ((unsigned int) AT91C_PIO_PA29) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA3        ((unsigned int) 1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_TWD      ((unsigned int) AT91C_PIO_PA3) //  TWI Two-wire Serial Data

+#define AT91C_PA3_NPCS3    ((unsigned int) AT91C_PIO_PA3) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA30       ((unsigned int) 1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ1     ((unsigned int) AT91C_PIO_PA30) //  External Interrupt 1

+#define AT91C_PA30_NPCS2    ((unsigned int) AT91C_PIO_PA30) //  SPI Peripheral Chip Select 2

+#define AT91C_PIO_PA31       ((unsigned int) 1 << 31) // Pin Controlled by PA31

+#define AT91C_PA31_NPCS1    ((unsigned int) AT91C_PIO_PA31) //  SPI Peripheral Chip Select 1

+#define AT91C_PA31_PCK2     ((unsigned int) AT91C_PIO_PA31) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4        ((unsigned int) 1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_TWCK     ((unsigned int) AT91C_PIO_PA4) //  TWI Two-wire Serial Clock

+#define AT91C_PA4_TCLK0    ((unsigned int) AT91C_PIO_PA4) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PA5        ((unsigned int) 1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD0     ((unsigned int) AT91C_PIO_PA5) //  USART 0 Receive Data

+#define AT91C_PA5_NPCS3    ((unsigned int) AT91C_PIO_PA5) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA6        ((unsigned int) 1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD0     ((unsigned int) AT91C_PIO_PA6) //  USART 0 Transmit Data

+#define AT91C_PA6_PCK0     ((unsigned int) AT91C_PIO_PA6) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PA7        ((unsigned int) 1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_RTS0     ((unsigned int) AT91C_PIO_PA7) //  USART 0 Ready To Send

+#define AT91C_PA7_PWM3     ((unsigned int) AT91C_PIO_PA7) //  PWM Channel 3

+#define AT91C_PIO_PA8        ((unsigned int) 1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_CTS0     ((unsigned int) AT91C_PIO_PA8) //  USART 0 Clear To Send

+#define AT91C_PA8_ADTRG    ((unsigned int) AT91C_PIO_PA8) //  ADC External Trigger

+#define AT91C_PIO_PA9        ((unsigned int) 1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_DRXD     ((unsigned int) AT91C_PIO_PA9) //  DBGU Debug Receive Data

+#define AT91C_PA9_NPCS1    ((unsigned int) AT91C_PIO_PA9) //  SPI Peripheral Chip Select 1

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_ID_FIQ    ((unsigned int)  0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS    ((unsigned int)  1) // System Peripheral

+#define AT91C_ID_PIOA   ((unsigned int)  2) // Parallel IO Controller

+#define AT91C_ID_3_Reserved ((unsigned int)  3) // Reserved

+#define AT91C_ID_ADC    ((unsigned int)  4) // Analog-to-Digital Converter

+#define AT91C_ID_SPI    ((unsigned int)  5) // Serial Peripheral Interface

+#define AT91C_ID_US0    ((unsigned int)  6) // USART 0

+#define AT91C_ID_US1    ((unsigned int)  7) // USART 1

+#define AT91C_ID_SSC    ((unsigned int)  8) // Serial Synchronous Controller

+#define AT91C_ID_TWI    ((unsigned int)  9) // Two-Wire Interface

+#define AT91C_ID_PWMC   ((unsigned int) 10) // PWM Controller

+#define AT91C_ID_UDP    ((unsigned int) 11) // USB Device Port

+#define AT91C_ID_TC0    ((unsigned int) 12) // Timer Counter 0

+#define AT91C_ID_TC1    ((unsigned int) 13) // Timer Counter 1

+#define AT91C_ID_TC2    ((unsigned int) 14) // Timer Counter 2

+#define AT91C_ID_15_Reserved ((unsigned int) 15) // Reserved

+#define AT91C_ID_16_Reserved ((unsigned int) 16) // Reserved

+#define AT91C_ID_17_Reserved ((unsigned int) 17) // Reserved

+#define AT91C_ID_18_Reserved ((unsigned int) 18) // Reserved

+#define AT91C_ID_19_Reserved ((unsigned int) 19) // Reserved

+#define AT91C_ID_20_Reserved ((unsigned int) 20) // Reserved

+#define AT91C_ID_21_Reserved ((unsigned int) 21) // Reserved

+#define AT91C_ID_22_Reserved ((unsigned int) 22) // Reserved

+#define AT91C_ID_23_Reserved ((unsigned int) 23) // Reserved

+#define AT91C_ID_24_Reserved ((unsigned int) 24) // Reserved

+#define AT91C_ID_25_Reserved ((unsigned int) 25) // Reserved

+#define AT91C_ID_26_Reserved ((unsigned int) 26) // Reserved

+#define AT91C_ID_27_Reserved ((unsigned int) 27) // Reserved

+#define AT91C_ID_28_Reserved ((unsigned int) 28) // Reserved

+#define AT91C_ID_29_Reserved ((unsigned int) 29) // Reserved

+#define AT91C_ID_IRQ0   ((unsigned int) 30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1   ((unsigned int) 31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_BASE_SYSC      ((AT91PS_SYSC) 	0xFFFFF000) // (SYSC) Base Address

+#define AT91C_BASE_AIC       ((AT91PS_AIC) 	0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_DBGU      ((AT91PS_DBGU) 	0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PDC_DBGU  ((AT91PS_PDC) 	0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_PIOA      ((AT91PS_PIO) 	0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_CKGR      ((AT91PS_CKGR) 	0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC       ((AT91PS_PMC) 	0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC      ((AT91PS_RSTC) 	0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC      ((AT91PS_RTTC) 	0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC      ((AT91PS_PITC) 	0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC      ((AT91PS_WDTC) 	0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_MC        ((AT91PS_MC) 	0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI   ((AT91PS_PDC) 	0xFFFE0100) // (PDC_SPI) Base Address

+#define AT91C_BASE_SPI       ((AT91PS_SPI) 	0xFFFE0000) // (SPI) Base Address

+#define AT91C_BASE_PDC_ADC   ((AT91PS_PDC) 	0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC       ((AT91PS_ADC) 	0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_SSC   ((AT91PS_PDC) 	0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC       ((AT91PS_SSC) 	0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_PDC_US1   ((AT91PS_PDC) 	0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1       ((AT91PS_USART) 	0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0   ((AT91PS_PDC) 	0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0       ((AT91PS_USART) 	0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_TWI       ((AT91PS_TWI) 	0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_TC2       ((AT91PS_TC) 	0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TC1       ((AT91PS_TC) 	0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC0       ((AT91PS_TC) 	0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TCB       ((AT91PS_TCB) 	0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_PWMC_CH3  ((AT91PS_PWMC_CH) 	0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2  ((AT91PS_PWMC_CH) 	0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1  ((AT91PS_PWMC_CH) 	0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0  ((AT91PS_PWMC_CH) 	0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC      ((AT91PS_PWMC) 	0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP       ((AT91PS_UDP) 	0xFFFB0000) // (UDP) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_ISRAM	 ((char *) 	0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	 ((unsigned int) 0x00004000) // Internal SRAM size in byte (16 Kbyte)

+#define AT91C_IFLASH	 ((char *) 	0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	 ((unsigned int) 0x00010000) // Internal ROM size in byte (64 Kbyte)

+

+#endif

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64_inc.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64_inc.h
new file mode 100644
index 0000000..7d2657a
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7S64_inc.h
@@ -0,0 +1,1812 @@
+// ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+// ----------------------------------------------------------------------------

+//  The software is delivered "AS IS" without warranty or condition of any

+//  kind, either express, implied or statutory. This includes without

+//  limitation any warranty or condition with respect to merchantability or

+//  fitness for any particular purpose, or against the infringements of

+//  intellectual property rights of others.

+// ----------------------------------------------------------------------------

+// File Name           : AT91SAM7S64.h

+// Object              : AT91SAM7S64 definitions

+// Generated           : AT91 SW Application Group  07/16/2004 (07:43:09)

+// 

+// CVS Reference       : /AT91SAM7S64.pl/1.12/Mon Jul 12 13:02:30 2004//

+// CVS Reference       : /SYSC_SAM7Sxx.pl/1.5/Mon Jul 12 16:22:12 2004//

+// CVS Reference       : /MC_SAM02.pl/1.3/Wed Mar 10 08:37:04 2004//

+// CVS Reference       : /UDP_1765B.pl/1.3/Fri Aug  2 14:45:38 2002//

+// CVS Reference       : /AIC_1796B.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//

+// CVS Reference       : /lib_pmc_SAM.h/1.6/Tue Apr 27 13:53:52 2004//

+// CVS Reference       : /PIO_1725D.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//

+// CVS Reference       : /DBGU_1754A.pl/1.4/Fri Jan 31 12:18:24 2003//

+// CVS Reference       : /US_1739C.pl/1.2/Mon Jul 12 17:26:24 2004//

+// CVS Reference       : /SPI2.pl/1.2/Fri Oct 17 08:13:40 2003//

+// CVS Reference       : /SSC_1762A.pl/1.2/Fri Nov  8 13:26:40 2002//

+// CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+// CVS Reference       : /TWI_1761B.pl/1.4/Fri Feb  7 10:30:08 2003//

+// CVS Reference       : /PDC_1734B.pl/1.2/Thu Nov 21 16:38:24 2002//

+// CVS Reference       : /ADC_SAM.pl/1.7/Fri Oct 17 08:12:38 2003//

+// CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+// ----------------------------------------------------------------------------

+

+// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+// *** Register offset in AT91S_SYSC structure ***

+#define SYSC_AIC_SMR    ( 0) // Source Mode Register

+#define SYSC_AIC_SVR    (128) // Source Vector Register

+#define SYSC_AIC_IVR    (256) // IRQ Vector Register

+#define SYSC_AIC_FVR    (260) // FIQ Vector Register

+#define SYSC_AIC_ISR    (264) // Interrupt Status Register

+#define SYSC_AIC_IPR    (268) // Interrupt Pending Register

+#define SYSC_AIC_IMR    (272) // Interrupt Mask Register

+#define SYSC_AIC_CISR   (276) // Core Interrupt Status Register

+#define SYSC_AIC_IECR   (288) // Interrupt Enable Command Register

+#define SYSC_AIC_IDCR   (292) // Interrupt Disable Command Register

+#define SYSC_AIC_ICCR   (296) // Interrupt Clear Command Register

+#define SYSC_AIC_ISCR   (300) // Interrupt Set Command Register

+#define SYSC_AIC_EOICR  (304) // End of Interrupt Command Register

+#define SYSC_AIC_SPU    (308) // Spurious Vector Register

+#define SYSC_AIC_DCR    (312) // Debug Control Register (Protect)

+#define SYSC_AIC_FFER   (320) // Fast Forcing Enable Register

+#define SYSC_AIC_FFDR   (324) // Fast Forcing Disable Register

+#define SYSC_AIC_FFSR   (328) // Fast Forcing Status Register

+#define SYSC_DBGU_CR    (512) // Control Register

+#define SYSC_DBGU_MR    (516) // Mode Register

+#define SYSC_DBGU_IER   (520) // Interrupt Enable Register

+#define SYSC_DBGU_IDR   (524) // Interrupt Disable Register

+#define SYSC_DBGU_IMR   (528) // Interrupt Mask Register

+#define SYSC_DBGU_CSR   (532) // Channel Status Register

+#define SYSC_DBGU_RHR   (536) // Receiver Holding Register

+#define SYSC_DBGU_THR   (540) // Transmitter Holding Register

+#define SYSC_DBGU_BRGR  (544) // Baud Rate Generator Register

+#define SYSC_DBGU_C1R   (576) // Chip ID1 Register

+#define SYSC_DBGU_C2R   (580) // Chip ID2 Register

+#define SYSC_DBGU_FNTR  (584) // Force NTRST Register

+#define SYSC_DBGU_RPR   (768) // Receive Pointer Register

+#define SYSC_DBGU_RCR   (772) // Receive Counter Register

+#define SYSC_DBGU_TPR   (776) // Transmit Pointer Register

+#define SYSC_DBGU_TCR   (780) // Transmit Counter Register

+#define SYSC_DBGU_RNPR  (784) // Receive Next Pointer Register

+#define SYSC_DBGU_RNCR  (788) // Receive Next Counter Register

+#define SYSC_DBGU_TNPR  (792) // Transmit Next Pointer Register

+#define SYSC_DBGU_TNCR  (796) // Transmit Next Counter Register

+#define SYSC_DBGU_PTCR  (800) // PDC Transfer Control Register

+#define SYSC_DBGU_PTSR  (804) // PDC Transfer Status Register

+#define SYSC_PIOA_PER   (1024) // PIO Enable Register

+#define SYSC_PIOA_PDR   (1028) // PIO Disable Register

+#define SYSC_PIOA_PSR   (1032) // PIO Status Register

+#define SYSC_PIOA_OER   (1040) // Output Enable Register

+#define SYSC_PIOA_ODR   (1044) // Output Disable Registerr

+#define SYSC_PIOA_OSR   (1048) // Output Status Register

+#define SYSC_PIOA_IFER  (1056) // Input Filter Enable Register

+#define SYSC_PIOA_IFDR  (1060) // Input Filter Disable Register

+#define SYSC_PIOA_IFSR  (1064) // Input Filter Status Register

+#define SYSC_PIOA_SODR  (1072) // Set Output Data Register

+#define SYSC_PIOA_CODR  (1076) // Clear Output Data Register

+#define SYSC_PIOA_ODSR  (1080) // Output Data Status Register

+#define SYSC_PIOA_PDSR  (1084) // Pin Data Status Register

+#define SYSC_PIOA_IER   (1088) // Interrupt Enable Register

+#define SYSC_PIOA_IDR   (1092) // Interrupt Disable Register

+#define SYSC_PIOA_IMR   (1096) // Interrupt Mask Register

+#define SYSC_PIOA_ISR   (1100) // Interrupt Status Register

+#define SYSC_PIOA_MDER  (1104) // Multi-driver Enable Register

+#define SYSC_PIOA_MDDR  (1108) // Multi-driver Disable Register

+#define SYSC_PIOA_MDSR  (1112) // Multi-driver Status Register

+#define SYSC_PIOA_PPUDR (1120) // Pull-up Disable Register

+#define SYSC_PIOA_PPUER (1124) // Pull-up Enable Register

+#define SYSC_PIOA_PPUSR (1128) // Pad Pull-up Status Register

+#define SYSC_PIOA_ASR   (1136) // Select A Register

+#define SYSC_PIOA_BSR   (1140) // Select B Register

+#define SYSC_PIOA_ABSR  (1144) // AB Select Status Register

+#define SYSC_PIOA_OWER  (1184) // Output Write Enable Register

+#define SYSC_PIOA_OWDR  (1188) // Output Write Disable Register

+#define SYSC_PIOA_OWSR  (1192) // Output Write Status Register

+#define SYSC_PMC_SCER   (3072) // System Clock Enable Register

+#define SYSC_PMC_SCDR   (3076) // System Clock Disable Register

+#define SYSC_PMC_SCSR   (3080) // System Clock Status Register

+#define SYSC_PMC_PCER   (3088) // Peripheral Clock Enable Register

+#define SYSC_PMC_PCDR   (3092) // Peripheral Clock Disable Register

+#define SYSC_PMC_PCSR   (3096) // Peripheral Clock Status Register

+#define SYSC_PMC_MOR    (3104) // Main Oscillator Register

+#define SYSC_PMC_MCFR   (3108) // Main Clock  Frequency Register

+#define SYSC_PMC_PLLR   (3116) // PLL Register

+#define SYSC_PMC_MCKR   (3120) // Master Clock Register

+#define SYSC_PMC_PCKR   (3136) // Programmable Clock Register

+#define SYSC_PMC_IER    (3168) // Interrupt Enable Register

+#define SYSC_PMC_IDR    (3172) // Interrupt Disable Register

+#define SYSC_PMC_SR     (3176) // Status Register

+#define SYSC_PMC_IMR    (3180) // Interrupt Mask Register

+#define SYSC_RSTC_RCR   (3328) // Reset Control Register

+#define SYSC_RSTC_RSR   (3332) // Reset Status Register

+#define SYSC_RSTC_RMR   (3336) // Reset Mode Register

+#define SYSC_RTTC_RTMR  (3360) // Real-time Mode Register

+#define SYSC_RTTC_RTAR  (3364) // Real-time Alarm Register

+#define SYSC_RTTC_RTVR  (3368) // Real-time Value Register

+#define SYSC_RTTC_RTSR  (3372) // Real-time Status Register

+#define SYSC_PITC_PIMR  (3376) // Period Interval Mode Register

+#define SYSC_PITC_PISR  (3380) // Period Interval Status Register

+#define SYSC_PITC_PIVR  (3384) // Period Interval Value Register

+#define SYSC_PITC_PIIR  (3388) // Period Interval Image Register

+#define SYSC_WDTC_WDCR  (3392) // Watchdog Control Register

+#define SYSC_WDTC_WDMR  (3396) // Watchdog Mode Register

+#define SYSC_WDTC_WDSR  (3400) // Watchdog Status Register

+#define SYSC_SYSC_VRPM  (3424) // Voltage Regulator Power Mode Register

+// -------- VRPM : (SYSC Offset: 0xd60) Voltage Regulator Power Mode Register -------- 

+#define AT91C_SYSC_PSTDBY         (0x1 <<  0) // (SYSC) Voltage Regulator Power Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+// *** Register offset in AT91S_AIC structure ***

+#define AIC_SMR         ( 0) // Source Mode Register

+#define AIC_SVR         (128) // Source Vector Register

+#define AIC_IVR         (256) // IRQ Vector Register

+#define AIC_FVR         (260) // FIQ Vector Register

+#define AIC_ISR         (264) // Interrupt Status Register

+#define AIC_IPR         (268) // Interrupt Pending Register

+#define AIC_IMR         (272) // Interrupt Mask Register

+#define AIC_CISR        (276) // Core Interrupt Status Register

+#define AIC_IECR        (288) // Interrupt Enable Command Register

+#define AIC_IDCR        (292) // Interrupt Disable Command Register

+#define AIC_ICCR        (296) // Interrupt Clear Command Register

+#define AIC_ISCR        (300) // Interrupt Set Command Register

+#define AIC_EOICR       (304) // End of Interrupt Command Register

+#define AIC_SPU         (308) // Spurious Vector Register

+#define AIC_DCR         (312) // Debug Control Register (Protect)

+#define AIC_FFER        (320) // Fast Forcing Enable Register

+#define AIC_FFDR        (324) // Fast Forcing Disable Register

+#define AIC_FFSR        (328) // Fast Forcing Status Register

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR           (0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               (0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              (0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE         (0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_LEVEL_SENSITIVE  (0x0 <<  5) // (AIC) Internal Sources Code Label Level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_EDGE_TRIGGERED   (0x1 <<  5) // (AIC) Internal Sources Code Label Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_HIGH_LEVEL       (0x2 <<  5) // (AIC) External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_POSITIVE_EDGE    (0x3 <<  5) // (AIC) External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ            (0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ            (0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT        (0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK        (0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+// *** Register offset in AT91S_DBGU structure ***

+#define DBGU_CR         ( 0) // Control Register

+#define DBGU_MR         ( 4) // Mode Register

+#define DBGU_IER        ( 8) // Interrupt Enable Register

+#define DBGU_IDR        (12) // Interrupt Disable Register

+#define DBGU_IMR        (16) // Interrupt Mask Register

+#define DBGU_CSR        (20) // Channel Status Register

+#define DBGU_RHR        (24) // Receiver Holding Register

+#define DBGU_THR        (28) // Transmitter Holding Register

+#define DBGU_BRGR       (32) // Baud Rate Generator Register

+#define DBGU_C1R        (64) // Chip ID1 Register

+#define DBGU_C2R        (68) // Chip ID2 Register

+#define DBGU_FNTR       (72) // Force NTRST Register

+#define DBGU_RPR        (256) // Receive Pointer Register

+#define DBGU_RCR        (260) // Receive Counter Register

+#define DBGU_TPR        (264) // Transmit Pointer Register

+#define DBGU_TCR        (268) // Transmit Counter Register

+#define DBGU_RNPR       (272) // Receive Next Pointer Register

+#define DBGU_RNCR       (276) // Receive Next Counter Register

+#define DBGU_TNPR       (280) // Transmit Next Pointer Register

+#define DBGU_TNCR       (284) // Transmit Next Counter Register

+#define DBGU_PTCR       (288) // PDC Transfer Control Register

+#define DBGU_PTSR       (292) // PDC Transfer Status Register

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX            (0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX            (0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN             (0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS            (0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN             (0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS            (0x1 <<  7) // (DBGU) Transmitter Disable

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR              (0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 (0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  (0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                (0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 (0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 (0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           (0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE           (0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               (0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 (0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                (0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               (0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY            (0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY            (0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX            (0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX            (0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE             (0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME            (0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE             (0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY          (0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE           (0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF           (0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX          (0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX          (0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST      (0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral Data Controller

+// *****************************************************************************

+// *** Register offset in AT91S_PDC structure ***

+#define PDC_RPR         ( 0) // Receive Pointer Register

+#define PDC_RCR         ( 4) // Receive Counter Register

+#define PDC_TPR         ( 8) // Transmit Pointer Register

+#define PDC_TCR         (12) // Transmit Counter Register

+#define PDC_RNPR        (16) // Receive Next Pointer Register

+#define PDC_RNCR        (20) // Receive Next Counter Register

+#define PDC_TNPR        (24) // Transmit Next Pointer Register

+#define PDC_TNCR        (28) // Transmit Next Counter Register

+#define PDC_PTCR        (32) // PDC Transfer Control Register

+#define PDC_PTSR        (36) // PDC Transfer Status Register

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN           (0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS          (0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN           (0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS          (0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PIO structure ***

+#define PIO_PER         ( 0) // PIO Enable Register

+#define PIO_PDR         ( 4) // PIO Disable Register

+#define PIO_PSR         ( 8) // PIO Status Register

+#define PIO_OER         (16) // Output Enable Register

+#define PIO_ODR         (20) // Output Disable Registerr

+#define PIO_OSR         (24) // Output Status Register

+#define PIO_IFER        (32) // Input Filter Enable Register

+#define PIO_IFDR        (36) // Input Filter Disable Register

+#define PIO_IFSR        (40) // Input Filter Status Register

+#define PIO_SODR        (48) // Set Output Data Register

+#define PIO_CODR        (52) // Clear Output Data Register

+#define PIO_ODSR        (56) // Output Data Status Register

+#define PIO_PDSR        (60) // Pin Data Status Register

+#define PIO_IER         (64) // Interrupt Enable Register

+#define PIO_IDR         (68) // Interrupt Disable Register

+#define PIO_IMR         (72) // Interrupt Mask Register

+#define PIO_ISR         (76) // Interrupt Status Register

+#define PIO_MDER        (80) // Multi-driver Enable Register

+#define PIO_MDDR        (84) // Multi-driver Disable Register

+#define PIO_MDSR        (88) // Multi-driver Status Register

+#define PIO_PPUDR       (96) // Pull-up Disable Register

+#define PIO_PPUER       (100) // Pull-up Enable Register

+#define PIO_PPUSR       (104) // Pad Pull-up Status Register

+#define PIO_ASR         (112) // Select A Register

+#define PIO_BSR         (116) // Select B Register

+#define PIO_ABSR        (120) // AB Select Status Register

+#define PIO_OWER        (160) // Output Write Enable Register

+#define PIO_OWDR        (164) // Output Write Disable Register

+#define PIO_OWSR        (168) // Output Write Status Register

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+// *** Register offset in AT91S_CKGR structure ***

+#define CKGR_MOR        ( 0) // Main Oscillator Register

+#define CKGR_MCFR       ( 4) // Main Clock  Frequency Register

+#define CKGR_PLLR       (12) // PLL Register

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN         (0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS      (0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT        (0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF          (0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY        (0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV            (0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    (0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               (0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT       (0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT            (0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    (0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    (0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    (0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    (0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL            (0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV         (0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    (0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    (0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    (0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PMC structure ***

+#define PMC_SCER        ( 0) // System Clock Enable Register

+#define PMC_SCDR        ( 4) // System Clock Disable Register

+#define PMC_SCSR        ( 8) // System Clock Status Register

+#define PMC_PCER        (16) // Peripheral Clock Enable Register

+#define PMC_PCDR        (20) // Peripheral Clock Disable Register

+#define PMC_PCSR        (24) // Peripheral Clock Status Register

+#define PMC_MOR         (32) // Main Oscillator Register

+#define PMC_MCFR        (36) // Main Clock  Frequency Register

+#define PMC_PLLR        (44) // PLL Register

+#define PMC_MCKR        (48) // Master Clock Register

+#define PMC_PCKR        (64) // Programmable Clock Register

+#define PMC_IER         (96) // Interrupt Enable Register

+#define PMC_IDR         (100) // Interrupt Disable Register

+#define PMC_SR          (104) // Status Register

+#define PMC_IMR         (108) // Interrupt Mask Register

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK             (0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP             (0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0            (0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1            (0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2            (0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3            (0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS             (0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             (0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             (0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              (0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES            (0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  (0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                (0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                (0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                (0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               (0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               (0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               (0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS           (0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK            (0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY          (0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY         (0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY         (0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY         (0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY         (0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RSTC structure ***

+#define RSTC_RCR        ( 0) // Reset Control Register

+#define RSTC_RSR        ( 4) // Reset Status Register

+#define RSTC_RMR        ( 8) // Reset Mode Register

+// -------- SYSC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_SYSC_PROCRST        (0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_SYSC_ICERST         (0x1 <<  1) // (RSTC) ICE Interface Reset

+#define AT91C_SYSC_PERRST         (0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_SYSC_EXTRST         (0x1 <<  3) // (RSTC) External Reset

+#define AT91C_SYSC_KEY            (0xFF << 24) // (RSTC) Password

+// -------- SYSC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_SYSC_URSTS          (0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_SYSC_BODSTS         (0x1 <<  1) // (RSTC) Brown-out Detection Status

+#define AT91C_SYSC_RSTTYP         (0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_SYSC_RSTTYP_POWERUP              (0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_SYSC_RSTTYP_WATCHDOG             (0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_SYSC_RSTTYP_SOFTWARE             (0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_SYSC_RSTTYP_USER                 (0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_SYSC_RSTTYP_BROWNOUT             (0x5 <<  8) // (RSTC) Brown-out Reset.

+#define AT91C_SYSC_NRSTL          (0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_SYSC_SRCMP          (0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- SYSC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_SYSC_URSTEN         (0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_SYSC_URSTIEN        (0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_SYSC_ERSTL          (0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_SYSC_BODIEN         (0x1 << 16) // (RSTC) Brown-out Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RTTC structure ***

+#define RTTC_RTMR       ( 0) // Real-time Mode Register

+#define RTTC_RTAR       ( 4) // Real-time Alarm Register

+#define RTTC_RTVR       ( 8) // Real-time Value Register

+#define RTTC_RTSR       (12) // Real-time Status Register

+// -------- SYSC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_SYSC_RTPRES         (0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_SYSC_ALMIEN         (0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_SYSC_RTTINCIEN      (0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_SYSC_RTTRST         (0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- SYSC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_SYSC_ALMV           (0x0 <<  0) // (RTTC) Alarm Value

+// -------- SYSC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_SYSC_CRTV           (0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- SYSC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_SYSC_ALMS           (0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_SYSC_RTTINC         (0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PITC structure ***

+#define PITC_PIMR       ( 0) // Period Interval Mode Register

+#define PITC_PISR       ( 4) // Period Interval Status Register

+#define PITC_PIVR       ( 8) // Period Interval Value Register

+#define PITC_PIIR       (12) // Period Interval Image Register

+// -------- SYSC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_SYSC_PIV            (0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_SYSC_PITEN          (0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_SYSC_PITIEN         (0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- SYSC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_SYSC_PITS           (0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- SYSC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_SYSC_CPIV           (0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_SYSC_PICNT          (0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- SYSC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_WDTC structure ***

+#define WDTC_WDCR       ( 0) // Watchdog Control Register

+#define WDTC_WDMR       ( 4) // Watchdog Mode Register

+#define WDTC_WDSR       ( 8) // Watchdog Status Register

+// -------- SYSC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_SYSC_WDRSTT         (0x1 <<  0) // (WDTC) Watchdog Restart

+// -------- SYSC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_SYSC_WDV            (0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_SYSC_WDFIEN         (0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_SYSC_WDRSTEN        (0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_SYSC_WDRPROC        (0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_SYSC_WDDIS          (0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_SYSC_WDD            (0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_SYSC_WDDBGHLT       (0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_SYSC_WDIDLEHLT      (0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- SYSC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_SYSC_WDUNF          (0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_SYSC_WDERR          (0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_MC structure ***

+#define MC_RCR          ( 0) // MC Remap Control Register

+#define MC_ASR          ( 4) // MC Abort Status Register

+#define MC_AASR         ( 8) // MC Abort Address Status Register

+#define MC_FMR          (96) // MC Flash Mode Register

+#define MC_FCR          (100) // MC Flash Command Register

+#define MC_FSR          (104) // MC Flash Status Register

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB              (0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD           (0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD           (0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ            (0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 (0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                (0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 (0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP           (0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                (0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                (0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                (0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0             (0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1             (0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0           (0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1           (0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY             (0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE            (0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE            (0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP             (0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS              (0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 (0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 (0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 (0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 (0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN             (0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD             (0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           (0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 (0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        (0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               (0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            (0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           (0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           (0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         (0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN            (0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY              (0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY         (0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0           (0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1           (0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2           (0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3           (0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4           (0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5           (0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6           (0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7           (0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0           (0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1           (0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2           (0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3           (0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4           (0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5           (0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6           (0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7           (0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8           (0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9           (0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10          (0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11          (0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12          (0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13          (0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14          (0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15          (0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SPI structure ***

+#define SPI_CR          ( 0) // Control Register

+#define SPI_MR          ( 4) // Mode Register

+#define SPI_RDR         ( 8) // Receive Data Register

+#define SPI_TDR         (12) // Transmit Data Register

+#define SPI_SR          (16) // Status Register

+#define SPI_IER         (20) // Interrupt Enable Register

+#define SPI_IDR         (24) // Interrupt Disable Register

+#define SPI_IMR         (28) // Interrupt Mask Register

+#define SPI_CSR         (48) // Chip Select Register

+#define SPI_RPR         (256) // Receive Pointer Register

+#define SPI_RCR         (260) // Receive Counter Register

+#define SPI_TPR         (264) // Transmit Pointer Register

+#define SPI_TCR         (268) // Transmit Counter Register

+#define SPI_RNPR        (272) // Receive Next Pointer Register

+#define SPI_RNCR        (276) // Receive Next Counter Register

+#define SPI_TNPR        (280) // Transmit Next Pointer Register

+#define SPI_TNCR        (284) // Transmit Next Counter Register

+#define SPI_PTCR        (288) // PDC Transfer Control Register

+#define SPI_PTSR        (292) // PDC Transfer Status Register

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN           (0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS          (0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST           (0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER        (0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR            (0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS              (0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                (0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             (0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC          (0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV            (0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS         (0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB             (0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS             (0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS          (0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD              (0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD              (0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF            (0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE            (0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF            (0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES           (0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX           (0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX           (0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF          (0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE          (0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR            (0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY         (0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS          (0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL            (0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA           (0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT           (0x1 <<  2) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS            (0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    (0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    (0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   (0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   (0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   (0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   (0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   (0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   (0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   (0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR            (0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS           (0xFF << 16) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBCT          (0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+// *** Register offset in AT91S_ADC structure ***

+#define ADC_CR          ( 0) // ADC Control Register

+#define ADC_MR          ( 4) // ADC Mode Register

+#define ADC_CHER        (16) // ADC Channel Enable Register

+#define ADC_CHDR        (20) // ADC Channel Disable Register

+#define ADC_CHSR        (24) // ADC Channel Status Register

+#define ADC_SR          (28) // ADC Status Register

+#define ADC_LCDR        (32) // ADC Last Converted Data Register

+#define ADC_IER         (36) // ADC Interrupt Enable Register

+#define ADC_IDR         (40) // ADC Interrupt Disable Register

+#define ADC_IMR         (44) // ADC Interrupt Mask Register

+#define ADC_CDR0        (48) // ADC Channel Data Register 0

+#define ADC_CDR1        (52) // ADC Channel Data Register 1

+#define ADC_CDR2        (56) // ADC Channel Data Register 2

+#define ADC_CDR3        (60) // ADC Channel Data Register 3

+#define ADC_CDR4        (64) // ADC Channel Data Register 4

+#define ADC_CDR5        (68) // ADC Channel Data Register 5

+#define ADC_CDR6        (72) // ADC Channel Data Register 6

+#define ADC_CDR7        (76) // ADC Channel Data Register 7

+#define ADC_RPR         (256) // Receive Pointer Register

+#define ADC_RCR         (260) // Receive Counter Register

+#define ADC_TPR         (264) // Transmit Pointer Register

+#define ADC_TCR         (268) // Transmit Counter Register

+#define ADC_RNPR        (272) // Receive Next Pointer Register

+#define ADC_RNCR        (276) // Receive Next Counter Register

+#define ADC_TNPR        (280) // Transmit Next Pointer Register

+#define ADC_TNCR        (284) // Transmit Next Counter Register

+#define ADC_PTCR        (288) // PDC Transfer Control Register

+#define ADC_PTSR        (292) // PDC Transfer Status Register

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST           (0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START           (0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN           (0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  (0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   (0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL          (0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                (0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                (0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                (0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                (0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                (0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                (0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  (0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES          (0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               (0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                (0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP           (0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          (0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 (0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL         (0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP         (0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM           (0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0             (0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1             (0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2             (0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3             (0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4             (0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5             (0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6             (0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7             (0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0            (0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1            (0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2            (0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3            (0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4            (0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5            (0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6            (0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7            (0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0           (0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1           (0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2           (0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3           (0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4           (0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5           (0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6           (0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7           (0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY            (0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE           (0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX           (0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF          (0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA           (0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA            (0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SSC structure ***

+#define SSC_CR          ( 0) // Control Register

+#define SSC_CMR         ( 4) // Clock Mode Register

+#define SSC_RCMR        (16) // Receive Clock ModeRegister

+#define SSC_RFMR        (20) // Receive Frame Mode Register

+#define SSC_TCMR        (24) // Transmit Clock Mode Register

+#define SSC_TFMR        (28) // Transmit Frame Mode Register

+#define SSC_RHR         (32) // Receive Holding Register

+#define SSC_THR         (36) // Transmit Holding Register

+#define SSC_RSHR        (48) // Receive Sync Holding Register

+#define SSC_TSHR        (52) // Transmit Sync Holding Register

+#define SSC_RC0R        (56) // Receive Compare 0 Register

+#define SSC_RC1R        (60) // Receive Compare 1 Register

+#define SSC_SR          (64) // Status Register

+#define SSC_IER         (68) // Interrupt Enable Register

+#define SSC_IDR         (72) // Interrupt Disable Register

+#define SSC_IMR         (76) // Interrupt Mask Register

+#define SSC_RPR         (256) // Receive Pointer Register

+#define SSC_RCR         (260) // Receive Counter Register

+#define SSC_TPR         (264) // Transmit Pointer Register

+#define SSC_TCR         (268) // Transmit Counter Register

+#define SSC_RNPR        (272) // Receive Next Pointer Register

+#define SSC_RNCR        (276) // Receive Next Counter Register

+#define SSC_TNPR        (280) // Transmit Next Pointer Register

+#define SSC_TNCR        (284) // Transmit Next Counter Register

+#define SSC_PTCR        (288) // PDC Transfer Control Register

+#define SSC_PTSR        (292) // PDC Transfer Status Register

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN            (0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS           (0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN            (0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS           (0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST           (0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS             (0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  (0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   (0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   (0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO             (0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 (0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            (0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              (0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI             (0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_CKG             (0x3 <<  6) // (SSC) Receive/Transmit Clock Gating Selection

+#define 	AT91C_SSC_CKG_NONE                 (0x0 <<  6) // (SSC) Receive/Transmit Clock Gating: None, continuous clock

+#define 	AT91C_SSC_CKG_LOW                  (0x1 <<  6) // (SSC) Receive/Transmit Clock enabled only if RF Low

+#define 	AT91C_SSC_CKG_HIGH                 (0x2 <<  6) // (SSC) Receive/Transmit Clock enabled only if RF High

+#define AT91C_SSC_START           (0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            (0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   (0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               (0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              (0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              (0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              (0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             (0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              (0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    (0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STOP            (0x1 << 12) // (SSC) Receive Stop Selection

+#define AT91C_SSC_STTOUT          (0x1 << 15) // (SSC) Receive/Transmit Start Output Selection

+#define AT91C_SSC_STTDLY          (0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD          (0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN          (0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP            (0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF            (0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB           (0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN           (0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS            (0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 (0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             (0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             (0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  (0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 (0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               (0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE          (0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF          (0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN           (0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY           (0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY         (0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX           (0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE          (0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY           (0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN           (0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX           (0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF          (0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_CP0             (0x1 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_CP1             (0x1 <<  9) // (SSC) Compare 1

+#define AT91C_SSC_TXSYN           (0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN           (0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA           (0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA           (0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+// *** Register offset in AT91S_USART structure ***

+#define US_CR           ( 0) // Control Register

+#define US_MR           ( 4) // Mode Register

+#define US_IER          ( 8) // Interrupt Enable Register

+#define US_IDR          (12) // Interrupt Disable Register

+#define US_IMR          (16) // Interrupt Mask Register

+#define US_CSR          (20) // Channel Status Register

+#define US_RHR          (24) // Receiver Holding Register

+#define US_THR          (28) // Transmitter Holding Register

+#define US_BRGR         (32) // Baud Rate Generator Register

+#define US_RTOR         (36) // Receiver Time-out Register

+#define US_TTGR         (40) // Transmitter Time-guard Register

+#define US_FIDI         (64) // FI_DI_Ratio Register

+#define US_NER          (68) // Nb Errors Register

+#define US_XXR          (72) // XON_XOFF Register

+#define US_IF           (76) // IRDA_FILTER Register

+#define US_RPR          (256) // Receive Pointer Register

+#define US_RCR          (260) // Receive Counter Register

+#define US_TPR          (264) // Transmit Pointer Register

+#define US_TCR          (268) // Transmit Counter Register

+#define US_RNPR         (272) // Receive Next Pointer Register

+#define US_RNCR         (276) // Receive Next Counter Register

+#define US_TNPR         (280) // Transmit Next Pointer Register

+#define US_TNCR         (284) // Transmit Next Counter Register

+#define US_PTCR         (288) // PDC Transfer Control Register

+#define US_PTSR         (292) // PDC Transfer Status Register

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTSTA           (0x1 <<  8) // (USART) Reset Status Bits

+#define AT91C_US_STTBRK           (0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK           (0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO            (0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA            (0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT            (0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK          (0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO            (0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN            (0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS           (0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN            (0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS           (0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE           (0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               (0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                (0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                (0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                (0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            (0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            (0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 (0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                (0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS             (0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                (0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                (0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 (0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  (0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL             (0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               (0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               (0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               (0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               (0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC             (0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP           (0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                (0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               (0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                (0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF             (0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9            (0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO             (0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER             (0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK            (0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK           (0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER         (0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER           (0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK            (0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT          (0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION        (0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK             (0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC             (0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC            (0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC            (0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC            (0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI               (0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR              (0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD              (0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS              (0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TWI structure ***

+#define TWI_CR          ( 0) // Control Register

+#define TWI_MMR         ( 4) // Master Mode Register

+#define TWI_SMR         ( 8) // Slave Mode Register

+#define TWI_IADR        (12) // Internal Address Register

+#define TWI_CWGR        (16) // Clock Waveform Generator Register

+#define TWI_SR          (32) // Status Register

+#define TWI_IER         (36) // Interrupt Enable Register

+#define TWI_IDR         (40) // Interrupt Disable Register

+#define TWI_IMR         (44) // Interrupt Mask Register

+#define TWI_RHR         (48) // Receive Holding Register

+#define TWI_THR         (52) // Transmit Holding Register

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START           (0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP            (0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN            (0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS           (0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SVEN            (0x1 <<  4) // (TWI) TWI Slave Transfer Enabled

+#define AT91C_TWI_SVDIS           (0x1 <<  5) // (TWI) TWI Slave Transfer Disabled

+#define AT91C_TWI_SWRST           (0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ          (0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   (0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               (0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               (0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               (0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD           (0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR            (0x7F << 16) // (TWI) Device Address

+// -------- TWI_SMR : (TWI Offset: 0x8) TWI Slave Mode Register -------- 

+#define AT91C_TWI_SADR            (0x7F << 16) // (TWI) Slave Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV           (0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV           (0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV           (0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP          (0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY           (0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY           (0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_SVREAD          (0x1 <<  3) // (TWI) Slave Read

+#define AT91C_TWI_SVACC           (0x1 <<  4) // (TWI) Slave Access

+#define AT91C_TWI_GCACC           (0x1 <<  5) // (TWI) General Call Access

+#define AT91C_TWI_OVRE            (0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE            (0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK            (0x1 <<  8) // (TWI) Not Acknowledged

+#define AT91C_TWI_ARBLST          (0x1 <<  9) // (TWI) Arbitration Lost

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TC structure ***

+#define TC_CCR          ( 0) // Channel Control Register

+#define TC_CMR          ( 4) // Channel Mode Register (Capture Mode / Waveform Mode)

+#define TC_CV           (16) // Counter Value

+#define TC_RA           (20) // Register A

+#define TC_RB           (24) // Register B

+#define TC_RC           (28) // Register C

+#define TC_SR           (32) // Status Register

+#define TC_IER          (36) // Interrupt Enable Register

+#define TC_IDR          (40) // Interrupt Disable Register

+#define TC_IMR          (44) // Interrupt Mask Register

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN            (0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS           (0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG            (0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS             (0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     (0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     (0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     (0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     (0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     (0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  (0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  (0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  (0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI             (0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST            (0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 (0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  (0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  (0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  (0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_LDBDIS           (0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_CPCDIS           (0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_ETRGEDG          (0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG          (0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_ABETRG           (0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_EEVT             (0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_NONE                 (0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_RISING               (0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_FALLING              (0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_BOTH                 (0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ENETRG           (0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL          (0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   (0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               (0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              (0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          (0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG           (0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE             (0x1 << 15) // (TC) 

+#define AT91C_TC_LDRA             (0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 (0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               (0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              (0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 (0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPA             (0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 (0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  (0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                (0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               (0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRB             (0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 (0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               (0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              (0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 (0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC             (0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 (0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  (0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                (0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               (0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_AEEVT            (0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 (0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  (0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                (0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               (0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG           (0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 (0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  (0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                (0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               (0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB             (0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 (0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  (0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                (0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               (0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC             (0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 (0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  (0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                (0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               (0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT            (0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 (0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  (0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                (0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               (0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG           (0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 (0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  (0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                (0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               (0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS            (0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS            (0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS             (0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS             (0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS             (0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS            (0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS            (0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRCS            (0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_ETRGS            (0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA            (0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB            (0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TCB structure ***

+#define TCB_TC0         ( 0) // TC Channel 0

+#define TCB_TC1         (64) // TC Channel 1

+#define TCB_TC2         (128) // TC Channel 2

+#define TCB_BCR         (192) // TC Block Control Register

+#define TCB_BMR         (196) // TC Block Mode Register

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC            (0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S         (0x1 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                (0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 (0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                (0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                (0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S         (0x1 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                (0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 (0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                (0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                (0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S         (0x1 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                (0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 (0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                (0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA2                (0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC_CH structure ***

+#define PWMC_CMR        ( 0) // Channel Mode Register

+#define PWMC_CDTYR      ( 4) // Channel Duty Cycle Register

+#define PWMC_CPRDR      ( 8) // Channel Period Register

+#define PWMC_CCNTR      (12) // Channel Counter Register

+#define PWMC_CUPDR      (16) // Channel Update Register

+#define PWMC_Reserved   (20) // Reserved

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE           (0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  (0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 (0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 (0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG           (0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL           (0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD            (0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY           (0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD           (0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT           (0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD           (0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC structure ***

+#define PWMC_MR         ( 0) // PWMC Mode Register

+#define PWMC_ENA        ( 4) // PWMC Enable Register

+#define PWMC_DIS        ( 8) // PWMC Disable Register

+#define PWMC_SR         (12) // PWMC Status Register

+#define PWMC_IER        (16) // PWMC Interrupt Enable Register

+#define PWMC_IDR        (20) // PWMC Interrupt Disable Register

+#define PWMC_IMR        (24) // PWMC Interrupt Mask Register

+#define PWMC_ISR        (28) // PWMC Interrupt Status Register

+#define PWMC_VR         (252) // PWMC Version Register

+#define PWMC_CH         (512) // PWMC Channel 0

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA           (0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA           (0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  (0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB           (0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB           (0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  (0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0          (0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1          (0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2          (0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3          (0x1 <<  3) // (PWMC) Channel ID 3

+#define AT91C_PWMC_CHID4          (0x1 <<  4) // (PWMC) Channel ID 4

+#define AT91C_PWMC_CHID5          (0x1 <<  5) // (PWMC) Channel ID 5

+#define AT91C_PWMC_CHID6          (0x1 <<  6) // (PWMC) Channel ID 6

+#define AT91C_PWMC_CHID7          (0x1 <<  7) // (PWMC) Channel ID 7

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+// *** Register offset in AT91S_UDP structure ***

+#define UDP_NUM         ( 0) // Frame Number Register

+#define UDP_GLBSTATE    ( 4) // Global State Register

+#define UDP_FADDR       ( 8) // Function Address Register

+#define UDP_IER         (16) // Interrupt Enable Register

+#define UDP_IDR         (20) // Interrupt Disable Register

+#define UDP_IMR         (24) // Interrupt Mask Register

+#define UDP_ISR         (28) // Interrupt Status Register

+#define UDP_ICR         (32) // Interrupt Clear Register

+#define UDP_RSTEP       (40) // Reset Endpoint Register

+#define UDP_CSR         (48) // Endpoint Control and Status Register

+#define UDP_FDR         (80) // Endpoint FIFO Data Register

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM         (0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR         (0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK          (0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN          (0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG           (0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_RMWUPE          (0x1 <<  2) // (UDP) Remote Wake Up Enable

+#define AT91C_UDP_RSMINPR         (0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD            (0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN             (0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0          (0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1          (0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2          (0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3          (0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4          (0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5          (0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_EPINT6          (0x1 <<  6) // (UDP) Endpoint 6 Interrupt

+#define AT91C_UDP_EPINT7          (0x1 <<  7) // (UDP) Endpoint 7 Interrupt

+#define AT91C_UDP_RXSUSP          (0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM           (0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM          (0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT          (0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP          (0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES       (0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0             (0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1             (0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2             (0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3             (0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4             (0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5             (0x1 <<  5) // (UDP) Reset Endpoint 5

+#define AT91C_UDP_EP6             (0x1 <<  6) // (UDP) Reset Endpoint 6

+#define AT91C_UDP_EP7             (0x1 <<  7) // (UDP) Reset Endpoint 7

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP          (0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0     (0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP         (0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR        (0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY        (0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL      (0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1     (0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR             (0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE          (0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 (0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              (0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             (0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              (0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               (0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              (0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               (0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE           (0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS           (0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT       (0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7S64

+// *****************************************************************************

+// ========== Register definition for SYSC peripheral ========== 

+#define AT91C_SYSC_SYSC_VRPM      (0xFFFFFD60) // (SYSC) Voltage Regulator Power Mode Register

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_ICCR            (0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_IECR            (0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_SMR             (0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_ISCR            (0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_EOICR           (0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_DCR             (0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_FFER            (0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_SVR             (0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_SPU             (0xFFFFF134) // (AIC) Spurious Vector Register

+#define AT91C_AIC_FFDR            (0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_FVR             (0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_FFSR            (0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_IMR             (0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_ISR             (0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IVR             (0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_IDCR            (0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_CISR            (0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IPR             (0xFFFFF10C) // (AIC) Interrupt Pending Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_C2R            (0xFFFFF244) // (DBGU) Chip ID2 Register

+#define AT91C_DBGU_THR            (0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_CSR            (0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_IDR            (0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_MR             (0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_FNTR           (0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_C1R            (0xFFFFF240) // (DBGU) Chip ID1 Register

+#define AT91C_DBGU_BRGR           (0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_RHR            (0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IMR            (0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_IER            (0xFFFFF208) // (DBGU) Interrupt Enable Register

+#define AT91C_DBGU_CR             (0xFFFFF200) // (DBGU) Control Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TNCR           (0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+#define AT91C_DBGU_RNCR           (0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR           (0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR           (0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_RCR            (0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_TCR            (0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RPR            (0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_TPR            (0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RNPR           (0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR           (0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_IMR            (0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_IER            (0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_OWDR           (0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_ISR            (0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_PPUDR          (0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_MDSR           (0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_MDER           (0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PER            (0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_PSR            (0xFFFFF408) // (PIOA) PIO Status Register

+#define AT91C_PIOA_OER            (0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_BSR            (0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_PPUER          (0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_MDDR           (0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_PDR            (0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_ODR            (0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_IFDR           (0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_ABSR           (0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_ASR            (0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_PPUSR          (0xFFFFF468) // (PIOA) Pad Pull-up Status Register

+#define AT91C_PIOA_ODSR           (0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_SODR           (0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_IFSR           (0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_IFER           (0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_OSR            (0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_IDR            (0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_PDSR           (0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_CODR           (0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_OWSR           (0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_OWER           (0xFFFFF4A0) // (PIOA) Output Write Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_PLLR           (0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR           (0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+#define AT91C_CKGR_MOR            (0xFFFFFC20) // (CKGR) Main Oscillator Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_SCSR            (0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_SCER            (0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR             (0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IDR             (0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_PCDR            (0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCDR            (0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_SR              (0xFFFFFC68) // (PMC) Status Register

+#define AT91C_PMC_IER             (0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_MCKR            (0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_MOR             (0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PCER            (0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCSR            (0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_PLLR            (0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_MCFR            (0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_PCKR            (0xFFFFFC40) // (PMC) Programmable Clock Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RSR            (0xFFFFFD04) // (RSTC) Reset Status Register

+#define AT91C_RSTC_RMR            (0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RCR            (0xFFFFFD00) // (RSTC) Reset Control Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR           (0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTAR           (0xFFFFFD24) // (RTTC) Real-time Alarm Register

+#define AT91C_RTTC_RTVR           (0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTMR           (0xFFFFFD20) // (RTTC) Real-time Mode Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIIR           (0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PISR           (0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIVR           (0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PIMR           (0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDMR           (0xFFFFFD44) // (WDTC) Watchdog Mode Register

+#define AT91C_WDTC_WDSR           (0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDCR           (0xFFFFFD40) // (WDTC) Watchdog Control Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_FCR              (0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_ASR              (0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_FSR              (0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR              (0xFFFFFF60) // (MC) MC Flash Mode Register

+#define AT91C_MC_AASR             (0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_RCR              (0xFFFFFF00) // (MC) MC Remap Control Register

+// ========== Register definition for PDC_SPI peripheral ========== 

+#define AT91C_SPI_PTCR            (0xFFFE0120) // (PDC_SPI) PDC Transfer Control Register

+#define AT91C_SPI_TNPR            (0xFFFE0118) // (PDC_SPI) Transmit Next Pointer Register

+#define AT91C_SPI_RNPR            (0xFFFE0110) // (PDC_SPI) Receive Next Pointer Register

+#define AT91C_SPI_TPR             (0xFFFE0108) // (PDC_SPI) Transmit Pointer Register

+#define AT91C_SPI_RPR             (0xFFFE0100) // (PDC_SPI) Receive Pointer Register

+#define AT91C_SPI_PTSR            (0xFFFE0124) // (PDC_SPI) PDC Transfer Status Register

+#define AT91C_SPI_TNCR            (0xFFFE011C) // (PDC_SPI) Transmit Next Counter Register

+#define AT91C_SPI_RNCR            (0xFFFE0114) // (PDC_SPI) Receive Next Counter Register

+#define AT91C_SPI_TCR             (0xFFFE010C) // (PDC_SPI) Transmit Counter Register

+#define AT91C_SPI_RCR             (0xFFFE0104) // (PDC_SPI) Receive Counter Register

+// ========== Register definition for SPI peripheral ========== 

+#define AT91C_SPI_CSR             (0xFFFE0030) // (SPI) Chip Select Register

+#define AT91C_SPI_IDR             (0xFFFE0018) // (SPI) Interrupt Disable Register

+#define AT91C_SPI_SR              (0xFFFE0010) // (SPI) Status Register

+#define AT91C_SPI_RDR             (0xFFFE0008) // (SPI) Receive Data Register

+#define AT91C_SPI_CR              (0xFFFE0000) // (SPI) Control Register

+#define AT91C_SPI_IMR             (0xFFFE001C) // (SPI) Interrupt Mask Register

+#define AT91C_SPI_IER             (0xFFFE0014) // (SPI) Interrupt Enable Register

+#define AT91C_SPI_TDR             (0xFFFE000C) // (SPI) Transmit Data Register

+#define AT91C_SPI_MR              (0xFFFE0004) // (SPI) Mode Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTCR            (0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR            (0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_RNPR            (0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_TPR             (0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RPR             (0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_PTSR            (0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_TNCR            (0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNCR            (0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_TCR             (0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_RCR             (0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_IMR             (0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+#define AT91C_ADC_CDR4            (0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR2            (0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR0            (0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR7            (0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR1            (0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_CDR3            (0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR5            (0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_MR              (0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_CDR6            (0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_CR              (0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CHER            (0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR            (0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_IER             (0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_SR              (0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CHDR            (0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_IDR             (0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_LCDR            (0xFFFD8020) // (ADC) ADC Last Converted Data Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_PTCR            (0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TNPR            (0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_RNPR            (0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TPR             (0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_RPR             (0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_PTSR            (0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+#define AT91C_SSC_TNCR            (0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RNCR            (0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TCR             (0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR             (0xFFFD4104) // (PDC_SSC) Receive Counter Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RFMR            (0xFFFD4014) // (SSC) Receive Frame Mode Register

+#define AT91C_SSC_CMR             (0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_IDR             (0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_SR              (0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_RC0R            (0xFFFD4038) // (SSC) Receive Compare 0 Register

+#define AT91C_SSC_RSHR            (0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_RHR             (0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_TCMR            (0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_RCMR            (0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_CR              (0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR             (0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_IER             (0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_RC1R            (0xFFFD403C) // (SSC) Receive Compare 1 Register

+#define AT91C_SSC_TSHR            (0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_THR             (0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_TFMR            (0xFFFD401C) // (SSC) Transmit Frame Mode Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_PTSR            (0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNCR            (0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_RNCR            (0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_TCR             (0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_RCR             (0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_PTCR            (0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TNPR            (0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RNPR            (0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_TPR             (0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+#define AT91C_US1_RPR             (0xFFFC4100) // (PDC_US1) Receive Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_XXR             (0xFFFC4048) // (US1) XON_XOFF Register

+#define AT91C_US1_RHR             (0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_IMR             (0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_IER             (0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_CR              (0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_RTOR            (0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_THR             (0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_CSR             (0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR             (0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_FIDI            (0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_BRGR            (0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_TTGR            (0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_IF              (0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER             (0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_MR              (0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_PTCR            (0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_TNPR            (0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR            (0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TPR             (0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RPR             (0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_PTSR            (0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR            (0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_RNCR            (0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+#define AT91C_US0_TCR             (0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_RCR             (0xFFFC0104) // (PDC_US0) Receive Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_TTGR            (0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_BRGR            (0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_RHR             (0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IMR             (0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_NER             (0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_RTOR            (0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_XXR             (0xFFFC0048) // (US0) XON_XOFF Register

+#define AT91C_US0_FIDI            (0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_CR              (0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IER             (0xFFFC0008) // (US0) Interrupt Enable Register

+#define AT91C_US0_IF              (0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_MR              (0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_IDR             (0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_CSR             (0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_THR             (0xFFFC001C) // (US0) Transmitter Holding Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_RHR             (0xFFFB8030) // (TWI) Receive Holding Register

+#define AT91C_TWI_IDR             (0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_SR              (0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_CWGR            (0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_SMR             (0xFFFB8008) // (TWI) Slave Mode Register

+#define AT91C_TWI_CR              (0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_THR             (0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IMR             (0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_IER             (0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_IADR            (0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR             (0xFFFB8004) // (TWI) Master Mode Register

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_IMR             (0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_IER             (0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_RC              (0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_RA              (0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_CMR             (0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_IDR             (0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_SR              (0xFFFA00A0) // (TC2) Status Register

+#define AT91C_TC2_RB              (0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_CV              (0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_CCR             (0xFFFA0080) // (TC2) Channel Control Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_IMR             (0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_IER             (0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_RC              (0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_RA              (0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_CMR             (0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_IDR             (0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR              (0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_RB              (0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CV              (0xFFFA0050) // (TC1) Counter Value

+#define AT91C_TC1_CCR             (0xFFFA0040) // (TC1) Channel Control Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_IMR             (0xFFFA002C) // (TC0) Interrupt Mask Register

+#define AT91C_TC0_IER             (0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RC              (0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RA              (0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_CMR             (0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IDR             (0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_SR              (0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RB              (0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CV              (0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_CCR             (0xFFFA0000) // (TC0) Channel Control Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR             (0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR             (0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_CH3_CUPDR           (0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_CH3_CPRDR           (0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_CH3_CMR             (0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+#define AT91C_CH3_Reserved        (0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_CH3_CCNTR           (0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_CH3_CDTYR           (0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_CH2_CUPDR           (0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_CH2_CPRDR           (0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_CH2_CMR             (0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_CH2_Reserved        (0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_CH2_CCNTR           (0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_CH2_CDTYR           (0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_CH1_CUPDR           (0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_CH1_CPRDR           (0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_CH1_CMR             (0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+#define AT91C_CH1_Reserved        (0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_CH1_CCNTR           (0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_CH1_CDTYR           (0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_CH0_CUPDR           (0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_CH0_CPRDR           (0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_CH0_CMR             (0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_CH0_Reserved        (0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_CH0_CCNTR           (0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+#define AT91C_CH0_CDTYR           (0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_VR             (0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR            (0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_IDR            (0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_SR             (0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_ENA            (0xFFFCC004) // (PWMC) PWMC Enable Register

+#define AT91C_PWMC_IMR            (0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR             (0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_DIS            (0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER            (0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_ISR             (0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_IDR             (0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_GLBSTATE        (0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_FDR             (0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_CSR             (0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_RSTEP           (0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_ICR             (0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_IMR             (0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_IER             (0xFFFB0010) // (UDP) Interrupt Enable Register

+#define AT91C_UDP_FADDR           (0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM             (0xFFFB0000) // (UDP) Frame Number Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_PIO_PA0             (1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_PWM0            (AT91C_PIO_PA0) //  PWM Channel 0

+#define AT91C_PA0_TIOA0           (AT91C_PIO_PA0) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA1             (1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_PWM1            (AT91C_PIO_PA1) //  PWM Channel 1

+#define AT91C_PA1_TIOB0           (AT91C_PIO_PA1) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA10            (1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_DTXD           (AT91C_PIO_PA10) //  DBGU Debug Transmit Data

+#define AT91C_PA10_NPCS2          (AT91C_PIO_PA10) //  SPI Peripheral Chip Select 2

+#define AT91C_PIO_PA11            (1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_NPCS0          (AT91C_PIO_PA11) //  SPI Peripheral Chip Select 0

+#define AT91C_PA11_PWM0           (AT91C_PIO_PA11) //  PWM Channel 0

+#define AT91C_PIO_PA12            (1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_MISO           (AT91C_PIO_PA12) //  SPI Master In Slave

+#define AT91C_PA12_PWM1           (AT91C_PIO_PA12) //  PWM Channel 1

+#define AT91C_PIO_PA13            (1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_MOSI           (AT91C_PIO_PA13) //  SPI Master Out Slave

+#define AT91C_PA13_PWM2           (AT91C_PIO_PA13) //  PWM Channel 2

+#define AT91C_PIO_PA14            (1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_SPCK           (AT91C_PIO_PA14) //  SPI Serial Clock

+#define AT91C_PA14_PWM3           (AT91C_PIO_PA14) //  PWM Channel 3

+#define AT91C_PIO_PA15            (1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_TF             (AT91C_PIO_PA15) //  SSC Transmit Frame Sync

+#define AT91C_PA15_TIOA1          (AT91C_PIO_PA15) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA16            (1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_TK             (AT91C_PIO_PA16) //  SSC Transmit Clock

+#define AT91C_PA16_TIOB1          (AT91C_PIO_PA16) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA17            (1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_TD             (AT91C_PIO_PA17) //  SSC Transmit data

+#define AT91C_PA17_PCK1           (AT91C_PIO_PA17) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA18            (1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_RD             (AT91C_PIO_PA18) //  SSC Receive Data

+#define AT91C_PA18_PCK2           (AT91C_PIO_PA18) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA19            (1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_RK             (AT91C_PIO_PA19) //  SSC Receive Clock

+#define AT91C_PA19_FIQ            (AT91C_PIO_PA19) //  AIC Fast Interrupt Input

+#define AT91C_PIO_PA2             (1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_PWM2            (AT91C_PIO_PA2) //  PWM Channel 2

+#define AT91C_PA2_SCK0            (AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PIO_PA20            (1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_RF             (AT91C_PIO_PA20) //  SSC Receive Frame Sync

+#define AT91C_PA20_IRQ0           (AT91C_PIO_PA20) //  External Interrupt 0

+#define AT91C_PIO_PA21            (1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_RXD1           (AT91C_PIO_PA21) //  USART 1 Receive Data

+#define AT91C_PA21_PCK1           (AT91C_PIO_PA21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA22            (1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TXD1           (AT91C_PIO_PA22) //  USART 1 Transmit Data

+#define AT91C_PA22_NPCS3          (AT91C_PIO_PA22) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA23            (1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_SCK1           (AT91C_PIO_PA23) //  USART 1 Serial Clock

+#define AT91C_PA23_PWM0           (AT91C_PIO_PA23) //  PWM Channel 0

+#define AT91C_PIO_PA24            (1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RTS1           (AT91C_PIO_PA24) //  USART 1 Ready To Send

+#define AT91C_PA24_PWM1           (AT91C_PIO_PA24) //  PWM Channel 1

+#define AT91C_PIO_PA25            (1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_CTS1           (AT91C_PIO_PA25) //  USART 1 Clear To Send

+#define AT91C_PA25_PWM2           (AT91C_PIO_PA25) //  PWM Channel 2

+#define AT91C_PIO_PA26            (1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_DCD1           (AT91C_PIO_PA26) //  USART 1 Data Carrier Detect

+#define AT91C_PA26_TIOA2          (AT91C_PIO_PA26) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PIO_PA27            (1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DTR1           (AT91C_PIO_PA27) //  USART 1 Data Terminal ready

+#define AT91C_PA27_TIOB2          (AT91C_PIO_PA27) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PIO_PA28            (1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DSR1           (AT91C_PIO_PA28) //  USART 1 Data Set ready

+#define AT91C_PA28_TCLK1          (AT91C_PIO_PA28) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PA29            (1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_RI1            (AT91C_PIO_PA29) //  USART 1 Ring Indicator

+#define AT91C_PA29_TCLK2          (AT91C_PIO_PA29) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA3             (1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_TWD             (AT91C_PIO_PA3) //  TWI Two-wire Serial Data

+#define AT91C_PA3_NPCS3           (AT91C_PIO_PA3) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA30            (1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ1           (AT91C_PIO_PA30) //  External Interrupt 1

+#define AT91C_PA30_NPCS2          (AT91C_PIO_PA30) //  SPI Peripheral Chip Select 2

+#define AT91C_PIO_PA31            (1 << 31) // Pin Controlled by PA31

+#define AT91C_PA31_NPCS1          (AT91C_PIO_PA31) //  SPI Peripheral Chip Select 1

+#define AT91C_PA31_PCK2           (AT91C_PIO_PA31) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4             (1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_TWCK            (AT91C_PIO_PA4) //  TWI Two-wire Serial Clock

+#define AT91C_PA4_TCLK0           (AT91C_PIO_PA4) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PA5             (1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD0            (AT91C_PIO_PA5) //  USART 0 Receive Data

+#define AT91C_PA5_NPCS3           (AT91C_PIO_PA5) //  SPI Peripheral Chip Select 3

+#define AT91C_PIO_PA6             (1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD0            (AT91C_PIO_PA6) //  USART 0 Transmit Data

+#define AT91C_PA6_PCK0            (AT91C_PIO_PA6) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PA7             (1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_RTS0            (AT91C_PIO_PA7) //  USART 0 Ready To Send

+#define AT91C_PA7_PWM3            (AT91C_PIO_PA7) //  PWM Channel 3

+#define AT91C_PIO_PA8             (1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_CTS0            (AT91C_PIO_PA8) //  USART 0 Clear To Send

+#define AT91C_PA8_ADTRG           (AT91C_PIO_PA8) //  ADC External Trigger

+#define AT91C_PIO_PA9             (1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_DRXD            (AT91C_PIO_PA9) //  DBGU Debug Receive Data

+#define AT91C_PA9_NPCS1           (AT91C_PIO_PA9) //  SPI Peripheral Chip Select 1

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_ID_FIQ              ( 0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS              ( 1) // System Peripheral

+#define AT91C_ID_PIOA             ( 2) // Parallel IO Controller

+#define AT91C_ID_3_Reserved       ( 3) // Reserved

+#define AT91C_ID_ADC              ( 4) // Analog-to-Digital Converter

+#define AT91C_ID_SPI              ( 5) // Serial Peripheral Interface

+#define AT91C_ID_US0              ( 6) // USART 0

+#define AT91C_ID_US1              ( 7) // USART 1

+#define AT91C_ID_SSC              ( 8) // Serial Synchronous Controller

+#define AT91C_ID_TWI              ( 9) // Two-Wire Interface

+#define AT91C_ID_PWMC             (10) // PWM Controller

+#define AT91C_ID_UDP              (11) // USB Device Port

+#define AT91C_ID_TC0              (12) // Timer Counter 0

+#define AT91C_ID_TC1              (13) // Timer Counter 1

+#define AT91C_ID_TC2              (14) // Timer Counter 2

+#define AT91C_ID_15_Reserved      (15) // Reserved

+#define AT91C_ID_16_Reserved      (16) // Reserved

+#define AT91C_ID_17_Reserved      (17) // Reserved

+#define AT91C_ID_18_Reserved      (18) // Reserved

+#define AT91C_ID_19_Reserved      (19) // Reserved

+#define AT91C_ID_20_Reserved      (20) // Reserved

+#define AT91C_ID_21_Reserved      (21) // Reserved

+#define AT91C_ID_22_Reserved      (22) // Reserved

+#define AT91C_ID_23_Reserved      (23) // Reserved

+#define AT91C_ID_24_Reserved      (24) // Reserved

+#define AT91C_ID_25_Reserved      (25) // Reserved

+#define AT91C_ID_26_Reserved      (26) // Reserved

+#define AT91C_ID_27_Reserved      (27) // Reserved

+#define AT91C_ID_28_Reserved      (28) // Reserved

+#define AT91C_ID_29_Reserved      (29) // Reserved

+#define AT91C_ID_IRQ0             (30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1             (31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_BASE_SYSC           (0xFFFFF000) // (SYSC) Base Address

+#define AT91C_BASE_AIC            (0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_DBGU           (0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PDC_DBGU       (0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_PIOA           (0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_CKGR           (0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC            (0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC           (0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC           (0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC           (0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC           (0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_MC             (0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI        (0xFFFE0100) // (PDC_SPI) Base Address

+#define AT91C_BASE_SPI            (0xFFFE0000) // (SPI) Base Address

+#define AT91C_BASE_PDC_ADC        (0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC            (0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_SSC        (0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC            (0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_PDC_US1        (0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1            (0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0        (0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0            (0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_TWI            (0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_TC2            (0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TC1            (0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC0            (0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TCB            (0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_PWMC_CH3       (0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2       (0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1       (0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0       (0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC           (0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP            (0xFFFB0000) // (UDP) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7S64

+// *****************************************************************************

+#define AT91C_ISRAM	              (0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	         (0x00004000) // Internal SRAM size in byte (16 Kbyte)

+#define AT91C_IFLASH	             (0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	        (0x00010000) // Internal ROM size in byte (64 Kbyte)

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128.h
new file mode 100644
index 0000000..ae4f35f
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128.h
@@ -0,0 +1,2715 @@
+//  ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+//  ----------------------------------------------------------------------------

+//  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//  ----------------------------------------------------------------------------

+// File Name           : AT91SAM7X128.h

+// Object              : AT91SAM7X128 definitions

+// Generated           : AT91 SW Application Group  05/20/2005 (16:22:23)

+// 

+// CVS Reference       : /AT91SAM7X128.pl/1.14/Tue May 10 12:12:05 2005//

+// CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+//  ----------------------------------------------------------------------------

+

+#ifndef AT91SAM7X128_H

+#define AT91SAM7X128_H

+

+typedef volatile unsigned int AT91_REG;// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+typedef struct _AT91S_SYS {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+	AT91_REG	 Reserved2[45]; 	// 

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved3[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved4[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+	AT91_REG	 Reserved5[54]; 	// 

+	AT91_REG	 PIOA_PER; 	// PIO Enable Register

+	AT91_REG	 PIOA_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOA_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved6[1]; 	// 

+	AT91_REG	 PIOA_OER; 	// Output Enable Register

+	AT91_REG	 PIOA_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOA_OSR; 	// Output Status Register

+	AT91_REG	 Reserved7[1]; 	// 

+	AT91_REG	 PIOA_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOA_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOA_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved8[1]; 	// 

+	AT91_REG	 PIOA_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOA_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOA_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOA_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOA_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOA_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOA_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOA_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOA_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOA_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOA_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved9[1]; 	// 

+	AT91_REG	 PIOA_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOA_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOA_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved10[1]; 	// 

+	AT91_REG	 PIOA_ASR; 	// Select A Register

+	AT91_REG	 PIOA_BSR; 	// Select B Register

+	AT91_REG	 PIOA_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved11[9]; 	// 

+	AT91_REG	 PIOA_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOA_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOA_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved12[85]; 	// 

+	AT91_REG	 PIOB_PER; 	// PIO Enable Register

+	AT91_REG	 PIOB_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOB_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved13[1]; 	// 

+	AT91_REG	 PIOB_OER; 	// Output Enable Register

+	AT91_REG	 PIOB_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOB_OSR; 	// Output Status Register

+	AT91_REG	 Reserved14[1]; 	// 

+	AT91_REG	 PIOB_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOB_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOB_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved15[1]; 	// 

+	AT91_REG	 PIOB_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOB_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOB_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOB_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOB_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOB_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOB_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOB_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOB_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOB_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOB_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved16[1]; 	// 

+	AT91_REG	 PIOB_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOB_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOB_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved17[1]; 	// 

+	AT91_REG	 PIOB_ASR; 	// Select A Register

+	AT91_REG	 PIOB_BSR; 	// Select B Register

+	AT91_REG	 PIOB_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved18[9]; 	// 

+	AT91_REG	 PIOB_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOB_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOB_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved19[341]; 	// 

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved20[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved21[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved22[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved23[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved24[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved25[36]; 	// 

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+	AT91_REG	 Reserved26[5]; 	// 

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+	AT91_REG	 Reserved27[5]; 	// 

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_SYS, *AT91PS_SYS;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+typedef struct _AT91S_AIC {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+} AT91S_AIC, *AT91PS_AIC;

+

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR       ((unsigned int) 0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               ((unsigned int) 0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              ((unsigned int) 0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE     ((unsigned int) 0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       ((unsigned int) 0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        ((unsigned int) 0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           ((unsigned int) 0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        ((unsigned int) 0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ        ((unsigned int) 0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ        ((unsigned int) 0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT    ((unsigned int) 0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK    ((unsigned int) 0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+typedef struct _AT91S_PDC {

+	AT91_REG	 PDC_RPR; 	// Receive Pointer Register

+	AT91_REG	 PDC_RCR; 	// Receive Counter Register

+	AT91_REG	 PDC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 PDC_TCR; 	// Transmit Counter Register

+	AT91_REG	 PDC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 PDC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 PDC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 PDC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 PDC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 PDC_PTSR; 	// PDC Transfer Status Register

+} AT91S_PDC, *AT91PS_PDC;

+

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN       ((unsigned int) 0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS      ((unsigned int) 0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN       ((unsigned int) 0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS      ((unsigned int) 0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+typedef struct _AT91S_DBGU {

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved0[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved1[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+} AT91S_DBGU, *AT91PS_DBGU;

+

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX        ((unsigned int) 0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX        ((unsigned int) 0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN         ((unsigned int) 0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS        ((unsigned int) 0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN         ((unsigned int) 0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS        ((unsigned int) 0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA       ((unsigned int) 0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR          ((unsigned int) 0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 ((unsigned int) 0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  ((unsigned int) 0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                ((unsigned int) 0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 ((unsigned int) 0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 ((unsigned int) 0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           ((unsigned int) 0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE       ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY        ((unsigned int) 0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY        ((unsigned int) 0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX        ((unsigned int) 0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX        ((unsigned int) 0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE         ((unsigned int) 0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME        ((unsigned int) 0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE         ((unsigned int) 0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY      ((unsigned int) 0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE       ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF       ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX      ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX      ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST  ((unsigned int) 0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+typedef struct _AT91S_PIO {

+	AT91_REG	 PIO_PER; 	// PIO Enable Register

+	AT91_REG	 PIO_PDR; 	// PIO Disable Register

+	AT91_REG	 PIO_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PIO_OER; 	// Output Enable Register

+	AT91_REG	 PIO_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIO_OSR; 	// Output Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PIO_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIO_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIO_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PIO_SODR; 	// Set Output Data Register

+	AT91_REG	 PIO_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIO_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIO_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIO_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIO_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIO_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIO_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIO_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIO_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIO_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved3[1]; 	// 

+	AT91_REG	 PIO_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIO_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIO_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved4[1]; 	// 

+	AT91_REG	 PIO_ASR; 	// Select A Register

+	AT91_REG	 PIO_BSR; 	// Select B Register

+	AT91_REG	 PIO_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved5[9]; 	// 

+	AT91_REG	 PIO_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIO_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIO_OWSR; 	// Output Write Status Register

+} AT91S_PIO, *AT91PS_PIO;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+typedef struct _AT91S_CKGR {

+	AT91_REG	 CKGR_MOR; 	// Main Oscillator Register

+	AT91_REG	 CKGR_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 CKGR_PLLR; 	// PLL Register

+} AT91S_CKGR, *AT91PS_CKGR;

+

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN     ((unsigned int) 0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS  ((unsigned int) 0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT    ((unsigned int) 0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF      ((unsigned int) 0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY    ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV        ((unsigned int) 0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    ((unsigned int) 0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               ((unsigned int) 0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT   ((unsigned int) 0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT        ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL        ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV     ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+typedef struct _AT91S_PMC {

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved3[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved4[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+} AT91S_PMC, *AT91PS_PMC;

+

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK         ((unsigned int) 0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP         ((unsigned int) 0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0        ((unsigned int) 0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1        ((unsigned int) 0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2        ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3        ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS         ((unsigned int) 0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             ((unsigned int) 0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             ((unsigned int) 0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              ((unsigned int) 0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES        ((unsigned int) 0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  ((unsigned int) 0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                ((unsigned int) 0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                ((unsigned int) 0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                ((unsigned int) 0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               ((unsigned int) 0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               ((unsigned int) 0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               ((unsigned int) 0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS       ((unsigned int) 0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK        ((unsigned int) 0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY      ((unsigned int) 0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY     ((unsigned int) 0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY     ((unsigned int) 0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY     ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY     ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RSTC {

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+} AT91S_RSTC, *AT91PS_RSTC;

+

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST    ((unsigned int) 0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST     ((unsigned int) 0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST     ((unsigned int) 0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY        ((unsigned int) 0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS      ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS     ((unsigned int) 0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP     ((unsigned int) 0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              ((unsigned int) 0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               ((unsigned int) 0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             ((unsigned int) 0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             ((unsigned int) 0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 ((unsigned int) 0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             ((unsigned int) 0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL      ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP      ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN     ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN    ((unsigned int) 0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL      ((unsigned int) 0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN     ((unsigned int) 0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RTTC {

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+} AT91S_RTTC, *AT91PS_RTTC;

+

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES     ((unsigned int) 0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN     ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN  ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST     ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV       ((unsigned int) 0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV       ((unsigned int) 0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS       ((unsigned int) 0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC     ((unsigned int) 0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PITC {

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+} AT91S_PITC, *AT91PS_PITC;

+

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV        ((unsigned int) 0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN      ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN     ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS       ((unsigned int) 0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV       ((unsigned int) 0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT      ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_WDTC {

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+} AT91S_WDTC, *AT91PS_WDTC;

+

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT     ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY        ((unsigned int) 0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV        ((unsigned int) 0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN     ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN    ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC    ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS      ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD        ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT   ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT  ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF      ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR      ((unsigned int) 0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_VREG {

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_VREG, *AT91PS_VREG;

+

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY     ((unsigned int) 0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_MC {

+	AT91_REG	 MC_RCR; 	// MC Remap Control Register

+	AT91_REG	 MC_ASR; 	// MC Abort Status Register

+	AT91_REG	 MC_AASR; 	// MC Abort Address Status Register

+	AT91_REG	 Reserved0[21]; 	// 

+	AT91_REG	 MC_FMR; 	// MC Flash Mode Register

+	AT91_REG	 MC_FCR; 	// MC Flash Command Register

+	AT91_REG	 MC_FSR; 	// MC Flash Status Register

+} AT91S_MC, *AT91PS_MC;

+

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB          ((unsigned int) 0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD       ((unsigned int) 0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD       ((unsigned int) 0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ        ((unsigned int) 0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 ((unsigned int) 0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                ((unsigned int) 0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 ((unsigned int) 0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP       ((unsigned int) 0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                ((unsigned int) 0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                ((unsigned int) 0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                ((unsigned int) 0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0         ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1         ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0       ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1       ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY         ((unsigned int) 0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE        ((unsigned int) 0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE        ((unsigned int) 0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP         ((unsigned int) 0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS          ((unsigned int) 0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 ((unsigned int) 0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 ((unsigned int) 0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 ((unsigned int) 0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 ((unsigned int) 0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN         ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD         ((unsigned int) 0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         ((unsigned int) 0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN        ((unsigned int) 0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY          ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY     ((unsigned int) 0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0       ((unsigned int) 0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1       ((unsigned int) 0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2       ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3       ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4       ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5       ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6       ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7       ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0       ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1       ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2       ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3       ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4       ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5       ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6       ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7       ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8       ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9       ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10      ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11      ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12      ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13      ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14      ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15      ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+typedef struct _AT91S_SPI {

+	AT91_REG	 SPI_CR; 	// Control Register

+	AT91_REG	 SPI_MR; 	// Mode Register

+	AT91_REG	 SPI_RDR; 	// Receive Data Register

+	AT91_REG	 SPI_TDR; 	// Transmit Data Register

+	AT91_REG	 SPI_SR; 	// Status Register

+	AT91_REG	 SPI_IER; 	// Interrupt Enable Register

+	AT91_REG	 SPI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SPI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91_REG	 SPI_CSR[4]; 	// Chip Select Register

+	AT91_REG	 Reserved1[48]; 	// 

+	AT91_REG	 SPI_RPR; 	// Receive Pointer Register

+	AT91_REG	 SPI_RCR; 	// Receive Counter Register

+	AT91_REG	 SPI_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SPI_TCR; 	// Transmit Counter Register

+	AT91_REG	 SPI_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SPI_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SPI_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SPI_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SPI_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SPI_PTSR; 	// PDC Transfer Status Register

+} AT91S_SPI, *AT91PS_SPI;

+

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN       ((unsigned int) 0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS      ((unsigned int) 0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST       ((unsigned int) 0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER    ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR        ((unsigned int) 0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS          ((unsigned int) 0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                ((unsigned int) 0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             ((unsigned int) 0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC      ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV        ((unsigned int) 0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS     ((unsigned int) 0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB         ((unsigned int) 0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS         ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD          ((unsigned int) 0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD          ((unsigned int) 0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF        ((unsigned int) 0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE        ((unsigned int) 0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF        ((unsigned int) 0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES       ((unsigned int) 0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX       ((unsigned int) 0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX       ((unsigned int) 0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF      ((unsigned int) 0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE      ((unsigned int) 0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR        ((unsigned int) 0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY     ((unsigned int) 0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS      ((unsigned int) 0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL        ((unsigned int) 0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA       ((unsigned int) 0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT       ((unsigned int) 0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS        ((unsigned int) 0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    ((unsigned int) 0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    ((unsigned int) 0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   ((unsigned int) 0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   ((unsigned int) 0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   ((unsigned int) 0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   ((unsigned int) 0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   ((unsigned int) 0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   ((unsigned int) 0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   ((unsigned int) 0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR        ((unsigned int) 0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS       ((unsigned int) 0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+typedef struct _AT91S_USART {

+	AT91_REG	 US_CR; 	// Control Register

+	AT91_REG	 US_MR; 	// Mode Register

+	AT91_REG	 US_IER; 	// Interrupt Enable Register

+	AT91_REG	 US_IDR; 	// Interrupt Disable Register

+	AT91_REG	 US_IMR; 	// Interrupt Mask Register

+	AT91_REG	 US_CSR; 	// Channel Status Register

+	AT91_REG	 US_RHR; 	// Receiver Holding Register

+	AT91_REG	 US_THR; 	// Transmitter Holding Register

+	AT91_REG	 US_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 US_RTOR; 	// Receiver Time-out Register

+	AT91_REG	 US_TTGR; 	// Transmitter Time-guard Register

+	AT91_REG	 Reserved0[5]; 	// 

+	AT91_REG	 US_FIDI; 	// FI_DI_Ratio Register

+	AT91_REG	 US_NER; 	// Nb Errors Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 US_IF; 	// IRDA_FILTER Register

+	AT91_REG	 Reserved2[44]; 	// 

+	AT91_REG	 US_RPR; 	// Receive Pointer Register

+	AT91_REG	 US_RCR; 	// Receive Counter Register

+	AT91_REG	 US_TPR; 	// Transmit Pointer Register

+	AT91_REG	 US_TCR; 	// Transmit Counter Register

+	AT91_REG	 US_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 US_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 US_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 US_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 US_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 US_PTSR; 	// PDC Transfer Status Register

+} AT91S_USART, *AT91PS_USART;

+

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK       ((unsigned int) 0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK       ((unsigned int) 0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO        ((unsigned int) 0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA        ((unsigned int) 0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT        ((unsigned int) 0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK      ((unsigned int) 0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO        ((unsigned int) 0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN        ((unsigned int) 0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS       ((unsigned int) 0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN        ((unsigned int) 0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS       ((unsigned int) 0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE       ((unsigned int) 0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               ((unsigned int) 0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                ((unsigned int) 0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                ((unsigned int) 0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                ((unsigned int) 0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            ((unsigned int) 0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            ((unsigned int) 0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 ((unsigned int) 0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                ((unsigned int) 0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS         ((unsigned int) 0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                ((unsigned int) 0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                ((unsigned int) 0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 ((unsigned int) 0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  ((unsigned int) 0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL         ((unsigned int) 0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               ((unsigned int) 0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               ((unsigned int) 0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               ((unsigned int) 0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               ((unsigned int) 0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC         ((unsigned int) 0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP       ((unsigned int) 0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                ((unsigned int) 0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               ((unsigned int) 0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                ((unsigned int) 0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF         ((unsigned int) 0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9        ((unsigned int) 0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO         ((unsigned int) 0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER         ((unsigned int) 0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK        ((unsigned int) 0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK       ((unsigned int) 0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER     ((unsigned int) 0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER       ((unsigned int) 0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK        ((unsigned int) 0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT      ((unsigned int) 0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION    ((unsigned int) 0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK         ((unsigned int) 0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC         ((unsigned int) 0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC        ((unsigned int) 0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC        ((unsigned int) 0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC        ((unsigned int) 0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI           ((unsigned int) 0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR          ((unsigned int) 0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD          ((unsigned int) 0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS          ((unsigned int) 0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_SSC {

+	AT91_REG	 SSC_CR; 	// Control Register

+	AT91_REG	 SSC_CMR; 	// Clock Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SSC_RCMR; 	// Receive Clock ModeRegister

+	AT91_REG	 SSC_RFMR; 	// Receive Frame Mode Register

+	AT91_REG	 SSC_TCMR; 	// Transmit Clock Mode Register

+	AT91_REG	 SSC_TFMR; 	// Transmit Frame Mode Register

+	AT91_REG	 SSC_RHR; 	// Receive Holding Register

+	AT91_REG	 SSC_THR; 	// Transmit Holding Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 SSC_RSHR; 	// Receive Sync Holding Register

+	AT91_REG	 SSC_TSHR; 	// Transmit Sync Holding Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 SSC_SR; 	// Status Register

+	AT91_REG	 SSC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SSC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SSC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved3[44]; 	// 

+	AT91_REG	 SSC_RPR; 	// Receive Pointer Register

+	AT91_REG	 SSC_RCR; 	// Receive Counter Register

+	AT91_REG	 SSC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SSC_TCR; 	// Transmit Counter Register

+	AT91_REG	 SSC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SSC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SSC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SSC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SSC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SSC_PTSR; 	// PDC Transfer Status Register

+} AT91S_SSC, *AT91PS_SSC;

+

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN        ((unsigned int) 0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS       ((unsigned int) 0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN        ((unsigned int) 0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS       ((unsigned int) 0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST       ((unsigned int) 0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS         ((unsigned int) 0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  ((unsigned int) 0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   ((unsigned int) 0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   ((unsigned int) 0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO         ((unsigned int) 0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 ((unsigned int) 0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            ((unsigned int) 0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              ((unsigned int) 0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI         ((unsigned int) 0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START       ((unsigned int) 0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            ((unsigned int) 0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   ((unsigned int) 0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               ((unsigned int) 0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              ((unsigned int) 0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              ((unsigned int) 0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              ((unsigned int) 0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             ((unsigned int) 0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              ((unsigned int) 0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    ((unsigned int) 0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY      ((unsigned int) 0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD      ((unsigned int) 0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN      ((unsigned int) 0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP        ((unsigned int) 0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF        ((unsigned int) 0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB       ((unsigned int) 0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN       ((unsigned int) 0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS        ((unsigned int) 0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 ((unsigned int) 0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             ((unsigned int) 0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             ((unsigned int) 0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  ((unsigned int) 0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 ((unsigned int) 0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               ((unsigned int) 0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE      ((unsigned int) 0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF      ((unsigned int) 0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN       ((unsigned int) 0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY       ((unsigned int) 0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY     ((unsigned int) 0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX       ((unsigned int) 0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE      ((unsigned int) 0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY       ((unsigned int) 0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN       ((unsigned int) 0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX       ((unsigned int) 0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF      ((unsigned int) 0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN       ((unsigned int) 0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN       ((unsigned int) 0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA       ((unsigned int) 0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA       ((unsigned int) 0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+typedef struct _AT91S_TWI {

+	AT91_REG	 TWI_CR; 	// Control Register

+	AT91_REG	 TWI_MMR; 	// Master Mode Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 TWI_IADR; 	// Internal Address Register

+	AT91_REG	 TWI_CWGR; 	// Clock Waveform Generator Register

+	AT91_REG	 Reserved1[3]; 	// 

+	AT91_REG	 TWI_SR; 	// Status Register

+	AT91_REG	 TWI_IER; 	// Interrupt Enable Register

+	AT91_REG	 TWI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TWI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TWI_RHR; 	// Receive Holding Register

+	AT91_REG	 TWI_THR; 	// Transmit Holding Register

+} AT91S_TWI, *AT91PS_TWI;

+

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START       ((unsigned int) 0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP        ((unsigned int) 0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN        ((unsigned int) 0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS       ((unsigned int) 0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST       ((unsigned int) 0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ      ((unsigned int) 0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   ((unsigned int) 0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               ((unsigned int) 0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               ((unsigned int) 0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               ((unsigned int) 0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD       ((unsigned int) 0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR        ((unsigned int) 0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV       ((unsigned int) 0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV       ((unsigned int) 0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV       ((unsigned int) 0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP      ((unsigned int) 0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY       ((unsigned int) 0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY       ((unsigned int) 0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE        ((unsigned int) 0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE        ((unsigned int) 0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK        ((unsigned int) 0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC_CH {

+	AT91_REG	 PWMC_CMR; 	// Channel Mode Register

+	AT91_REG	 PWMC_CDTYR; 	// Channel Duty Cycle Register

+	AT91_REG	 PWMC_CPRDR; 	// Channel Period Register

+	AT91_REG	 PWMC_CCNTR; 	// Channel Counter Register

+	AT91_REG	 PWMC_CUPDR; 	// Channel Update Register

+	AT91_REG	 PWMC_Reserved[3]; 	// Reserved

+} AT91S_PWMC_CH, *AT91PS_PWMC_CH;

+

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE       ((unsigned int) 0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  ((unsigned int) 0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 ((unsigned int) 0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 ((unsigned int) 0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG       ((unsigned int) 0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL       ((unsigned int) 0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD        ((unsigned int) 0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC {

+	AT91_REG	 PWMC_MR; 	// PWMC Mode Register

+	AT91_REG	 PWMC_ENA; 	// PWMC Enable Register

+	AT91_REG	 PWMC_DIS; 	// PWMC Disable Register

+	AT91_REG	 PWMC_SR; 	// PWMC Status Register

+	AT91_REG	 PWMC_IER; 	// PWMC Interrupt Enable Register

+	AT91_REG	 PWMC_IDR; 	// PWMC Interrupt Disable Register

+	AT91_REG	 PWMC_IMR; 	// PWMC Interrupt Mask Register

+	AT91_REG	 PWMC_ISR; 	// PWMC Interrupt Status Register

+	AT91_REG	 Reserved0[55]; 	// 

+	AT91_REG	 PWMC_VR; 	// PWMC Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_PWMC_CH	 PWMC_CH[4]; 	// PWMC Channel

+} AT91S_PWMC, *AT91PS_PWMC;

+

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA       ((unsigned int) 0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA       ((unsigned int) 0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  ((unsigned int) 0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB       ((unsigned int) 0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB       ((unsigned int) 0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  ((unsigned int) 0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0      ((unsigned int) 0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1      ((unsigned int) 0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2      ((unsigned int) 0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3      ((unsigned int) 0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+typedef struct _AT91S_UDP {

+	AT91_REG	 UDP_NUM; 	// Frame Number Register

+	AT91_REG	 UDP_GLBSTATE; 	// Global State Register

+	AT91_REG	 UDP_FADDR; 	// Function Address Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 UDP_IER; 	// Interrupt Enable Register

+	AT91_REG	 UDP_IDR; 	// Interrupt Disable Register

+	AT91_REG	 UDP_IMR; 	// Interrupt Mask Register

+	AT91_REG	 UDP_ISR; 	// Interrupt Status Register

+	AT91_REG	 UDP_ICR; 	// Interrupt Clear Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 UDP_RSTEP; 	// Reset Endpoint Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 UDP_CSR[6]; 	// Endpoint Control and Status Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 UDP_FDR[6]; 	// Endpoint FIFO Data Register

+	AT91_REG	 Reserved4[3]; 	// 

+	AT91_REG	 UDP_TXVC; 	// Transceiver Control Register

+} AT91S_UDP, *AT91PS_UDP;

+

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM     ((unsigned int) 0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR     ((unsigned int) 0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK      ((unsigned int) 0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN      ((unsigned int) 0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG       ((unsigned int) 0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR         ((unsigned int) 0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR     ((unsigned int) 0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE      ((unsigned int) 0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD        ((unsigned int) 0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN         ((unsigned int) 0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0      ((unsigned int) 0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1      ((unsigned int) 0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2      ((unsigned int) 0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3      ((unsigned int) 0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4      ((unsigned int) 0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5      ((unsigned int) 0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP      ((unsigned int) 0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM       ((unsigned int) 0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM      ((unsigned int) 0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT      ((unsigned int) 0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP      ((unsigned int) 0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES   ((unsigned int) 0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0         ((unsigned int) 0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1         ((unsigned int) 0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2         ((unsigned int) 0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3         ((unsigned int) 0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4         ((unsigned int) 0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5         ((unsigned int) 0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP      ((unsigned int) 0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0 ((unsigned int) 0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP     ((unsigned int) 0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR    ((unsigned int) 0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY    ((unsigned int) 0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL  ((unsigned int) 0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1 ((unsigned int) 0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR         ((unsigned int) 0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE      ((unsigned int) 0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 ((unsigned int) 0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              ((unsigned int) 0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             ((unsigned int) 0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              ((unsigned int) 0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               ((unsigned int) 0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              ((unsigned int) 0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               ((unsigned int) 0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE       ((unsigned int) 0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS       ((unsigned int) 0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT   ((unsigned int) 0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS      ((unsigned int) 0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON        ((unsigned int) 0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_TC {

+	AT91_REG	 TC_CCR; 	// Channel Control Register

+	AT91_REG	 TC_CMR; 	// Channel Mode Register (Capture Mode / Waveform Mode)

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TC_CV; 	// Counter Value

+	AT91_REG	 TC_RA; 	// Register A

+	AT91_REG	 TC_RB; 	// Register B

+	AT91_REG	 TC_RC; 	// Register C

+	AT91_REG	 TC_SR; 	// Status Register

+	AT91_REG	 TC_IER; 	// Interrupt Enable Register

+	AT91_REG	 TC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TC_IMR; 	// Interrupt Mask Register

+} AT91S_TC, *AT91PS_TC;

+

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN        ((unsigned int) 0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS       ((unsigned int) 0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG        ((unsigned int) 0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS         ((unsigned int) 0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     ((unsigned int) 0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     ((unsigned int) 0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     ((unsigned int) 0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     ((unsigned int) 0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     ((unsigned int) 0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  ((unsigned int) 0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  ((unsigned int) 0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  ((unsigned int) 0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI         ((unsigned int) 0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST        ((unsigned int) 0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 ((unsigned int) 0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  ((unsigned int) 0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  ((unsigned int) 0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  ((unsigned int) 0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG      ((unsigned int) 0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG      ((unsigned int) 0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT         ((unsigned int) 0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 ((unsigned int) 0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  ((unsigned int) 0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  ((unsigned int) 0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  ((unsigned int) 0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG       ((unsigned int) 0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG       ((unsigned int) 0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL      ((unsigned int) 0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   ((unsigned int) 0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               ((unsigned int) 0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              ((unsigned int) 0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          ((unsigned int) 0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG       ((unsigned int) 0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE         ((unsigned int) 0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA         ((unsigned int) 0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  ((unsigned int) 0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                ((unsigned int) 0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               ((unsigned int) 0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA         ((unsigned int) 0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               ((unsigned int) 0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              ((unsigned int) 0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 ((unsigned int) 0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC         ((unsigned int) 0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 ((unsigned int) 0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  ((unsigned int) 0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                ((unsigned int) 0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               ((unsigned int) 0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB         ((unsigned int) 0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 ((unsigned int) 0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               ((unsigned int) 0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              ((unsigned int) 0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 ((unsigned int) 0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT        ((unsigned int) 0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 ((unsigned int) 0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  ((unsigned int) 0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                ((unsigned int) 0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               ((unsigned int) 0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG       ((unsigned int) 0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 ((unsigned int) 0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  ((unsigned int) 0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                ((unsigned int) 0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               ((unsigned int) 0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB         ((unsigned int) 0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 ((unsigned int) 0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  ((unsigned int) 0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                ((unsigned int) 0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               ((unsigned int) 0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC         ((unsigned int) 0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 ((unsigned int) 0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  ((unsigned int) 0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                ((unsigned int) 0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               ((unsigned int) 0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT        ((unsigned int) 0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 ((unsigned int) 0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  ((unsigned int) 0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                ((unsigned int) 0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               ((unsigned int) 0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG       ((unsigned int) 0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 ((unsigned int) 0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  ((unsigned int) 0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                ((unsigned int) 0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               ((unsigned int) 0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS        ((unsigned int) 0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS        ((unsigned int) 0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS         ((unsigned int) 0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS         ((unsigned int) 0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS         ((unsigned int) 0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS        ((unsigned int) 0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS        ((unsigned int) 0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS        ((unsigned int) 0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA       ((unsigned int) 0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA        ((unsigned int) 0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB        ((unsigned int) 0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+typedef struct _AT91S_TCB {

+	AT91S_TC	 TCB_TC0; 	// TC Channel 0

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91S_TC	 TCB_TC1; 	// TC Channel 1

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91S_TC	 TCB_TC2; 	// TC Channel 2

+	AT91_REG	 Reserved2[4]; 	// 

+	AT91_REG	 TCB_BCR; 	// TC Block Control Register

+	AT91_REG	 TCB_BMR; 	// TC Block Mode Register

+} AT91S_TCB, *AT91PS_TCB;

+

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC        ((unsigned int) 0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S     ((unsigned int) 0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                ((unsigned int) 0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 ((unsigned int) 0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                ((unsigned int) 0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                ((unsigned int) 0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S     ((unsigned int) 0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                ((unsigned int) 0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 ((unsigned int) 0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                ((unsigned int) 0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                ((unsigned int) 0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S     ((unsigned int) 0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                ((unsigned int) 0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 ((unsigned int) 0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                ((unsigned int) 0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                ((unsigned int) 0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN_MB {

+	AT91_REG	 CAN_MB_MMR; 	// MailBox Mode Register

+	AT91_REG	 CAN_MB_MAM; 	// MailBox Acceptance Mask Register

+	AT91_REG	 CAN_MB_MID; 	// MailBox ID Register

+	AT91_REG	 CAN_MB_MFID; 	// MailBox Family ID Register

+	AT91_REG	 CAN_MB_MSR; 	// MailBox Status Register

+	AT91_REG	 CAN_MB_MDL; 	// MailBox Data Low Register

+	AT91_REG	 CAN_MB_MDH; 	// MailBox Data High Register

+	AT91_REG	 CAN_MB_MCR; 	// MailBox Control Register

+} AT91S_CAN_MB, *AT91PS_CAN_MB;

+

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK   ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR       ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT         ((unsigned int) 0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  ((unsigned int) 0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   ((unsigned int) 0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          ((unsigned int) 0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   ((unsigned int) 0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             ((unsigned int) 0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             ((unsigned int) 0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB       ((unsigned int) 0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA       ((unsigned int) 0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE        ((unsigned int) 0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP  ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC        ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR        ((unsigned int) 0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT        ((unsigned int) 0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI         ((unsigned int) 0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR        ((unsigned int) 0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN {

+	AT91_REG	 CAN_MR; 	// Mode Register

+	AT91_REG	 CAN_IER; 	// Interrupt Enable Register

+	AT91_REG	 CAN_IDR; 	// Interrupt Disable Register

+	AT91_REG	 CAN_IMR; 	// Interrupt Mask Register

+	AT91_REG	 CAN_SR; 	// Status Register

+	AT91_REG	 CAN_BR; 	// Baudrate Register

+	AT91_REG	 CAN_TIM; 	// Timer Register

+	AT91_REG	 CAN_TIMESTP; 	// Time Stamp Register

+	AT91_REG	 CAN_ECR; 	// Error Counter Register

+	AT91_REG	 CAN_TCR; 	// Transfer Command Register

+	AT91_REG	 CAN_ACR; 	// Abort Command Register

+	AT91_REG	 Reserved0[52]; 	// 

+	AT91_REG	 CAN_VR; 	// Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_CAN_MB	 CAN_MB0; 	// CAN Mailbox 0

+	AT91S_CAN_MB	 CAN_MB1; 	// CAN Mailbox 1

+	AT91S_CAN_MB	 CAN_MB2; 	// CAN Mailbox 2

+	AT91S_CAN_MB	 CAN_MB3; 	// CAN Mailbox 3

+	AT91S_CAN_MB	 CAN_MB4; 	// CAN Mailbox 4

+	AT91S_CAN_MB	 CAN_MB5; 	// CAN Mailbox 5

+	AT91S_CAN_MB	 CAN_MB6; 	// CAN Mailbox 6

+	AT91S_CAN_MB	 CAN_MB7; 	// CAN Mailbox 7

+	AT91S_CAN_MB	 CAN_MB8; 	// CAN Mailbox 8

+	AT91S_CAN_MB	 CAN_MB9; 	// CAN Mailbox 9

+	AT91S_CAN_MB	 CAN_MB10; 	// CAN Mailbox 10

+	AT91S_CAN_MB	 CAN_MB11; 	// CAN Mailbox 11

+	AT91S_CAN_MB	 CAN_MB12; 	// CAN Mailbox 12

+	AT91S_CAN_MB	 CAN_MB13; 	// CAN Mailbox 13

+	AT91S_CAN_MB	 CAN_MB14; 	// CAN Mailbox 14

+	AT91S_CAN_MB	 CAN_MB15; 	// CAN Mailbox 15

+} AT91S_CAN, *AT91PS_CAN;

+

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN       ((unsigned int) 0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM         ((unsigned int) 0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM         ((unsigned int) 0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL         ((unsigned int) 0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF        ((unsigned int) 0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM         ((unsigned int) 0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ      ((unsigned int) 0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT        ((unsigned int) 0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0         ((unsigned int) 0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1         ((unsigned int) 0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2         ((unsigned int) 0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3         ((unsigned int) 0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4         ((unsigned int) 0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5         ((unsigned int) 0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6         ((unsigned int) 0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7         ((unsigned int) 0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8         ((unsigned int) 0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9         ((unsigned int) 0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10        ((unsigned int) 0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11        ((unsigned int) 0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12        ((unsigned int) 0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13        ((unsigned int) 0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14        ((unsigned int) 0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15        ((unsigned int) 0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA        ((unsigned int) 0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN        ((unsigned int) 0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP        ((unsigned int) 0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF        ((unsigned int) 0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP       ((unsigned int) 0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP      ((unsigned int) 0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF        ((unsigned int) 0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP        ((unsigned int) 0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR        ((unsigned int) 0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR        ((unsigned int) 0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR        ((unsigned int) 0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR        ((unsigned int) 0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR        ((unsigned int) 0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY        ((unsigned int) 0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY        ((unsigned int) 0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY        ((unsigned int) 0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2      ((unsigned int) 0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1      ((unsigned int) 0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG      ((unsigned int) 0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC        ((unsigned int) 0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP         ((unsigned int) 0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP         ((unsigned int) 0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER       ((unsigned int) 0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC         ((unsigned int) 0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC         ((unsigned int) 0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST      ((unsigned int) 0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+typedef struct _AT91S_EMAC {

+	AT91_REG	 EMAC_NCR; 	// Network Control Register

+	AT91_REG	 EMAC_NCFGR; 	// Network Configuration Register

+	AT91_REG	 EMAC_NSR; 	// Network Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 EMAC_TSR; 	// Transmit Status Register

+	AT91_REG	 EMAC_RBQP; 	// Receive Buffer Queue Pointer

+	AT91_REG	 EMAC_TBQP; 	// Transmit Buffer Queue Pointer

+	AT91_REG	 EMAC_RSR; 	// Receive Status Register

+	AT91_REG	 EMAC_ISR; 	// Interrupt Status Register

+	AT91_REG	 EMAC_IER; 	// Interrupt Enable Register

+	AT91_REG	 EMAC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 EMAC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 EMAC_MAN; 	// PHY Maintenance Register

+	AT91_REG	 EMAC_PTR; 	// Pause Time Register

+	AT91_REG	 EMAC_PFR; 	// Pause Frames received Register

+	AT91_REG	 EMAC_FTO; 	// Frames Transmitted OK Register

+	AT91_REG	 EMAC_SCF; 	// Single Collision Frame Register

+	AT91_REG	 EMAC_MCF; 	// Multiple Collision Frame Register

+	AT91_REG	 EMAC_FRO; 	// Frames Received OK Register

+	AT91_REG	 EMAC_FCSE; 	// Frame Check Sequence Error Register

+	AT91_REG	 EMAC_ALE; 	// Alignment Error Register

+	AT91_REG	 EMAC_DTF; 	// Deferred Transmission Frame Register

+	AT91_REG	 EMAC_LCOL; 	// Late Collision Register

+	AT91_REG	 EMAC_ECOL; 	// Excessive Collision Register

+	AT91_REG	 EMAC_TUND; 	// Transmit Underrun Error Register

+	AT91_REG	 EMAC_CSE; 	// Carrier Sense Error Register

+	AT91_REG	 EMAC_RRE; 	// Receive Ressource Error Register

+	AT91_REG	 EMAC_ROV; 	// Receive Overrun Errors Register

+	AT91_REG	 EMAC_RSE; 	// Receive Symbol Errors Register

+	AT91_REG	 EMAC_ELE; 	// Excessive Length Errors Register

+	AT91_REG	 EMAC_RJA; 	// Receive Jabbers Register

+	AT91_REG	 EMAC_USF; 	// Undersize Frames Register

+	AT91_REG	 EMAC_STE; 	// SQE Test Error Register

+	AT91_REG	 EMAC_RLE; 	// Receive Length Field Mismatch Register

+	AT91_REG	 EMAC_TPF; 	// Transmitted Pause Frames Register

+	AT91_REG	 EMAC_HRB; 	// Hash Address Bottom[31:0]

+	AT91_REG	 EMAC_HRT; 	// Hash Address Top[63:32]

+	AT91_REG	 EMAC_SA1L; 	// Specific Address 1 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA1H; 	// Specific Address 1 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA2L; 	// Specific Address 2 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA2H; 	// Specific Address 2 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA3L; 	// Specific Address 3 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA3H; 	// Specific Address 3 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA4L; 	// Specific Address 4 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA4H; 	// Specific Address 4 Top, Last 2 bytes

+	AT91_REG	 EMAC_TID; 	// Type ID Checking Register

+	AT91_REG	 EMAC_TPQ; 	// Transmit Pause Quantum Register

+	AT91_REG	 EMAC_USRIO; 	// USER Input/Output Register

+	AT91_REG	 EMAC_WOL; 	// Wake On LAN Register

+	AT91_REG	 Reserved1[13]; 	// 

+	AT91_REG	 EMAC_REV; 	// Revision Register

+} AT91S_EMAC, *AT91PS_EMAC;

+

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB         ((unsigned int) 0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB        ((unsigned int) 0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE         ((unsigned int) 0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE         ((unsigned int) 0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE        ((unsigned int) 0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT    ((unsigned int) 0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT    ((unsigned int) 0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT     ((unsigned int) 0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP         ((unsigned int) 0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART     ((unsigned int) 0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT      ((unsigned int) 0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR       ((unsigned int) 0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ        ((unsigned int) 0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD        ((unsigned int) 0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD         ((unsigned int) 0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME     ((unsigned int) 0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF        ((unsigned int) 0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC        ((unsigned int) 0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI        ((unsigned int) 0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI        ((unsigned int) 0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG        ((unsigned int) 0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE        ((unsigned int) 0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK        ((unsigned int) 0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               ((unsigned int) 0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              ((unsigned int) 0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              ((unsigned int) 0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              ((unsigned int) 0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY        ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE        ((unsigned int) 0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF       ((unsigned int) 0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             ((unsigned int) 0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             ((unsigned int) 0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             ((unsigned int) 0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             ((unsigned int) 0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE       ((unsigned int) 0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS      ((unsigned int) 0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD      ((unsigned int) 0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS     ((unsigned int) 0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR      ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO       ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE       ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES       ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO        ((unsigned int) 0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX        ((unsigned int) 0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND        ((unsigned int) 0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR        ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP      ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR      ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR      ((unsigned int) 0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR      ((unsigned int) 0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR      ((unsigned int) 0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP      ((unsigned int) 0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK       ((unsigned int) 0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR       ((unsigned int) 0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP      ((unsigned int) 0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE       ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ        ((unsigned int) 0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA       ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE       ((unsigned int) 0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA       ((unsigned int) 0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA       ((unsigned int) 0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW         ((unsigned int) 0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF        ((unsigned int) 0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII       ((unsigned int) 0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP         ((unsigned int) 0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG        ((unsigned int) 0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP        ((unsigned int) 0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1        ((unsigned int) 0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF     ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF    ((unsigned int) 0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+typedef struct _AT91S_ADC {

+	AT91_REG	 ADC_CR; 	// ADC Control Register

+	AT91_REG	 ADC_MR; 	// ADC Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 ADC_CHER; 	// ADC Channel Enable Register

+	AT91_REG	 ADC_CHDR; 	// ADC Channel Disable Register

+	AT91_REG	 ADC_CHSR; 	// ADC Channel Status Register

+	AT91_REG	 ADC_SR; 	// ADC Status Register

+	AT91_REG	 ADC_LCDR; 	// ADC Last Converted Data Register

+	AT91_REG	 ADC_IER; 	// ADC Interrupt Enable Register

+	AT91_REG	 ADC_IDR; 	// ADC Interrupt Disable Register

+	AT91_REG	 ADC_IMR; 	// ADC Interrupt Mask Register

+	AT91_REG	 ADC_CDR0; 	// ADC Channel Data Register 0

+	AT91_REG	 ADC_CDR1; 	// ADC Channel Data Register 1

+	AT91_REG	 ADC_CDR2; 	// ADC Channel Data Register 2

+	AT91_REG	 ADC_CDR3; 	// ADC Channel Data Register 3

+	AT91_REG	 ADC_CDR4; 	// ADC Channel Data Register 4

+	AT91_REG	 ADC_CDR5; 	// ADC Channel Data Register 5

+	AT91_REG	 ADC_CDR6; 	// ADC Channel Data Register 6

+	AT91_REG	 ADC_CDR7; 	// ADC Channel Data Register 7

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 ADC_RPR; 	// Receive Pointer Register

+	AT91_REG	 ADC_RCR; 	// Receive Counter Register

+	AT91_REG	 ADC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 ADC_TCR; 	// Transmit Counter Register

+	AT91_REG	 ADC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 ADC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 ADC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 ADC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 ADC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 ADC_PTSR; 	// PDC Transfer Status Register

+} AT91S_ADC, *AT91PS_ADC;

+

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST       ((unsigned int) 0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START       ((unsigned int) 0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN       ((unsigned int) 0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  ((unsigned int) 0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   ((unsigned int) 0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL      ((unsigned int) 0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                ((unsigned int) 0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                ((unsigned int) 0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                ((unsigned int) 0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                ((unsigned int) 0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                ((unsigned int) 0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                ((unsigned int) 0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  ((unsigned int) 0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES      ((unsigned int) 0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               ((unsigned int) 0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                ((unsigned int) 0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP       ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          ((unsigned int) 0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL     ((unsigned int) 0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP     ((unsigned int) 0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM       ((unsigned int) 0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0         ((unsigned int) 0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1         ((unsigned int) 0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2         ((unsigned int) 0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3         ((unsigned int) 0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4         ((unsigned int) 0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5         ((unsigned int) 0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6         ((unsigned int) 0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7         ((unsigned int) 0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0        ((unsigned int) 0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1        ((unsigned int) 0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2        ((unsigned int) 0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3        ((unsigned int) 0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4        ((unsigned int) 0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5        ((unsigned int) 0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6        ((unsigned int) 0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7        ((unsigned int) 0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0       ((unsigned int) 0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1       ((unsigned int) 0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2       ((unsigned int) 0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3       ((unsigned int) 0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4       ((unsigned int) 0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5       ((unsigned int) 0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6       ((unsigned int) 0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7       ((unsigned int) 0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY        ((unsigned int) 0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE       ((unsigned int) 0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX       ((unsigned int) 0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF      ((unsigned int) 0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA       ((unsigned int) 0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA        ((unsigned int) 0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_AES {

+	AT91_REG	 AES_CR; 	// Control Register

+	AT91_REG	 AES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AES_IER; 	// Interrupt Enable Register

+	AT91_REG	 AES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 AES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AES_ISR; 	// Interrupt Status Register

+	AT91_REG	 AES_KEYWxR[4]; 	// Key Word x Register

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91_REG	 AES_IDATAxR[4]; 	// Input Data x Register

+	AT91_REG	 AES_ODATAxR[4]; 	// Output Data x Register

+	AT91_REG	 AES_IVxR[4]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved2[35]; 	// 

+	AT91_REG	 AES_VR; 	// AES Version Register

+	AT91_REG	 AES_RPR; 	// Receive Pointer Register

+	AT91_REG	 AES_RCR; 	// Receive Counter Register

+	AT91_REG	 AES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 AES_TCR; 	// Transmit Counter Register

+	AT91_REG	 AES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 AES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 AES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 AES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 AES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 AES_PTSR; 	// PDC Transfer Status Register

+} AT91S_AES, *AT91PS_AES;

+

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START       ((unsigned int) 0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST       ((unsigned int) 0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED    ((unsigned int) 0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER      ((unsigned int) 0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY     ((unsigned int) 0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD        ((unsigned int) 0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD       ((unsigned int) 0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  ((unsigned int) 0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD         ((unsigned int) 0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS        ((unsigned int) 0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              ((unsigned int) 0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               ((unsigned int) 0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               ((unsigned int) 0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               ((unsigned int) 0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                ((unsigned int) 0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY        ((unsigned int) 0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE       ((unsigned int) 0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             ((unsigned int) 0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             ((unsigned int) 0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             ((unsigned int) 0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             ((unsigned int) 0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             ((unsigned int) 0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY      ((unsigned int) 0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX       ((unsigned int) 0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX       ((unsigned int) 0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF      ((unsigned int) 0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE      ((unsigned int) 0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD        ((unsigned int) 0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT        ((unsigned int) 0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  ((unsigned int) 0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY ((unsigned int) 0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          ((unsigned int) 0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_TDES {

+	AT91_REG	 TDES_CR; 	// Control Register

+	AT91_REG	 TDES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TDES_IER; 	// Interrupt Enable Register

+	AT91_REG	 TDES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TDES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TDES_ISR; 	// Interrupt Status Register

+	AT91_REG	 TDES_KEY1WxR[2]; 	// Key 1 Word x Register

+	AT91_REG	 TDES_KEY2WxR[2]; 	// Key 2 Word x Register

+	AT91_REG	 TDES_KEY3WxR[2]; 	// Key 3 Word x Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 TDES_IDATAxR[2]; 	// Input Data x Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 TDES_ODATAxR[2]; 	// Output Data x Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 TDES_IVxR[2]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved4[37]; 	// 

+	AT91_REG	 TDES_VR; 	// TDES Version Register

+	AT91_REG	 TDES_RPR; 	// Receive Pointer Register

+	AT91_REG	 TDES_RCR; 	// Receive Counter Register

+	AT91_REG	 TDES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 TDES_TCR; 	// Transmit Counter Register

+	AT91_REG	 TDES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 TDES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 TDES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 TDES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 TDES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 TDES_PTSR; 	// PDC Transfer Status Register

+} AT91S_TDES, *AT91PS_TDES;

+

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START      ((unsigned int) 0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST      ((unsigned int) 0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER     ((unsigned int) 0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD    ((unsigned int) 0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD     ((unsigned int) 0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD       ((unsigned int) 0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD      ((unsigned int) 0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD        ((unsigned int) 0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS       ((unsigned int) 0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               ((unsigned int) 0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               ((unsigned int) 0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               ((unsigned int) 0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                ((unsigned int) 0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY     ((unsigned int) 0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX      ((unsigned int) 0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX      ((unsigned int) 0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF     ((unsigned int) 0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE     ((unsigned int) 0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD       ((unsigned int) 0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT       ((unsigned int) 0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          ((unsigned int) 0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X128

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR   ((AT91_REG *) 	0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR   ((AT91_REG *) 	0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR   ((AT91_REG *) 	0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR   ((AT91_REG *) 	0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR ((AT91_REG *) 	0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR   ((AT91_REG *) 	0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR  ((AT91_REG *) 	0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR  ((AT91_REG *) 	0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR   ((AT91_REG *) 	0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR   ((AT91_REG *) 	0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR   ((AT91_REG *) 	0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER  ((AT91_REG *) 	0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR  ((AT91_REG *) 	0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR  ((AT91_REG *) 	0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR  ((AT91_REG *) 	0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR  ((AT91_REG *) 	0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR  ((AT91_REG *) 	0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU   ((AT91_REG *) 	0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR  ((AT91_REG *) 	0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR ((AT91_REG *) 	0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR ((AT91_REG *) 	0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR  ((AT91_REG *) 	0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR  ((AT91_REG *) 	0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR  ((AT91_REG *) 	0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR ((AT91_REG *) 	0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR ((AT91_REG *) 	0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR ((AT91_REG *) 	0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR ((AT91_REG *) 	0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID ((AT91_REG *) 	0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR ((AT91_REG *) 	0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR  ((AT91_REG *) 	0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR  ((AT91_REG *) 	0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR ((AT91_REG *) 	0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR   ((AT91_REG *) 	0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR  ((AT91_REG *) 	0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR   ((AT91_REG *) 	0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR ((AT91_REG *) 	0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR  ((AT91_REG *) 	0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR  ((AT91_REG *) 	0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER  ((AT91_REG *) 	0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR  ((AT91_REG *) 	0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR ((AT91_REG *) 	0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR  ((AT91_REG *) 	0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR ((AT91_REG *) 	0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER  ((AT91_REG *) 	0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR ((AT91_REG *) 	0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR  ((AT91_REG *) 	0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER  ((AT91_REG *) 	0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR ((AT91_REG *) 	0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR ((AT91_REG *) 	0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR ((AT91_REG *) 	0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR  ((AT91_REG *) 	0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR ((AT91_REG *) 	0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR ((AT91_REG *) 	0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR ((AT91_REG *) 	0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR  ((AT91_REG *) 	0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER ((AT91_REG *) 	0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER ((AT91_REG *) 	0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR ((AT91_REG *) 	0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER ((AT91_REG *) 	0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR  ((AT91_REG *) 	0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR  ((AT91_REG *) 	0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR ((AT91_REG *) 	0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR ((AT91_REG *) 	0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER ((AT91_REG *) 	0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR  ((AT91_REG *) 	0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR ((AT91_REG *) 	0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER  ((AT91_REG *) 	0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR  ((AT91_REG *) 	0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR ((AT91_REG *) 	0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER ((AT91_REG *) 	0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR ((AT91_REG *) 	0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR  ((AT91_REG *) 	0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR  ((AT91_REG *) 	0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR ((AT91_REG *) 	0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR  ((AT91_REG *) 	0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER  ((AT91_REG *) 	0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR ((AT91_REG *) 	0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER ((AT91_REG *) 	0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR ((AT91_REG *) 	0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR ((AT91_REG *) 	0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR ((AT91_REG *) 	0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR  ((AT91_REG *) 	0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR ((AT91_REG *) 	0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR  ((AT91_REG *) 	0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR  ((AT91_REG *) 	0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR ((AT91_REG *) 	0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER ((AT91_REG *) 	0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR ((AT91_REG *) 	0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR  ((AT91_REG *) 	0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR ((AT91_REG *) 	0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR  ((AT91_REG *) 	0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR ((AT91_REG *) 	0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER ((AT91_REG *) 	0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR  ((AT91_REG *) 	0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR ((AT91_REG *) 	0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER  ((AT91_REG *) 	0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER  ((AT91_REG *) 	0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR  ((AT91_REG *) 	0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR ((AT91_REG *) 	0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR ((AT91_REG *) 	0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR   ((AT91_REG *) 	0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR   ((AT91_REG *) 	0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR  ((AT91_REG *) 	0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER  ((AT91_REG *) 	0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR  ((AT91_REG *) 	0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR  ((AT91_REG *) 	0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR  ((AT91_REG *) 	0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR  ((AT91_REG *) 	0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR  ((AT91_REG *) 	0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR  ((AT91_REG *) 	0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR  ((AT91_REG *) 	0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER  ((AT91_REG *) 	0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR   ((AT91_REG *) 	0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER   ((AT91_REG *) 	0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR    ((AT91_REG *) 	0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR  ((AT91_REG *) 	0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR  ((AT91_REG *) 	0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR  ((AT91_REG *) 	0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR ((AT91_REG *) 	0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR ((AT91_REG *) 	0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR ((AT91_REG *) 	0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR ((AT91_REG *) 	0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR ((AT91_REG *) 	0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR ((AT91_REG *) 	0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR ((AT91_REG *) 	0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR ((AT91_REG *) 	0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR ((AT91_REG *) 	0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR ((AT91_REG *) 	0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR ((AT91_REG *) 	0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR   ((AT91_REG *) 	0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR    ((AT91_REG *) 	0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR    ((AT91_REG *) 	0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR    ((AT91_REG *) 	0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR   ((AT91_REG *) 	0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR    ((AT91_REG *) 	0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR    ((AT91_REG *) 	0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR ((AT91_REG *) 	0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR  ((AT91_REG *) 	0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR ((AT91_REG *) 	0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR  ((AT91_REG *) 	0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR ((AT91_REG *) 	0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR  ((AT91_REG *) 	0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR  ((AT91_REG *) 	0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR ((AT91_REG *) 	0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR ((AT91_REG *) 	0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR ((AT91_REG *) 	0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR  ((AT91_REG *) 	0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER  ((AT91_REG *) 	0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR   ((AT91_REG *) 	0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR  ((AT91_REG *) 	0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR  ((AT91_REG *) 	0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR   ((AT91_REG *) 	0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR  ((AT91_REG *) 	0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR   ((AT91_REG *) 	0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR  ((AT91_REG *) 	0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR ((AT91_REG *) 	0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR  ((AT91_REG *) 	0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR  ((AT91_REG *) 	0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR  ((AT91_REG *) 	0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR ((AT91_REG *) 	0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR ((AT91_REG *) 	0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR  ((AT91_REG *) 	0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR ((AT91_REG *) 	0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR ((AT91_REG *) 	0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR ((AT91_REG *) 	0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER  ((AT91_REG *) 	0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR   ((AT91_REG *) 	0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR  ((AT91_REG *) 	0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR   ((AT91_REG *) 	0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR   ((AT91_REG *) 	0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR  ((AT91_REG *) 	0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR  ((AT91_REG *) 	0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR  ((AT91_REG *) 	0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR  ((AT91_REG *) 	0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR  ((AT91_REG *) 	0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR  ((AT91_REG *) 	0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR   ((AT91_REG *) 	0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR  ((AT91_REG *) 	0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR  ((AT91_REG *) 	0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR   ((AT91_REG *) 	0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR  ((AT91_REG *) 	0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR   ((AT91_REG *) 	0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR  ((AT91_REG *) 	0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR   ((AT91_REG *) 	0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF    ((AT91_REG *) 	0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER   ((AT91_REG *) 	0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR  ((AT91_REG *) 	0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR   ((AT91_REG *) 	0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR   ((AT91_REG *) 	0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER   ((AT91_REG *) 	0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR   ((AT91_REG *) 	0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR  ((AT91_REG *) 	0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR   ((AT91_REG *) 	0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR  ((AT91_REG *) 	0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR   ((AT91_REG *) 	0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI  ((AT91_REG *) 	0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR    ((AT91_REG *) 	0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR    ((AT91_REG *) 	0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR  ((AT91_REG *) 	0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR  ((AT91_REG *) 	0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR   ((AT91_REG *) 	0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR  ((AT91_REG *) 	0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR  ((AT91_REG *) 	0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR  ((AT91_REG *) 	0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR   ((AT91_REG *) 	0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR   ((AT91_REG *) 	0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR   ((AT91_REG *) 	0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR  ((AT91_REG *) 	0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR  ((AT91_REG *) 	0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER   ((AT91_REG *) 	0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR    ((AT91_REG *) 	0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR   ((AT91_REG *) 	0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI  ((AT91_REG *) 	0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR  ((AT91_REG *) 	0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR    ((AT91_REG *) 	0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR  ((AT91_REG *) 	0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR   ((AT91_REG *) 	0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR   ((AT91_REG *) 	0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR   ((AT91_REG *) 	0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR   ((AT91_REG *) 	0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF    ((AT91_REG *) 	0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER   ((AT91_REG *) 	0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR  ((AT91_REG *) 	0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR   ((AT91_REG *) 	0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR  ((AT91_REG *) 	0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR   ((AT91_REG *) 	0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR  ((AT91_REG *) 	0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR   ((AT91_REG *) 	0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR   ((AT91_REG *) 	0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR  ((AT91_REG *) 	0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR  ((AT91_REG *) 	0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR  ((AT91_REG *) 	0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR   ((AT91_REG *) 	0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR  ((AT91_REG *) 	0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR  ((AT91_REG *) 	0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR   ((AT91_REG *) 	0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR   ((AT91_REG *) 	0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR  ((AT91_REG *) 	0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER   ((AT91_REG *) 	0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR  ((AT91_REG *) 	0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR    ((AT91_REG *) 	0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR   ((AT91_REG *) 	0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR  ((AT91_REG *) 	0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR    ((AT91_REG *) 	0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR   ((AT91_REG *) 	0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR  ((AT91_REG *) 	0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER   ((AT91_REG *) 	0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR    ((AT91_REG *) 	0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR    ((AT91_REG *) 	0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR   ((AT91_REG *) 	0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR   ((AT91_REG *) 	0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR   ((AT91_REG *) 	0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR  ((AT91_REG *) 	0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR   ((AT91_REG *) 	0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR  ((AT91_REG *) 	0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR   ((AT91_REG *) 	0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR ((AT91_REG *) 	0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved ((AT91_REG *) 	0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR ((AT91_REG *) 	0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR ((AT91_REG *) 	0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR ((AT91_REG *) 	0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR ((AT91_REG *) 	0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved ((AT91_REG *) 	0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR ((AT91_REG *) 	0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR ((AT91_REG *) 	0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR ((AT91_REG *) 	0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR ((AT91_REG *) 	0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR ((AT91_REG *) 	0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved ((AT91_REG *) 	0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR ((AT91_REG *) 	0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR ((AT91_REG *) 	0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR ((AT91_REG *) 	0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR ((AT91_REG *) 	0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR ((AT91_REG *) 	0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved ((AT91_REG *) 	0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR ((AT91_REG *) 	0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR ((AT91_REG *) 	0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR ((AT91_REG *) 	0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR ((AT91_REG *) 	0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR ((AT91_REG *) 	0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR  ((AT91_REG *) 	0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS  ((AT91_REG *) 	0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER  ((AT91_REG *) 	0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR   ((AT91_REG *) 	0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR  ((AT91_REG *) 	0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR   ((AT91_REG *) 	0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR  ((AT91_REG *) 	0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR   ((AT91_REG *) 	0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA  ((AT91_REG *) 	0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR   ((AT91_REG *) 	0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR ((AT91_REG *) 	0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM   ((AT91_REG *) 	0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR   ((AT91_REG *) 	0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR   ((AT91_REG *) 	0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR   ((AT91_REG *) 	0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR   ((AT91_REG *) 	0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR   ((AT91_REG *) 	0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP ((AT91_REG *) 	0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC  ((AT91_REG *) 	0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE ((AT91_REG *) 	0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER   ((AT91_REG *) 	0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR    ((AT91_REG *) 	0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC    ((AT91_REG *) 	0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB    ((AT91_REG *) 	0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR   ((AT91_REG *) 	0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR   ((AT91_REG *) 	0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER   ((AT91_REG *) 	0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA    ((AT91_REG *) 	0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR   ((AT91_REG *) 	0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV    ((AT91_REG *) 	0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR   ((AT91_REG *) 	0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB    ((AT91_REG *) 	0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR   ((AT91_REG *) 	0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER   ((AT91_REG *) 	0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR   ((AT91_REG *) 	0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR    ((AT91_REG *) 	0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR   ((AT91_REG *) 	0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA    ((AT91_REG *) 	0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC    ((AT91_REG *) 	0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR   ((AT91_REG *) 	0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV    ((AT91_REG *) 	0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR   ((AT91_REG *) 	0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR   ((AT91_REG *) 	0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV    ((AT91_REG *) 	0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA    ((AT91_REG *) 	0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB    ((AT91_REG *) 	0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR   ((AT91_REG *) 	0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR   ((AT91_REG *) 	0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC    ((AT91_REG *) 	0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER   ((AT91_REG *) 	0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR    ((AT91_REG *) 	0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR   ((AT91_REG *) 	0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR   ((AT91_REG *) 	0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL ((AT91_REG *) 	0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM ((AT91_REG *) 	0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR ((AT91_REG *) 	0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID ((AT91_REG *) 	0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR ((AT91_REG *) 	0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID ((AT91_REG *) 	0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH ((AT91_REG *) 	0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR ((AT91_REG *) 	0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL ((AT91_REG *) 	0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID ((AT91_REG *) 	0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR ((AT91_REG *) 	0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR ((AT91_REG *) 	0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM ((AT91_REG *) 	0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH ((AT91_REG *) 	0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR ((AT91_REG *) 	0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID ((AT91_REG *) 	0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR ((AT91_REG *) 	0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH ((AT91_REG *) 	0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID ((AT91_REG *) 	0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL ((AT91_REG *) 	0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR ((AT91_REG *) 	0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM ((AT91_REG *) 	0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID ((AT91_REG *) 	0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR ((AT91_REG *) 	0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID ((AT91_REG *) 	0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM ((AT91_REG *) 	0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID ((AT91_REG *) 	0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR ((AT91_REG *) 	0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR ((AT91_REG *) 	0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR ((AT91_REG *) 	0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL ((AT91_REG *) 	0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH ((AT91_REG *) 	0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID ((AT91_REG *) 	0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR ((AT91_REG *) 	0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH ((AT91_REG *) 	0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID ((AT91_REG *) 	0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR ((AT91_REG *) 	0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR ((AT91_REG *) 	0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL ((AT91_REG *) 	0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM ((AT91_REG *) 	0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR ((AT91_REG *) 	0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR ((AT91_REG *) 	0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID ((AT91_REG *) 	0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH ((AT91_REG *) 	0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID ((AT91_REG *) 	0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR ((AT91_REG *) 	0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL ((AT91_REG *) 	0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM ((AT91_REG *) 	0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID ((AT91_REG *) 	0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID ((AT91_REG *) 	0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM ((AT91_REG *) 	0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR ((AT91_REG *) 	0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL ((AT91_REG *) 	0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR ((AT91_REG *) 	0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH ((AT91_REG *) 	0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR ((AT91_REG *) 	0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR ((AT91_REG *) 	0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH ((AT91_REG *) 	0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID ((AT91_REG *) 	0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL ((AT91_REG *) 	0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID ((AT91_REG *) 	0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR ((AT91_REG *) 	0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM ((AT91_REG *) 	0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR ((AT91_REG *) 	0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR   ((AT91_REG *) 	0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR   ((AT91_REG *) 	0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER   ((AT91_REG *) 	0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR   ((AT91_REG *) 	0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP ((AT91_REG *) 	0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR    ((AT91_REG *) 	0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR   ((AT91_REG *) 	0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR   ((AT91_REG *) 	0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM   ((AT91_REG *) 	0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR    ((AT91_REG *) 	0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR    ((AT91_REG *) 	0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR    ((AT91_REG *) 	0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR  ((AT91_REG *) 	0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H ((AT91_REG *) 	0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L ((AT91_REG *) 	0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE  ((AT91_REG *) 	0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL ((AT91_REG *) 	0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE  ((AT91_REG *) 	0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL  ((AT91_REG *) 	0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF  ((AT91_REG *) 	0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND ((AT91_REG *) 	0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR  ((AT91_REG *) 	0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L ((AT91_REG *) 	0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR  ((AT91_REG *) 	0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L ((AT91_REG *) 	0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR  ((AT91_REG *) 	0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR  ((AT91_REG *) 	0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE  ((AT91_REG *) 	0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL ((AT91_REG *) 	0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID  ((AT91_REG *) 	0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB  ((AT91_REG *) 	0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP ((AT91_REG *) 	0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO ((AT91_REG *) 	0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR  ((AT91_REG *) 	0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H ((AT91_REG *) 	0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV  ((AT91_REG *) 	0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE  ((AT91_REG *) 	0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA  ((AT91_REG *) 	0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP ((AT91_REG *) 	0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF  ((AT91_REG *) 	0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR ((AT91_REG *) 	0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT  ((AT91_REG *) 	0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF  ((AT91_REG *) 	0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE ((AT91_REG *) 	0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ  ((AT91_REG *) 	0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN  ((AT91_REG *) 	0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO  ((AT91_REG *) 	0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV  ((AT91_REG *) 	0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR  ((AT91_REG *) 	0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF  ((AT91_REG *) 	0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR  ((AT91_REG *) 	0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF  ((AT91_REG *) 	0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR  ((AT91_REG *) 	0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L ((AT91_REG *) 	0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO  ((AT91_REG *) 	0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER  ((AT91_REG *) 	0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H ((AT91_REG *) 	0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE  ((AT91_REG *) 	0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H ((AT91_REG *) 	0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE  ((AT91_REG *) 	0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE  ((AT91_REG *) 	0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR  ((AT91_REG *) 	0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR  ((AT91_REG *) 	0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR  ((AT91_REG *) 	0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR  ((AT91_REG *) 	0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR  ((AT91_REG *) 	0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR  ((AT91_REG *) 	0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR   ((AT91_REG *) 	0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR   ((AT91_REG *) 	0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR   ((AT91_REG *) 	0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR   ((AT91_REG *) 	0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2  ((AT91_REG *) 	0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3  ((AT91_REG *) 	0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0  ((AT91_REG *) 	0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5  ((AT91_REG *) 	0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR  ((AT91_REG *) 	0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR    ((AT91_REG *) 	0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4  ((AT91_REG *) 	0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1  ((AT91_REG *) 	0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR  ((AT91_REG *) 	0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR   ((AT91_REG *) 	0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR    ((AT91_REG *) 	0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7  ((AT91_REG *) 	0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6  ((AT91_REG *) 	0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER   ((AT91_REG *) 	0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER  ((AT91_REG *) 	0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR  ((AT91_REG *) 	0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR    ((AT91_REG *) 	0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR   ((AT91_REG *) 	0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR   ((AT91_REG *) 	0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR  ((AT91_REG *) 	0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR  ((AT91_REG *) 	0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR  ((AT91_REG *) 	0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR   ((AT91_REG *) 	0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR   ((AT91_REG *) 	0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR  ((AT91_REG *) 	0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR  ((AT91_REG *) 	0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR   ((AT91_REG *) 	0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR  ((AT91_REG *) 	0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR  ((AT91_REG *) 	0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR    ((AT91_REG *) 	0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR    ((AT91_REG *) 	0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR ((AT91_REG *) 	0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR ((AT91_REG *) 	0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR    ((AT91_REG *) 	0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR   ((AT91_REG *) 	0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR   ((AT91_REG *) 	0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER   ((AT91_REG *) 	0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR ((AT91_REG *) 	0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR   ((AT91_REG *) 	0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR ((AT91_REG *) 	0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR  ((AT91_REG *) 	0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR  ((AT91_REG *) 	0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR ((AT91_REG *) 	0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR ((AT91_REG *) 	0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR  ((AT91_REG *) 	0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR ((AT91_REG *) 	0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR  ((AT91_REG *) 	0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR ((AT91_REG *) 	0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR ((AT91_REG *) 	0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR ((AT91_REG *) 	0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR ((AT91_REG *) 	0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR  ((AT91_REG *) 	0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR   ((AT91_REG *) 	0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR ((AT91_REG *) 	0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR ((AT91_REG *) 	0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR  ((AT91_REG *) 	0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR   ((AT91_REG *) 	0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR   ((AT91_REG *) 	0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER  ((AT91_REG *) 	0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR  ((AT91_REG *) 	0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR ((AT91_REG *) 	0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR ((AT91_REG *) 	0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_PIO_PA0        ((unsigned int) 1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0     ((unsigned int) AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1        ((unsigned int) 1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0     ((unsigned int) AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10       ((unsigned int) 1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD      ((unsigned int) AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11       ((unsigned int) 1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK     ((unsigned int) AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12       ((unsigned int) 1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00   ((unsigned int) AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13       ((unsigned int) 1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01   ((unsigned int) AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1     ((unsigned int) AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14       ((unsigned int) 1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02   ((unsigned int) AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1     ((unsigned int) AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15       ((unsigned int) 1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03   ((unsigned int) AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2    ((unsigned int) AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16       ((unsigned int) 1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0    ((unsigned int) AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17       ((unsigned int) 1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0    ((unsigned int) AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18       ((unsigned int) 1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0    ((unsigned int) AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19       ((unsigned int) 1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX    ((unsigned int) AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2        ((unsigned int) 1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0     ((unsigned int) AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11   ((unsigned int) AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20       ((unsigned int) 1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX    ((unsigned int) AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21       ((unsigned int) 1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF       ((unsigned int) AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10   ((unsigned int) AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22       ((unsigned int) 1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK       ((unsigned int) AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1    ((unsigned int) AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23       ((unsigned int) 1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD       ((unsigned int) AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1    ((unsigned int) AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24       ((unsigned int) 1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD       ((unsigned int) AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1    ((unsigned int) AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25       ((unsigned int) 1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK       ((unsigned int) AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11   ((unsigned int) AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26       ((unsigned int) 1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF       ((unsigned int) AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12   ((unsigned int) AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27       ((unsigned int) 1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD     ((unsigned int) AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3     ((unsigned int) AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28       ((unsigned int) 1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD     ((unsigned int) AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29       ((unsigned int) 1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ      ((unsigned int) AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13   ((unsigned int) AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3        ((unsigned int) 1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0     ((unsigned int) AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12   ((unsigned int) AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30       ((unsigned int) 1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0     ((unsigned int) AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2     ((unsigned int) AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4        ((unsigned int) 1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0     ((unsigned int) AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13   ((unsigned int) AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5        ((unsigned int) 1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1     ((unsigned int) AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6        ((unsigned int) 1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1     ((unsigned int) AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7        ((unsigned int) 1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1     ((unsigned int) AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01   ((unsigned int) AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8        ((unsigned int) 1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1     ((unsigned int) AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02   ((unsigned int) AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9        ((unsigned int) 1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1     ((unsigned int) AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03   ((unsigned int) AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0        ((unsigned int) 1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK ((unsigned int) AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0     ((unsigned int) AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1        ((unsigned int) 1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN    ((unsigned int) AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10       ((unsigned int) 1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2     ((unsigned int) AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11   ((unsigned int) AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11       ((unsigned int) 1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3     ((unsigned int) AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12   ((unsigned int) AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12       ((unsigned int) 1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER    ((unsigned int) AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0    ((unsigned int) AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13       ((unsigned int) 1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2     ((unsigned int) AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01   ((unsigned int) AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14       ((unsigned int) 1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3     ((unsigned int) AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02   ((unsigned int) AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15       ((unsigned int) 1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV    ((unsigned int) AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16       ((unsigned int) 1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL     ((unsigned int) AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13   ((unsigned int) AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17       ((unsigned int) 1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK    ((unsigned int) AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03   ((unsigned int) AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18       ((unsigned int) 1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100    ((unsigned int) AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG    ((unsigned int) AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19       ((unsigned int) 1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0     ((unsigned int) AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1    ((unsigned int) AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2        ((unsigned int) 1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0     ((unsigned int) AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20       ((unsigned int) 1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1     ((unsigned int) AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0     ((unsigned int) AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21       ((unsigned int) 1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2     ((unsigned int) AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1     ((unsigned int) AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22       ((unsigned int) 1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3     ((unsigned int) AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2     ((unsigned int) AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23       ((unsigned int) 1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0    ((unsigned int) AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1     ((unsigned int) AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24       ((unsigned int) 1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0    ((unsigned int) AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1     ((unsigned int) AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25       ((unsigned int) 1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1    ((unsigned int) AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1     ((unsigned int) AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26       ((unsigned int) 1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1    ((unsigned int) AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1      ((unsigned int) AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27       ((unsigned int) 1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2    ((unsigned int) AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0     ((unsigned int) AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28       ((unsigned int) 1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2    ((unsigned int) AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1     ((unsigned int) AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29       ((unsigned int) 1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1     ((unsigned int) AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2     ((unsigned int) AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3        ((unsigned int) 1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1     ((unsigned int) AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30       ((unsigned int) 1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2     ((unsigned int) AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3     ((unsigned int) AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4        ((unsigned int) 1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV ((unsigned int) AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5        ((unsigned int) 1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0     ((unsigned int) AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6        ((unsigned int) 1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1     ((unsigned int) AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7        ((unsigned int) 1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER    ((unsigned int) AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8        ((unsigned int) 1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC     ((unsigned int) AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9        ((unsigned int) 1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO    ((unsigned int) AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_ID_FIQ    ((unsigned int)  0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS    ((unsigned int)  1) // System Peripheral

+#define AT91C_ID_PIOA   ((unsigned int)  2) // Parallel IO Controller A

+#define AT91C_ID_PIOB   ((unsigned int)  3) // Parallel IO Controller B

+#define AT91C_ID_SPI0   ((unsigned int)  4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1   ((unsigned int)  5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0    ((unsigned int)  6) // USART 0

+#define AT91C_ID_US1    ((unsigned int)  7) // USART 1

+#define AT91C_ID_SSC    ((unsigned int)  8) // Serial Synchronous Controller

+#define AT91C_ID_TWI    ((unsigned int)  9) // Two-Wire Interface

+#define AT91C_ID_PWMC   ((unsigned int) 10) // PWM Controller

+#define AT91C_ID_UDP    ((unsigned int) 11) // USB Device Port

+#define AT91C_ID_TC0    ((unsigned int) 12) // Timer Counter 0

+#define AT91C_ID_TC1    ((unsigned int) 13) // Timer Counter 1

+#define AT91C_ID_TC2    ((unsigned int) 14) // Timer Counter 2

+#define AT91C_ID_CAN    ((unsigned int) 15) // Control Area Network Controller

+#define AT91C_ID_EMAC   ((unsigned int) 16) // Ethernet MAC

+#define AT91C_ID_ADC    ((unsigned int) 17) // Analog-to-Digital Converter

+#define AT91C_ID_AES    ((unsigned int) 18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES   ((unsigned int) 19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved ((unsigned int) 20) // Reserved

+#define AT91C_ID_21_Reserved ((unsigned int) 21) // Reserved

+#define AT91C_ID_22_Reserved ((unsigned int) 22) // Reserved

+#define AT91C_ID_23_Reserved ((unsigned int) 23) // Reserved

+#define AT91C_ID_24_Reserved ((unsigned int) 24) // Reserved

+#define AT91C_ID_25_Reserved ((unsigned int) 25) // Reserved

+#define AT91C_ID_26_Reserved ((unsigned int) 26) // Reserved

+#define AT91C_ID_27_Reserved ((unsigned int) 27) // Reserved

+#define AT91C_ID_28_Reserved ((unsigned int) 28) // Reserved

+#define AT91C_ID_29_Reserved ((unsigned int) 29) // Reserved

+#define AT91C_ID_IRQ0   ((unsigned int) 30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1   ((unsigned int) 31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_BASE_SYS       ((AT91PS_SYS) 	0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC       ((AT91PS_AIC) 	0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU  ((AT91PS_PDC) 	0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU      ((AT91PS_DBGU) 	0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA      ((AT91PS_PIO) 	0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB      ((AT91PS_PIO) 	0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR      ((AT91PS_CKGR) 	0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC       ((AT91PS_PMC) 	0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC      ((AT91PS_RSTC) 	0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC      ((AT91PS_RTTC) 	0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC      ((AT91PS_PITC) 	0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC      ((AT91PS_WDTC) 	0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG      ((AT91PS_VREG) 	0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC        ((AT91PS_MC) 	0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1  ((AT91PS_PDC) 	0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1      ((AT91PS_SPI) 	0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0  ((AT91PS_PDC) 	0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0      ((AT91PS_SPI) 	0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1   ((AT91PS_PDC) 	0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1       ((AT91PS_USART) 	0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0   ((AT91PS_PDC) 	0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0       ((AT91PS_USART) 	0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC   ((AT91PS_PDC) 	0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC       ((AT91PS_SSC) 	0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI       ((AT91PS_TWI) 	0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3  ((AT91PS_PWMC_CH) 	0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2  ((AT91PS_PWMC_CH) 	0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1  ((AT91PS_PWMC_CH) 	0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0  ((AT91PS_PWMC_CH) 	0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC      ((AT91PS_PWMC) 	0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP       ((AT91PS_UDP) 	0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0       ((AT91PS_TC) 	0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1       ((AT91PS_TC) 	0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2       ((AT91PS_TC) 	0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB       ((AT91PS_TCB) 	0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0   ((AT91PS_CAN_MB) 	0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1   ((AT91PS_CAN_MB) 	0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2   ((AT91PS_CAN_MB) 	0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3   ((AT91PS_CAN_MB) 	0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4   ((AT91PS_CAN_MB) 	0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5   ((AT91PS_CAN_MB) 	0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6   ((AT91PS_CAN_MB) 	0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7   ((AT91PS_CAN_MB) 	0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN       ((AT91PS_CAN) 	0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC      ((AT91PS_EMAC) 	0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC   ((AT91PS_PDC) 	0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC       ((AT91PS_ADC) 	0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES   ((AT91PS_PDC) 	0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES       ((AT91PS_AES) 	0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES  ((AT91PS_PDC) 	0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES      ((AT91PS_TDES) 	0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_ISRAM	 ((char *) 	0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	 ((unsigned int) 0x00008000) // Internal SRAM size in byte (32 Kbyte)

+#define AT91C_IFLASH	 ((char *) 	0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	 ((unsigned int) 0x00020000) // Internal ROM size in byte (128 Kbyte)

+

+#endif

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128_inc.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128_inc.h
new file mode 100644
index 0000000..96b680a
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X128_inc.h
@@ -0,0 +1,2446 @@
+//  ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+//  ----------------------------------------------------------------------------

+//  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//  ----------------------------------------------------------------------------

+// File Name           : AT91SAM7X128.h

+// Object              : AT91SAM7X128 definitions

+// Generated           : AT91 SW Application Group  05/20/2005 (16:22:23)

+// 

+// CVS Reference       : /AT91SAM7X128.pl/1.14/Tue May 10 12:12:05 2005//

+// CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+//  ----------------------------------------------------------------------------

+

+// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+// *** Register offset in AT91S_AIC structure ***

+#define AIC_SMR         ( 0) // Source Mode Register

+#define AIC_SVR         (128) // Source Vector Register

+#define AIC_IVR         (256) // IRQ Vector Register

+#define AIC_FVR         (260) // FIQ Vector Register

+#define AIC_ISR         (264) // Interrupt Status Register

+#define AIC_IPR         (268) // Interrupt Pending Register

+#define AIC_IMR         (272) // Interrupt Mask Register

+#define AIC_CISR        (276) // Core Interrupt Status Register

+#define AIC_IECR        (288) // Interrupt Enable Command Register

+#define AIC_IDCR        (292) // Interrupt Disable Command Register

+#define AIC_ICCR        (296) // Interrupt Clear Command Register

+#define AIC_ISCR        (300) // Interrupt Set Command Register

+#define AIC_EOICR       (304) // End of Interrupt Command Register

+#define AIC_SPU         (308) // Spurious Vector Register

+#define AIC_DCR         (312) // Debug Control Register (Protect)

+#define AIC_FFER        (320) // Fast Forcing Enable Register

+#define AIC_FFDR        (324) // Fast Forcing Disable Register

+#define AIC_FFSR        (328) // Fast Forcing Status Register

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR           (0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               (0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              (0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE         (0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       (0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        (0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    (0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    (0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           (0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        (0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ            (0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ            (0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT        (0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK        (0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+// *** Register offset in AT91S_PDC structure ***

+#define PDC_RPR         ( 0) // Receive Pointer Register

+#define PDC_RCR         ( 4) // Receive Counter Register

+#define PDC_TPR         ( 8) // Transmit Pointer Register

+#define PDC_TCR         (12) // Transmit Counter Register

+#define PDC_RNPR        (16) // Receive Next Pointer Register

+#define PDC_RNCR        (20) // Receive Next Counter Register

+#define PDC_TNPR        (24) // Transmit Next Pointer Register

+#define PDC_TNCR        (28) // Transmit Next Counter Register

+#define PDC_PTCR        (32) // PDC Transfer Control Register

+#define PDC_PTSR        (36) // PDC Transfer Status Register

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN           (0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS          (0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN           (0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS          (0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+// *** Register offset in AT91S_DBGU structure ***

+#define DBGU_CR         ( 0) // Control Register

+#define DBGU_MR         ( 4) // Mode Register

+#define DBGU_IER        ( 8) // Interrupt Enable Register

+#define DBGU_IDR        (12) // Interrupt Disable Register

+#define DBGU_IMR        (16) // Interrupt Mask Register

+#define DBGU_CSR        (20) // Channel Status Register

+#define DBGU_RHR        (24) // Receiver Holding Register

+#define DBGU_THR        (28) // Transmitter Holding Register

+#define DBGU_BRGR       (32) // Baud Rate Generator Register

+#define DBGU_CIDR       (64) // Chip ID Register

+#define DBGU_EXID       (68) // Chip ID Extension Register

+#define DBGU_FNTR       (72) // Force NTRST Register

+#define DBGU_RPR        (256) // Receive Pointer Register

+#define DBGU_RCR        (260) // Receive Counter Register

+#define DBGU_TPR        (264) // Transmit Pointer Register

+#define DBGU_TCR        (268) // Transmit Counter Register

+#define DBGU_RNPR       (272) // Receive Next Pointer Register

+#define DBGU_RNCR       (276) // Receive Next Counter Register

+#define DBGU_TNPR       (280) // Transmit Next Pointer Register

+#define DBGU_TNCR       (284) // Transmit Next Counter Register

+#define DBGU_PTCR       (288) // PDC Transfer Control Register

+#define DBGU_PTSR       (292) // PDC Transfer Status Register

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX            (0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX            (0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN             (0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS            (0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN             (0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS            (0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA           (0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR              (0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 (0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  (0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                (0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 (0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 (0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           (0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE           (0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               (0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 (0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                (0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               (0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY            (0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY            (0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX            (0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX            (0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE             (0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME            (0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE             (0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY          (0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE           (0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF           (0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX          (0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX          (0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST      (0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PIO structure ***

+#define PIO_PER         ( 0) // PIO Enable Register

+#define PIO_PDR         ( 4) // PIO Disable Register

+#define PIO_PSR         ( 8) // PIO Status Register

+#define PIO_OER         (16) // Output Enable Register

+#define PIO_ODR         (20) // Output Disable Registerr

+#define PIO_OSR         (24) // Output Status Register

+#define PIO_IFER        (32) // Input Filter Enable Register

+#define PIO_IFDR        (36) // Input Filter Disable Register

+#define PIO_IFSR        (40) // Input Filter Status Register

+#define PIO_SODR        (48) // Set Output Data Register

+#define PIO_CODR        (52) // Clear Output Data Register

+#define PIO_ODSR        (56) // Output Data Status Register

+#define PIO_PDSR        (60) // Pin Data Status Register

+#define PIO_IER         (64) // Interrupt Enable Register

+#define PIO_IDR         (68) // Interrupt Disable Register

+#define PIO_IMR         (72) // Interrupt Mask Register

+#define PIO_ISR         (76) // Interrupt Status Register

+#define PIO_MDER        (80) // Multi-driver Enable Register

+#define PIO_MDDR        (84) // Multi-driver Disable Register

+#define PIO_MDSR        (88) // Multi-driver Status Register

+#define PIO_PPUDR       (96) // Pull-up Disable Register

+#define PIO_PPUER       (100) // Pull-up Enable Register

+#define PIO_PPUSR       (104) // Pull-up Status Register

+#define PIO_ASR         (112) // Select A Register

+#define PIO_BSR         (116) // Select B Register

+#define PIO_ABSR        (120) // AB Select Status Register

+#define PIO_OWER        (160) // Output Write Enable Register

+#define PIO_OWDR        (164) // Output Write Disable Register

+#define PIO_OWSR        (168) // Output Write Status Register

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+// *** Register offset in AT91S_CKGR structure ***

+#define CKGR_MOR        ( 0) // Main Oscillator Register

+#define CKGR_MCFR       ( 4) // Main Clock  Frequency Register

+#define CKGR_PLLR       (12) // PLL Register

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN         (0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS      (0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT        (0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF          (0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY        (0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV            (0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    (0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               (0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT       (0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT            (0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    (0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    (0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    (0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    (0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL            (0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV         (0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    (0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    (0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    (0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PMC structure ***

+#define PMC_SCER        ( 0) // System Clock Enable Register

+#define PMC_SCDR        ( 4) // System Clock Disable Register

+#define PMC_SCSR        ( 8) // System Clock Status Register

+#define PMC_PCER        (16) // Peripheral Clock Enable Register

+#define PMC_PCDR        (20) // Peripheral Clock Disable Register

+#define PMC_PCSR        (24) // Peripheral Clock Status Register

+#define PMC_MOR         (32) // Main Oscillator Register

+#define PMC_MCFR        (36) // Main Clock  Frequency Register

+#define PMC_PLLR        (44) // PLL Register

+#define PMC_MCKR        (48) // Master Clock Register

+#define PMC_PCKR        (64) // Programmable Clock Register

+#define PMC_IER         (96) // Interrupt Enable Register

+#define PMC_IDR         (100) // Interrupt Disable Register

+#define PMC_SR          (104) // Status Register

+#define PMC_IMR         (108) // Interrupt Mask Register

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK             (0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP             (0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0            (0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1            (0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2            (0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3            (0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS             (0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             (0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             (0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              (0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES            (0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  (0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                (0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                (0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                (0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               (0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               (0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               (0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS           (0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK            (0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY          (0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY         (0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY         (0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY         (0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY         (0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RSTC structure ***

+#define RSTC_RCR        ( 0) // Reset Control Register

+#define RSTC_RSR        ( 4) // Reset Status Register

+#define RSTC_RMR        ( 8) // Reset Mode Register

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST        (0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST         (0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST         (0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY            (0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS          (0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS         (0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP         (0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              (0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               (0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             (0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             (0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 (0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             (0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL          (0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP          (0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN         (0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN        (0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL          (0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN         (0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RTTC structure ***

+#define RTTC_RTMR       ( 0) // Real-time Mode Register

+#define RTTC_RTAR       ( 4) // Real-time Alarm Register

+#define RTTC_RTVR       ( 8) // Real-time Value Register

+#define RTTC_RTSR       (12) // Real-time Status Register

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES         (0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN         (0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN      (0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST         (0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV           (0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV           (0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS           (0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC         (0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PITC structure ***

+#define PITC_PIMR       ( 0) // Period Interval Mode Register

+#define PITC_PISR       ( 4) // Period Interval Status Register

+#define PITC_PIVR       ( 8) // Period Interval Value Register

+#define PITC_PIIR       (12) // Period Interval Image Register

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV            (0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN          (0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN         (0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS           (0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV           (0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT          (0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_WDTC structure ***

+#define WDTC_WDCR       ( 0) // Watchdog Control Register

+#define WDTC_WDMR       ( 4) // Watchdog Mode Register

+#define WDTC_WDSR       ( 8) // Watchdog Status Register

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT         (0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY            (0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV            (0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN         (0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN        (0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC        (0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS          (0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD            (0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT       (0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT      (0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF          (0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR          (0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_VREG structure ***

+#define VREG_MR         ( 0) // Voltage Regulator Mode Register

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY         (0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_MC structure ***

+#define MC_RCR          ( 0) // MC Remap Control Register

+#define MC_ASR          ( 4) // MC Abort Status Register

+#define MC_AASR         ( 8) // MC Abort Address Status Register

+#define MC_FMR          (96) // MC Flash Mode Register

+#define MC_FCR          (100) // MC Flash Command Register

+#define MC_FSR          (104) // MC Flash Status Register

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB              (0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD           (0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD           (0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ            (0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 (0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                (0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 (0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP           (0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                (0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                (0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                (0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0             (0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1             (0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0           (0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1           (0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY             (0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE            (0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE            (0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP             (0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS              (0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 (0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 (0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 (0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 (0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN             (0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD             (0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           (0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 (0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        (0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               (0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            (0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           (0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           (0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         (0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN            (0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY              (0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY         (0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0           (0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1           (0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2           (0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3           (0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4           (0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5           (0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6           (0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7           (0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0           (0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1           (0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2           (0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3           (0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4           (0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5           (0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6           (0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7           (0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8           (0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9           (0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10          (0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11          (0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12          (0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13          (0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14          (0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15          (0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SPI structure ***

+#define SPI_CR          ( 0) // Control Register

+#define SPI_MR          ( 4) // Mode Register

+#define SPI_RDR         ( 8) // Receive Data Register

+#define SPI_TDR         (12) // Transmit Data Register

+#define SPI_SR          (16) // Status Register

+#define SPI_IER         (20) // Interrupt Enable Register

+#define SPI_IDR         (24) // Interrupt Disable Register

+#define SPI_IMR         (28) // Interrupt Mask Register

+#define SPI_CSR         (48) // Chip Select Register

+#define SPI_RPR         (256) // Receive Pointer Register

+#define SPI_RCR         (260) // Receive Counter Register

+#define SPI_TPR         (264) // Transmit Pointer Register

+#define SPI_TCR         (268) // Transmit Counter Register

+#define SPI_RNPR        (272) // Receive Next Pointer Register

+#define SPI_RNCR        (276) // Receive Next Counter Register

+#define SPI_TNPR        (280) // Transmit Next Pointer Register

+#define SPI_TNCR        (284) // Transmit Next Counter Register

+#define SPI_PTCR        (288) // PDC Transfer Control Register

+#define SPI_PTSR        (292) // PDC Transfer Status Register

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN           (0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS          (0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST           (0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER        (0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR            (0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS              (0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                (0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             (0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC          (0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV            (0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS         (0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB             (0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS             (0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS          (0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD              (0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD              (0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF            (0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE            (0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF            (0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES           (0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX           (0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX           (0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF          (0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE          (0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR            (0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY         (0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS          (0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL            (0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA           (0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT           (0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS            (0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    (0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    (0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   (0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   (0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   (0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   (0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   (0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   (0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   (0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR            (0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS           (0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT          (0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+// *** Register offset in AT91S_USART structure ***

+#define US_CR           ( 0) // Control Register

+#define US_MR           ( 4) // Mode Register

+#define US_IER          ( 8) // Interrupt Enable Register

+#define US_IDR          (12) // Interrupt Disable Register

+#define US_IMR          (16) // Interrupt Mask Register

+#define US_CSR          (20) // Channel Status Register

+#define US_RHR          (24) // Receiver Holding Register

+#define US_THR          (28) // Transmitter Holding Register

+#define US_BRGR         (32) // Baud Rate Generator Register

+#define US_RTOR         (36) // Receiver Time-out Register

+#define US_TTGR         (40) // Transmitter Time-guard Register

+#define US_FIDI         (64) // FI_DI_Ratio Register

+#define US_NER          (68) // Nb Errors Register

+#define US_IF           (76) // IRDA_FILTER Register

+#define US_RPR          (256) // Receive Pointer Register

+#define US_RCR          (260) // Receive Counter Register

+#define US_TPR          (264) // Transmit Pointer Register

+#define US_TCR          (268) // Transmit Counter Register

+#define US_RNPR         (272) // Receive Next Pointer Register

+#define US_RNCR         (276) // Receive Next Counter Register

+#define US_TNPR         (280) // Transmit Next Pointer Register

+#define US_TNCR         (284) // Transmit Next Counter Register

+#define US_PTCR         (288) // PDC Transfer Control Register

+#define US_PTSR         (292) // PDC Transfer Status Register

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK           (0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK           (0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO            (0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA            (0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT            (0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK          (0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO            (0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN            (0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS           (0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN            (0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS           (0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE           (0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               (0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                (0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                (0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                (0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            (0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            (0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 (0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                (0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS             (0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                (0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                (0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 (0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  (0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL             (0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               (0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               (0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               (0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               (0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC             (0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP           (0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                (0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               (0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                (0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF             (0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9            (0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO             (0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER             (0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK            (0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK           (0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER         (0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER           (0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK            (0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT          (0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION        (0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK             (0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC             (0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC            (0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC            (0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC            (0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI               (0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR              (0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD              (0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS              (0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SSC structure ***

+#define SSC_CR          ( 0) // Control Register

+#define SSC_CMR         ( 4) // Clock Mode Register

+#define SSC_RCMR        (16) // Receive Clock ModeRegister

+#define SSC_RFMR        (20) // Receive Frame Mode Register

+#define SSC_TCMR        (24) // Transmit Clock Mode Register

+#define SSC_TFMR        (28) // Transmit Frame Mode Register

+#define SSC_RHR         (32) // Receive Holding Register

+#define SSC_THR         (36) // Transmit Holding Register

+#define SSC_RSHR        (48) // Receive Sync Holding Register

+#define SSC_TSHR        (52) // Transmit Sync Holding Register

+#define SSC_SR          (64) // Status Register

+#define SSC_IER         (68) // Interrupt Enable Register

+#define SSC_IDR         (72) // Interrupt Disable Register

+#define SSC_IMR         (76) // Interrupt Mask Register

+#define SSC_RPR         (256) // Receive Pointer Register

+#define SSC_RCR         (260) // Receive Counter Register

+#define SSC_TPR         (264) // Transmit Pointer Register

+#define SSC_TCR         (268) // Transmit Counter Register

+#define SSC_RNPR        (272) // Receive Next Pointer Register

+#define SSC_RNCR        (276) // Receive Next Counter Register

+#define SSC_TNPR        (280) // Transmit Next Pointer Register

+#define SSC_TNCR        (284) // Transmit Next Counter Register

+#define SSC_PTCR        (288) // PDC Transfer Control Register

+#define SSC_PTSR        (292) // PDC Transfer Status Register

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN            (0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS           (0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN            (0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS           (0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST           (0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS             (0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  (0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   (0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   (0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO             (0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 (0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            (0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              (0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI             (0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START           (0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            (0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   (0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               (0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              (0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              (0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              (0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             (0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              (0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    (0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY          (0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD          (0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN          (0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP            (0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF            (0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB           (0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN           (0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS            (0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 (0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             (0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             (0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  (0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 (0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               (0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE          (0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF          (0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN           (0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY           (0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY         (0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX           (0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE          (0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY           (0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN           (0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX           (0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF          (0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN           (0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN           (0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA           (0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA           (0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TWI structure ***

+#define TWI_CR          ( 0) // Control Register

+#define TWI_MMR         ( 4) // Master Mode Register

+#define TWI_IADR        (12) // Internal Address Register

+#define TWI_CWGR        (16) // Clock Waveform Generator Register

+#define TWI_SR          (32) // Status Register

+#define TWI_IER         (36) // Interrupt Enable Register

+#define TWI_IDR         (40) // Interrupt Disable Register

+#define TWI_IMR         (44) // Interrupt Mask Register

+#define TWI_RHR         (48) // Receive Holding Register

+#define TWI_THR         (52) // Transmit Holding Register

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START           (0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP            (0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN            (0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS           (0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST           (0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ          (0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   (0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               (0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               (0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               (0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD           (0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR            (0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV           (0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV           (0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV           (0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP          (0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY           (0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY           (0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE            (0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE            (0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK            (0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC_CH structure ***

+#define PWMC_CMR        ( 0) // Channel Mode Register

+#define PWMC_CDTYR      ( 4) // Channel Duty Cycle Register

+#define PWMC_CPRDR      ( 8) // Channel Period Register

+#define PWMC_CCNTR      (12) // Channel Counter Register

+#define PWMC_CUPDR      (16) // Channel Update Register

+#define PWMC_Reserved   (20) // Reserved

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE           (0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  (0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 (0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 (0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG           (0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL           (0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD            (0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY           (0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD           (0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT           (0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD           (0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC structure ***

+#define PWMC_MR         ( 0) // PWMC Mode Register

+#define PWMC_ENA        ( 4) // PWMC Enable Register

+#define PWMC_DIS        ( 8) // PWMC Disable Register

+#define PWMC_SR         (12) // PWMC Status Register

+#define PWMC_IER        (16) // PWMC Interrupt Enable Register

+#define PWMC_IDR        (20) // PWMC Interrupt Disable Register

+#define PWMC_IMR        (24) // PWMC Interrupt Mask Register

+#define PWMC_ISR        (28) // PWMC Interrupt Status Register

+#define PWMC_VR         (252) // PWMC Version Register

+#define PWMC_CH         (512) // PWMC Channel

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA           (0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA           (0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  (0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB           (0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB           (0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  (0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0          (0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1          (0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2          (0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3          (0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+// *** Register offset in AT91S_UDP structure ***

+#define UDP_NUM         ( 0) // Frame Number Register

+#define UDP_GLBSTATE    ( 4) // Global State Register

+#define UDP_FADDR       ( 8) // Function Address Register

+#define UDP_IER         (16) // Interrupt Enable Register

+#define UDP_IDR         (20) // Interrupt Disable Register

+#define UDP_IMR         (24) // Interrupt Mask Register

+#define UDP_ISR         (28) // Interrupt Status Register

+#define UDP_ICR         (32) // Interrupt Clear Register

+#define UDP_RSTEP       (40) // Reset Endpoint Register

+#define UDP_CSR         (48) // Endpoint Control and Status Register

+#define UDP_FDR         (80) // Endpoint FIFO Data Register

+#define UDP_TXVC        (116) // Transceiver Control Register

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM         (0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR         (0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK          (0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN          (0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG           (0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR             (0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR         (0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE          (0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD            (0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN             (0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0          (0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1          (0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2          (0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3          (0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4          (0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5          (0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP          (0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM           (0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM          (0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT          (0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP          (0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES       (0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0             (0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1             (0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2             (0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3             (0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4             (0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5             (0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP          (0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0     (0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP         (0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR        (0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY        (0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL      (0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1     (0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR             (0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE          (0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 (0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              (0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             (0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              (0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               (0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              (0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               (0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE           (0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS           (0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT       (0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS          (0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON            (0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TC structure ***

+#define TC_CCR          ( 0) // Channel Control Register

+#define TC_CMR          ( 4) // Channel Mode Register (Capture Mode / Waveform Mode)

+#define TC_CV           (16) // Counter Value

+#define TC_RA           (20) // Register A

+#define TC_RB           (24) // Register B

+#define TC_RC           (28) // Register C

+#define TC_SR           (32) // Status Register

+#define TC_IER          (36) // Interrupt Enable Register

+#define TC_IDR          (40) // Interrupt Disable Register

+#define TC_IMR          (44) // Interrupt Mask Register

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN            (0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS           (0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG            (0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS             (0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     (0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     (0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     (0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     (0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     (0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  (0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  (0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  (0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI             (0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST            (0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 (0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  (0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  (0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  (0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS           (0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS           (0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG          (0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG          (0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT             (0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 (0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  (0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  (0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  (0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG           (0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG           (0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL          (0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   (0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               (0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              (0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          (0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG           (0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE             (0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA             (0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 (0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  (0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                (0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               (0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA             (0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 (0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               (0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              (0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 (0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC             (0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 (0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  (0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                (0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               (0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB             (0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 (0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               (0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              (0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 (0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT            (0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 (0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  (0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                (0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               (0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG           (0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 (0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  (0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                (0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               (0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB             (0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 (0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  (0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                (0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               (0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC             (0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 (0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  (0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                (0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               (0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT            (0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 (0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  (0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                (0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               (0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG           (0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 (0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  (0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                (0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               (0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS            (0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS            (0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS             (0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS             (0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS             (0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS            (0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS            (0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS            (0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA           (0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA            (0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB            (0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TCB structure ***

+#define TCB_TC0         ( 0) // TC Channel 0

+#define TCB_TC1         (64) // TC Channel 1

+#define TCB_TC2         (128) // TC Channel 2

+#define TCB_BCR         (192) // TC Block Control Register

+#define TCB_BMR         (196) // TC Block Mode Register

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC            (0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S         (0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                (0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 (0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                (0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                (0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S         (0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                (0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 (0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                (0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                (0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S         (0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                (0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 (0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                (0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                (0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+// *** Register offset in AT91S_CAN_MB structure ***

+#define CAN_MB_MMR      ( 0) // MailBox Mode Register

+#define CAN_MB_MAM      ( 4) // MailBox Acceptance Mask Register

+#define CAN_MB_MID      ( 8) // MailBox ID Register

+#define CAN_MB_MFID     (12) // MailBox Family ID Register

+#define CAN_MB_MSR      (16) // MailBox Status Register

+#define CAN_MB_MDL      (20) // MailBox Data Low Register

+#define CAN_MB_MDH      (24) // MailBox Data High Register

+#define CAN_MB_MCR      (28) // MailBox Control Register

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK       (0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR           (0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT             (0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  (0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   (0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          (0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   (0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             (0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             (0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB           (0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA           (0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE            (0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP      (0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC            (0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR            (0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT            (0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY            (0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI             (0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR            (0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR            (0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+// *** Register offset in AT91S_CAN structure ***

+#define CAN_MR          ( 0) // Mode Register

+#define CAN_IER         ( 4) // Interrupt Enable Register

+#define CAN_IDR         ( 8) // Interrupt Disable Register

+#define CAN_IMR         (12) // Interrupt Mask Register

+#define CAN_SR          (16) // Status Register

+#define CAN_BR          (20) // Baudrate Register

+#define CAN_TIM         (24) // Timer Register

+#define CAN_TIMESTP     (28) // Time Stamp Register

+#define CAN_ECR         (32) // Error Counter Register

+#define CAN_TCR         (36) // Transfer Command Register

+#define CAN_ACR         (40) // Abort Command Register

+#define CAN_VR          (252) // Version Register

+#define CAN_MB0         (512) // CAN Mailbox 0

+#define CAN_MB1         (544) // CAN Mailbox 1

+#define CAN_MB2         (576) // CAN Mailbox 2

+#define CAN_MB3         (608) // CAN Mailbox 3

+#define CAN_MB4         (640) // CAN Mailbox 4

+#define CAN_MB5         (672) // CAN Mailbox 5

+#define CAN_MB6         (704) // CAN Mailbox 6

+#define CAN_MB7         (736) // CAN Mailbox 7

+#define CAN_MB8         (768) // CAN Mailbox 8

+#define CAN_MB9         (800) // CAN Mailbox 9

+#define CAN_MB10        (832) // CAN Mailbox 10

+#define CAN_MB11        (864) // CAN Mailbox 11

+#define CAN_MB12        (896) // CAN Mailbox 12

+#define CAN_MB13        (928) // CAN Mailbox 13

+#define CAN_MB14        (960) // CAN Mailbox 14

+#define CAN_MB15        (992) // CAN Mailbox 15

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN           (0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM             (0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM             (0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL             (0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF            (0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM             (0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ          (0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT            (0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0             (0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1             (0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2             (0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3             (0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4             (0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5             (0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6             (0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7             (0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8             (0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9             (0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10            (0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11            (0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12            (0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13            (0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14            (0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15            (0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA            (0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN            (0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP            (0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF            (0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP           (0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP          (0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF            (0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP            (0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR            (0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR            (0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR            (0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR            (0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR            (0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY            (0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY            (0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY            (0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2          (0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1          (0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG          (0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC            (0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP             (0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP             (0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER           (0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC             (0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC             (0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST          (0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+// *** Register offset in AT91S_EMAC structure ***

+#define EMAC_NCR        ( 0) // Network Control Register

+#define EMAC_NCFGR      ( 4) // Network Configuration Register

+#define EMAC_NSR        ( 8) // Network Status Register

+#define EMAC_TSR        (20) // Transmit Status Register

+#define EMAC_RBQP       (24) // Receive Buffer Queue Pointer

+#define EMAC_TBQP       (28) // Transmit Buffer Queue Pointer

+#define EMAC_RSR        (32) // Receive Status Register

+#define EMAC_ISR        (36) // Interrupt Status Register

+#define EMAC_IER        (40) // Interrupt Enable Register

+#define EMAC_IDR        (44) // Interrupt Disable Register

+#define EMAC_IMR        (48) // Interrupt Mask Register

+#define EMAC_MAN        (52) // PHY Maintenance Register

+#define EMAC_PTR        (56) // Pause Time Register

+#define EMAC_PFR        (60) // Pause Frames received Register

+#define EMAC_FTO        (64) // Frames Transmitted OK Register

+#define EMAC_SCF        (68) // Single Collision Frame Register

+#define EMAC_MCF        (72) // Multiple Collision Frame Register

+#define EMAC_FRO        (76) // Frames Received OK Register

+#define EMAC_FCSE       (80) // Frame Check Sequence Error Register

+#define EMAC_ALE        (84) // Alignment Error Register

+#define EMAC_DTF        (88) // Deferred Transmission Frame Register

+#define EMAC_LCOL       (92) // Late Collision Register

+#define EMAC_ECOL       (96) // Excessive Collision Register

+#define EMAC_TUND       (100) // Transmit Underrun Error Register

+#define EMAC_CSE        (104) // Carrier Sense Error Register

+#define EMAC_RRE        (108) // Receive Ressource Error Register

+#define EMAC_ROV        (112) // Receive Overrun Errors Register

+#define EMAC_RSE        (116) // Receive Symbol Errors Register

+#define EMAC_ELE        (120) // Excessive Length Errors Register

+#define EMAC_RJA        (124) // Receive Jabbers Register

+#define EMAC_USF        (128) // Undersize Frames Register

+#define EMAC_STE        (132) // SQE Test Error Register

+#define EMAC_RLE        (136) // Receive Length Field Mismatch Register

+#define EMAC_TPF        (140) // Transmitted Pause Frames Register

+#define EMAC_HRB        (144) // Hash Address Bottom[31:0]

+#define EMAC_HRT        (148) // Hash Address Top[63:32]

+#define EMAC_SA1L       (152) // Specific Address 1 Bottom, First 4 bytes

+#define EMAC_SA1H       (156) // Specific Address 1 Top, Last 2 bytes

+#define EMAC_SA2L       (160) // Specific Address 2 Bottom, First 4 bytes

+#define EMAC_SA2H       (164) // Specific Address 2 Top, Last 2 bytes

+#define EMAC_SA3L       (168) // Specific Address 3 Bottom, First 4 bytes

+#define EMAC_SA3H       (172) // Specific Address 3 Top, Last 2 bytes

+#define EMAC_SA4L       (176) // Specific Address 4 Bottom, First 4 bytes

+#define EMAC_SA4H       (180) // Specific Address 4 Top, Last 2 bytes

+#define EMAC_TID        (184) // Type ID Checking Register

+#define EMAC_TPQ        (188) // Transmit Pause Quantum Register

+#define EMAC_USRIO      (192) // USER Input/Output Register

+#define EMAC_WOL        (196) // Wake On LAN Register

+#define EMAC_REV        (252) // Revision Register

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB             (0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB            (0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE             (0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE             (0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE            (0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT        (0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT        (0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT         (0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP             (0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART         (0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT          (0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR           (0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ            (0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD            (0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD             (0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME         (0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF            (0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC            (0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI            (0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI            (0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG            (0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE            (0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK            (0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               (0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              (0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              (0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              (0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY            (0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE            (0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF           (0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             (0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             (0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             (0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             (0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE           (0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS          (0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD          (0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS         (0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR          (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO           (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE           (0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL            (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES           (0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO            (0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX            (0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP           (0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND            (0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC            (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR            (0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP          (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR          (0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR          (0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR          (0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX           (0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR          (0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP          (0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK           (0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR           (0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP          (0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE           (0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ            (0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA           (0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE           (0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA           (0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA           (0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW             (0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF            (0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII           (0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP             (0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG            (0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP            (0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1            (0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF         (0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF        (0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+// *** Register offset in AT91S_ADC structure ***

+#define ADC_CR          ( 0) // ADC Control Register

+#define ADC_MR          ( 4) // ADC Mode Register

+#define ADC_CHER        (16) // ADC Channel Enable Register

+#define ADC_CHDR        (20) // ADC Channel Disable Register

+#define ADC_CHSR        (24) // ADC Channel Status Register

+#define ADC_SR          (28) // ADC Status Register

+#define ADC_LCDR        (32) // ADC Last Converted Data Register

+#define ADC_IER         (36) // ADC Interrupt Enable Register

+#define ADC_IDR         (40) // ADC Interrupt Disable Register

+#define ADC_IMR         (44) // ADC Interrupt Mask Register

+#define ADC_CDR0        (48) // ADC Channel Data Register 0

+#define ADC_CDR1        (52) // ADC Channel Data Register 1

+#define ADC_CDR2        (56) // ADC Channel Data Register 2

+#define ADC_CDR3        (60) // ADC Channel Data Register 3

+#define ADC_CDR4        (64) // ADC Channel Data Register 4

+#define ADC_CDR5        (68) // ADC Channel Data Register 5

+#define ADC_CDR6        (72) // ADC Channel Data Register 6

+#define ADC_CDR7        (76) // ADC Channel Data Register 7

+#define ADC_RPR         (256) // Receive Pointer Register

+#define ADC_RCR         (260) // Receive Counter Register

+#define ADC_TPR         (264) // Transmit Pointer Register

+#define ADC_TCR         (268) // Transmit Counter Register

+#define ADC_RNPR        (272) // Receive Next Pointer Register

+#define ADC_RNCR        (276) // Receive Next Counter Register

+#define ADC_TNPR        (280) // Transmit Next Pointer Register

+#define ADC_TNCR        (284) // Transmit Next Counter Register

+#define ADC_PTCR        (288) // PDC Transfer Control Register

+#define ADC_PTSR        (292) // PDC Transfer Status Register

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST           (0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START           (0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN           (0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  (0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   (0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL          (0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                (0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                (0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                (0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                (0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                (0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                (0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  (0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES          (0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               (0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                (0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP           (0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          (0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 (0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL         (0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP         (0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM           (0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0             (0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1             (0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2             (0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3             (0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4             (0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5             (0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6             (0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7             (0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0            (0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1            (0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2            (0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3            (0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4            (0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5            (0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6            (0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7            (0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0           (0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1           (0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2           (0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3           (0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4           (0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5           (0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6           (0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7           (0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY            (0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE           (0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX           (0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF          (0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA           (0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA            (0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+// *** Register offset in AT91S_AES structure ***

+#define AES_CR          ( 0) // Control Register

+#define AES_MR          ( 4) // Mode Register

+#define AES_IER         (16) // Interrupt Enable Register

+#define AES_IDR         (20) // Interrupt Disable Register

+#define AES_IMR         (24) // Interrupt Mask Register

+#define AES_ISR         (28) // Interrupt Status Register

+#define AES_KEYWxR      (32) // Key Word x Register

+#define AES_IDATAxR     (64) // Input Data x Register

+#define AES_ODATAxR     (80) // Output Data x Register

+#define AES_IVxR        (96) // Initialization Vector x Register

+#define AES_VR          (252) // AES Version Register

+#define AES_RPR         (256) // Receive Pointer Register

+#define AES_RCR         (260) // Receive Counter Register

+#define AES_TPR         (264) // Transmit Pointer Register

+#define AES_TCR         (268) // Transmit Counter Register

+#define AES_RNPR        (272) // Receive Next Pointer Register

+#define AES_RNCR        (276) // Receive Next Counter Register

+#define AES_TNPR        (280) // Transmit Next Pointer Register

+#define AES_TNCR        (284) // Transmit Next Counter Register

+#define AES_PTCR        (288) // PDC Transfer Control Register

+#define AES_PTSR        (292) // PDC Transfer Status Register

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START           (0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST           (0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED        (0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER          (0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY         (0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD            (0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               (0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 (0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  (0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD           (0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  (0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  (0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  (0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  (0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  (0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD             (0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS            (0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              (0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               (0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               (0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               (0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                (0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY            (0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE           (0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             (0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             (0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             (0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             (0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             (0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY          (0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX           (0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX           (0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF          (0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE          (0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD            (0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT            (0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC (0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC (0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC (0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  (0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY (0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          (0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+// *** Register offset in AT91S_TDES structure ***

+#define TDES_CR         ( 0) // Control Register

+#define TDES_MR         ( 4) // Mode Register

+#define TDES_IER        (16) // Interrupt Enable Register

+#define TDES_IDR        (20) // Interrupt Disable Register

+#define TDES_IMR        (24) // Interrupt Mask Register

+#define TDES_ISR        (28) // Interrupt Status Register

+#define TDES_KEY1WxR    (32) // Key 1 Word x Register

+#define TDES_KEY2WxR    (40) // Key 2 Word x Register

+#define TDES_KEY3WxR    (48) // Key 3 Word x Register

+#define TDES_IDATAxR    (64) // Input Data x Register

+#define TDES_ODATAxR    (80) // Output Data x Register

+#define TDES_IVxR       (96) // Initialization Vector x Register

+#define TDES_VR         (252) // TDES Version Register

+#define TDES_RPR        (256) // Receive Pointer Register

+#define TDES_RCR        (260) // Receive Counter Register

+#define TDES_TPR        (264) // Transmit Pointer Register

+#define TDES_TCR        (268) // Transmit Counter Register

+#define TDES_RNPR       (272) // Receive Next Pointer Register

+#define TDES_RNCR       (276) // Receive Next Counter Register

+#define TDES_TNPR       (280) // Transmit Next Pointer Register

+#define TDES_TNCR       (284) // Transmit Next Counter Register

+#define TDES_PTCR       (288) // PDC Transfer Control Register

+#define TDES_PTSR       (292) // PDC Transfer Status Register

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START          (0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST          (0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER         (0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD        (0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD         (0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD           (0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               (0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 (0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  (0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD          (0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  (0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  (0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  (0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  (0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD            (0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS           (0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               (0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               (0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               (0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                (0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY         (0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX          (0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX          (0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF         (0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE         (0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD           (0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT           (0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC (0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC (0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC (0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          (0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X128

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR             (0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR             (0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR             (0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR             (0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR           (0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR             (0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR            (0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR            (0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR             (0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR             (0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR             (0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER            (0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR            (0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR            (0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR            (0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR            (0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR            (0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU             (0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR            (0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR           (0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR           (0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR            (0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR            (0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR            (0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR           (0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR           (0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR           (0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR           (0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID           (0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR           (0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR            (0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR            (0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR           (0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR             (0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR            (0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR             (0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR           (0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR            (0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR            (0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER            (0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR            (0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR           (0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR            (0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR           (0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER            (0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR          (0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR            (0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER            (0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR           (0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR           (0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR           (0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR            (0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR           (0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR          (0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR           (0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR            (0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER           (0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER           (0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR           (0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER          (0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR            (0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR            (0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR           (0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR           (0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER           (0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR            (0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR           (0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER            (0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR            (0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR           (0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER           (0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR          (0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR            (0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR            (0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR          (0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR            (0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER            (0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR           (0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER           (0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR           (0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR           (0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR           (0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR            (0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR           (0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR            (0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR            (0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR           (0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER          (0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR           (0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR            (0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR           (0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR            (0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR           (0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER           (0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR            (0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR           (0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER            (0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER            (0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR            (0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR           (0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR           (0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR             (0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR             (0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR            (0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER            (0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR            (0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR            (0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR            (0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR            (0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR            (0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR            (0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR            (0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER            (0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR             (0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER             (0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR              (0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR            (0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR            (0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR            (0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR           (0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR           (0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR           (0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR           (0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR           (0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR           (0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR           (0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR           (0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR           (0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR           (0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR           (0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR             (0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR              (0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR              (0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR              (0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR             (0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR              (0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR              (0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR           (0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR            (0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR           (0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR            (0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR           (0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR            (0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR            (0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR           (0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR           (0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR           (0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR            (0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER            (0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR             (0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR            (0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR            (0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR             (0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR            (0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR             (0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR            (0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR           (0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR            (0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR            (0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR            (0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR           (0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR           (0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR            (0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR           (0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR           (0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR           (0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER            (0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR             (0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR            (0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR             (0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR             (0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR            (0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR            (0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR            (0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR            (0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR            (0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR            (0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR             (0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR            (0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR            (0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR             (0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR            (0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR             (0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR            (0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR             (0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF              (0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER             (0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR            (0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR             (0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR             (0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER             (0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR             (0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR            (0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR             (0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR            (0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR             (0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI            (0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR              (0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR              (0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR            (0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR            (0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR             (0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR            (0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR            (0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR            (0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR             (0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR             (0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR             (0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR            (0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR            (0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER             (0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR              (0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR             (0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI            (0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR            (0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR              (0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR            (0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR             (0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR             (0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR             (0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR             (0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF              (0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER             (0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR            (0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR             (0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR            (0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR             (0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR            (0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR             (0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR             (0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR            (0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR            (0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR            (0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR             (0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR            (0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR            (0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR             (0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR             (0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR            (0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER             (0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR            (0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR              (0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR             (0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR            (0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR              (0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR             (0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR            (0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER             (0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR              (0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR              (0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR             (0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR             (0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR             (0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR            (0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR             (0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR            (0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR             (0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR      (0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved   (0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR      (0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR      (0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR      (0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR        (0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved   (0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR        (0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR      (0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR      (0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR      (0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR      (0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved   (0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR      (0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR      (0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR      (0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR      (0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR        (0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved   (0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR      (0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR      (0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR        (0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR      (0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR      (0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR            (0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS            (0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER            (0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR             (0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR            (0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR             (0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR            (0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR             (0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA            (0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR             (0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR           (0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM             (0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR             (0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR             (0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR             (0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR             (0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR             (0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP           (0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC            (0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE        (0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER             (0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR              (0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC              (0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB              (0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR             (0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR             (0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER             (0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA              (0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR             (0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV              (0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR             (0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB              (0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR             (0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER             (0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR             (0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR              (0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR             (0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA              (0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC              (0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR             (0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV              (0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR             (0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR             (0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV              (0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA              (0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB              (0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR             (0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR             (0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC              (0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER             (0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR              (0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR             (0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR             (0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL         (0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM         (0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR         (0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID         (0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR         (0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID        (0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH         (0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR         (0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL         (0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID         (0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR         (0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR         (0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM         (0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH         (0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR         (0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID        (0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR         (0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH         (0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID         (0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL         (0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR         (0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM         (0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID        (0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR         (0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID        (0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM         (0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID         (0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR         (0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR         (0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR         (0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL         (0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH         (0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID         (0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR         (0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH         (0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID        (0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR         (0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR         (0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL         (0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM         (0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR         (0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR         (0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID        (0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH         (0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID         (0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR         (0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL         (0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM         (0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID        (0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID         (0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM         (0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR         (0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL         (0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR         (0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH         (0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR         (0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR         (0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH         (0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID        (0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL         (0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID         (0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR         (0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM         (0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR         (0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR             (0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR             (0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER             (0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR             (0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP         (0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR              (0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR             (0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR             (0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM             (0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR              (0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR              (0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR              (0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR            (0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H           (0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L           (0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE            (0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL           (0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE            (0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL            (0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF            (0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND           (0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR            (0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L           (0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR            (0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L           (0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR            (0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR            (0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE            (0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL           (0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID            (0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB            (0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP           (0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO          (0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR            (0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H           (0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV            (0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE            (0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA            (0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP           (0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF            (0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR          (0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT            (0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF            (0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE           (0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ            (0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN            (0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO            (0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV            (0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR            (0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF            (0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR            (0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF            (0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR            (0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L           (0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO            (0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER            (0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H           (0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE            (0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H           (0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE            (0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE            (0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR            (0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR            (0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR            (0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR            (0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR            (0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR            (0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR             (0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR             (0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR             (0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR             (0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2            (0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3            (0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0            (0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5            (0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR            (0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR              (0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4            (0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1            (0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR            (0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR             (0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR              (0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7            (0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6            (0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER             (0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER            (0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR            (0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR              (0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR             (0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR             (0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR            (0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR            (0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR            (0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR             (0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR             (0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR            (0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR            (0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR             (0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR            (0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR            (0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR              (0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR              (0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR         (0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR         (0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR              (0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR             (0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR             (0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER             (0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR          (0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR             (0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR           (0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR            (0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR            (0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR           (0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR           (0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR            (0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR           (0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR            (0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR           (0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR           (0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR        (0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR        (0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR            (0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR             (0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR           (0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR        (0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR            (0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR             (0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR             (0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER            (0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR            (0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR        (0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR        (0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_PIO_PA0             (1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0            (AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1             (1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0            (AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10            (1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD            (AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11            (1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK           (AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12            (1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00         (AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13            (1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01         (AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1           (AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14            (1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02         (AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1           (AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15            (1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03         (AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2          (AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16            (1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0          (AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17            (1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0          (AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18            (1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0          (AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19            (1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX          (AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2             (1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0            (AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11          (AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20            (1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX          (AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21            (1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF             (AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10         (AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22            (1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK             (AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1          (AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23            (1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD             (AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1          (AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24            (1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD             (AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1          (AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25            (1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK             (AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11         (AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26            (1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF             (AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12         (AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27            (1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD           (AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3           (AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28            (1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD           (AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29            (1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ            (AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13         (AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3             (1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0            (AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12          (AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30            (1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0           (AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2           (AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4             (1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0            (AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13          (AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5             (1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1            (AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6             (1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1            (AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7             (1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1            (AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01          (AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8             (1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1            (AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02          (AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9             (1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1            (AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03          (AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0             (1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK    (AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0            (AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1             (1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN           (AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10            (1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2           (AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11         (AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11            (1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3           (AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12         (AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12            (1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER          (AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0          (AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13            (1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2           (AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01         (AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14            (1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3           (AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02         (AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15            (1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV          (AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16            (1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL           (AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13         (AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17            (1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK          (AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03         (AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18            (1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100          (AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG          (AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19            (1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0           (AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1          (AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2             (1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0            (AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20            (1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1           (AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0           (AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21            (1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2           (AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1           (AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22            (1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3           (AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2           (AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23            (1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0          (AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1           (AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24            (1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0          (AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1           (AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25            (1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1          (AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1           (AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26            (1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1          (AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1            (AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27            (1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2          (AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0           (AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28            (1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2          (AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1           (AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29            (1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1           (AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2           (AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3             (1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1            (AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30            (1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2           (AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3           (AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4             (1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV     (AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5             (1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0            (AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6             (1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1            (AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7             (1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER           (AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8             (1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC            (AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9             (1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO           (AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_ID_FIQ              ( 0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS              ( 1) // System Peripheral

+#define AT91C_ID_PIOA             ( 2) // Parallel IO Controller A

+#define AT91C_ID_PIOB             ( 3) // Parallel IO Controller B

+#define AT91C_ID_SPI0             ( 4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1             ( 5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0              ( 6) // USART 0

+#define AT91C_ID_US1              ( 7) // USART 1

+#define AT91C_ID_SSC              ( 8) // Serial Synchronous Controller

+#define AT91C_ID_TWI              ( 9) // Two-Wire Interface

+#define AT91C_ID_PWMC             (10) // PWM Controller

+#define AT91C_ID_UDP              (11) // USB Device Port

+#define AT91C_ID_TC0              (12) // Timer Counter 0

+#define AT91C_ID_TC1              (13) // Timer Counter 1

+#define AT91C_ID_TC2              (14) // Timer Counter 2

+#define AT91C_ID_CAN              (15) // Control Area Network Controller

+#define AT91C_ID_EMAC             (16) // Ethernet MAC

+#define AT91C_ID_ADC              (17) // Analog-to-Digital Converter

+#define AT91C_ID_AES              (18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES             (19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved      (20) // Reserved

+#define AT91C_ID_21_Reserved      (21) // Reserved

+#define AT91C_ID_22_Reserved      (22) // Reserved

+#define AT91C_ID_23_Reserved      (23) // Reserved

+#define AT91C_ID_24_Reserved      (24) // Reserved

+#define AT91C_ID_25_Reserved      (25) // Reserved

+#define AT91C_ID_26_Reserved      (26) // Reserved

+#define AT91C_ID_27_Reserved      (27) // Reserved

+#define AT91C_ID_28_Reserved      (28) // Reserved

+#define AT91C_ID_29_Reserved      (29) // Reserved

+#define AT91C_ID_IRQ0             (30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1             (31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_BASE_SYS            (0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC            (0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU       (0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU           (0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA           (0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB           (0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR           (0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC            (0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC           (0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC           (0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC           (0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC           (0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG           (0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC             (0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1       (0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1           (0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0       (0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0           (0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1        (0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1            (0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0        (0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0            (0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC        (0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC            (0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI            (0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3       (0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2       (0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1       (0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0       (0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC           (0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP            (0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0            (0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1            (0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2            (0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB            (0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0        (0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1        (0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2        (0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3        (0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4        (0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5        (0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6        (0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7        (0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN            (0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC           (0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC        (0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC            (0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES        (0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES            (0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES       (0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES           (0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X128

+// *****************************************************************************

+#define AT91C_ISRAM	              (0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	         (0x00008000) // Internal SRAM size in byte (32 Kbyte)

+#define AT91C_IFLASH	             (0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	        (0x00020000) // Internal ROM size in byte (128 Kbyte)

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256.h
new file mode 100644
index 0000000..6b73f8a
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256.h
@@ -0,0 +1,2715 @@
+//  ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+//  ----------------------------------------------------------------------------

+//  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//  ----------------------------------------------------------------------------

+// File Name           : AT91SAM7X256.h

+// Object              : AT91SAM7X256 definitions

+// Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+// 

+// CVS Reference       : /AT91SAM7X256.pl/1.11/Tue May 10 12:15:32 2005//

+// CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+//  ----------------------------------------------------------------------------

+

+#ifndef AT91SAM7X256_H

+#define AT91SAM7X256_H

+

+typedef volatile unsigned int AT91_REG;// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+typedef struct _AT91S_SYS {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+	AT91_REG	 Reserved2[45]; 	// 

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved3[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved4[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+	AT91_REG	 Reserved5[54]; 	// 

+	AT91_REG	 PIOA_PER; 	// PIO Enable Register

+	AT91_REG	 PIOA_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOA_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved6[1]; 	// 

+	AT91_REG	 PIOA_OER; 	// Output Enable Register

+	AT91_REG	 PIOA_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOA_OSR; 	// Output Status Register

+	AT91_REG	 Reserved7[1]; 	// 

+	AT91_REG	 PIOA_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOA_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOA_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved8[1]; 	// 

+	AT91_REG	 PIOA_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOA_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOA_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOA_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOA_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOA_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOA_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOA_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOA_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOA_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOA_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved9[1]; 	// 

+	AT91_REG	 PIOA_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOA_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOA_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved10[1]; 	// 

+	AT91_REG	 PIOA_ASR; 	// Select A Register

+	AT91_REG	 PIOA_BSR; 	// Select B Register

+	AT91_REG	 PIOA_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved11[9]; 	// 

+	AT91_REG	 PIOA_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOA_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOA_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved12[85]; 	// 

+	AT91_REG	 PIOB_PER; 	// PIO Enable Register

+	AT91_REG	 PIOB_PDR; 	// PIO Disable Register

+	AT91_REG	 PIOB_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved13[1]; 	// 

+	AT91_REG	 PIOB_OER; 	// Output Enable Register

+	AT91_REG	 PIOB_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIOB_OSR; 	// Output Status Register

+	AT91_REG	 Reserved14[1]; 	// 

+	AT91_REG	 PIOB_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIOB_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIOB_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved15[1]; 	// 

+	AT91_REG	 PIOB_SODR; 	// Set Output Data Register

+	AT91_REG	 PIOB_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIOB_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIOB_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIOB_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIOB_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIOB_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIOB_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIOB_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIOB_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIOB_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved16[1]; 	// 

+	AT91_REG	 PIOB_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIOB_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIOB_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved17[1]; 	// 

+	AT91_REG	 PIOB_ASR; 	// Select A Register

+	AT91_REG	 PIOB_BSR; 	// Select B Register

+	AT91_REG	 PIOB_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved18[9]; 	// 

+	AT91_REG	 PIOB_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIOB_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIOB_OWSR; 	// Output Write Status Register

+	AT91_REG	 Reserved19[341]; 	// 

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved20[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved21[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved22[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved23[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved24[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved25[36]; 	// 

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+	AT91_REG	 Reserved26[5]; 	// 

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+	AT91_REG	 Reserved27[5]; 	// 

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_SYS, *AT91PS_SYS;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+typedef struct _AT91S_AIC {

+	AT91_REG	 AIC_SMR[32]; 	// Source Mode Register

+	AT91_REG	 AIC_SVR[32]; 	// Source Vector Register

+	AT91_REG	 AIC_IVR; 	// IRQ Vector Register

+	AT91_REG	 AIC_FVR; 	// FIQ Vector Register

+	AT91_REG	 AIC_ISR; 	// Interrupt Status Register

+	AT91_REG	 AIC_IPR; 	// Interrupt Pending Register

+	AT91_REG	 AIC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AIC_CISR; 	// Core Interrupt Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AIC_IECR; 	// Interrupt Enable Command Register

+	AT91_REG	 AIC_IDCR; 	// Interrupt Disable Command Register

+	AT91_REG	 AIC_ICCR; 	// Interrupt Clear Command Register

+	AT91_REG	 AIC_ISCR; 	// Interrupt Set Command Register

+	AT91_REG	 AIC_EOICR; 	// End of Interrupt Command Register

+	AT91_REG	 AIC_SPU; 	// Spurious Vector Register

+	AT91_REG	 AIC_DCR; 	// Debug Control Register (Protect)

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 AIC_FFER; 	// Fast Forcing Enable Register

+	AT91_REG	 AIC_FFDR; 	// Fast Forcing Disable Register

+	AT91_REG	 AIC_FFSR; 	// Fast Forcing Status Register

+} AT91S_AIC, *AT91PS_AIC;

+

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR       ((unsigned int) 0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               ((unsigned int) 0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              ((unsigned int) 0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE     ((unsigned int) 0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       ((unsigned int) 0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        ((unsigned int) 0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    ((unsigned int) 0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           ((unsigned int) 0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        ((unsigned int) 0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ        ((unsigned int) 0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ        ((unsigned int) 0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT    ((unsigned int) 0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK    ((unsigned int) 0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+typedef struct _AT91S_PDC {

+	AT91_REG	 PDC_RPR; 	// Receive Pointer Register

+	AT91_REG	 PDC_RCR; 	// Receive Counter Register

+	AT91_REG	 PDC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 PDC_TCR; 	// Transmit Counter Register

+	AT91_REG	 PDC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 PDC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 PDC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 PDC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 PDC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 PDC_PTSR; 	// PDC Transfer Status Register

+} AT91S_PDC, *AT91PS_PDC;

+

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN       ((unsigned int) 0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS      ((unsigned int) 0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN       ((unsigned int) 0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS      ((unsigned int) 0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+typedef struct _AT91S_DBGU {

+	AT91_REG	 DBGU_CR; 	// Control Register

+	AT91_REG	 DBGU_MR; 	// Mode Register

+	AT91_REG	 DBGU_IER; 	// Interrupt Enable Register

+	AT91_REG	 DBGU_IDR; 	// Interrupt Disable Register

+	AT91_REG	 DBGU_IMR; 	// Interrupt Mask Register

+	AT91_REG	 DBGU_CSR; 	// Channel Status Register

+	AT91_REG	 DBGU_RHR; 	// Receiver Holding Register

+	AT91_REG	 DBGU_THR; 	// Transmitter Holding Register

+	AT91_REG	 DBGU_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 Reserved0[7]; 	// 

+	AT91_REG	 DBGU_CIDR; 	// Chip ID Register

+	AT91_REG	 DBGU_EXID; 	// Chip ID Extension Register

+	AT91_REG	 DBGU_FNTR; 	// Force NTRST Register

+	AT91_REG	 Reserved1[45]; 	// 

+	AT91_REG	 DBGU_RPR; 	// Receive Pointer Register

+	AT91_REG	 DBGU_RCR; 	// Receive Counter Register

+	AT91_REG	 DBGU_TPR; 	// Transmit Pointer Register

+	AT91_REG	 DBGU_TCR; 	// Transmit Counter Register

+	AT91_REG	 DBGU_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 DBGU_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 DBGU_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 DBGU_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 DBGU_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 DBGU_PTSR; 	// PDC Transfer Status Register

+} AT91S_DBGU, *AT91PS_DBGU;

+

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX        ((unsigned int) 0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX        ((unsigned int) 0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN         ((unsigned int) 0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS        ((unsigned int) 0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN         ((unsigned int) 0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS        ((unsigned int) 0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA       ((unsigned int) 0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR          ((unsigned int) 0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 ((unsigned int) 0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  ((unsigned int) 0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                ((unsigned int) 0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 ((unsigned int) 0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 ((unsigned int) 0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           ((unsigned int) 0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE       ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY        ((unsigned int) 0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY        ((unsigned int) 0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX        ((unsigned int) 0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX        ((unsigned int) 0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE         ((unsigned int) 0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME        ((unsigned int) 0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE         ((unsigned int) 0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY      ((unsigned int) 0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE       ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF       ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX      ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX      ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST  ((unsigned int) 0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+typedef struct _AT91S_PIO {

+	AT91_REG	 PIO_PER; 	// PIO Enable Register

+	AT91_REG	 PIO_PDR; 	// PIO Disable Register

+	AT91_REG	 PIO_PSR; 	// PIO Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PIO_OER; 	// Output Enable Register

+	AT91_REG	 PIO_ODR; 	// Output Disable Registerr

+	AT91_REG	 PIO_OSR; 	// Output Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PIO_IFER; 	// Input Filter Enable Register

+	AT91_REG	 PIO_IFDR; 	// Input Filter Disable Register

+	AT91_REG	 PIO_IFSR; 	// Input Filter Status Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PIO_SODR; 	// Set Output Data Register

+	AT91_REG	 PIO_CODR; 	// Clear Output Data Register

+	AT91_REG	 PIO_ODSR; 	// Output Data Status Register

+	AT91_REG	 PIO_PDSR; 	// Pin Data Status Register

+	AT91_REG	 PIO_IER; 	// Interrupt Enable Register

+	AT91_REG	 PIO_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PIO_IMR; 	// Interrupt Mask Register

+	AT91_REG	 PIO_ISR; 	// Interrupt Status Register

+	AT91_REG	 PIO_MDER; 	// Multi-driver Enable Register

+	AT91_REG	 PIO_MDDR; 	// Multi-driver Disable Register

+	AT91_REG	 PIO_MDSR; 	// Multi-driver Status Register

+	AT91_REG	 Reserved3[1]; 	// 

+	AT91_REG	 PIO_PPUDR; 	// Pull-up Disable Register

+	AT91_REG	 PIO_PPUER; 	// Pull-up Enable Register

+	AT91_REG	 PIO_PPUSR; 	// Pull-up Status Register

+	AT91_REG	 Reserved4[1]; 	// 

+	AT91_REG	 PIO_ASR; 	// Select A Register

+	AT91_REG	 PIO_BSR; 	// Select B Register

+	AT91_REG	 PIO_ABSR; 	// AB Select Status Register

+	AT91_REG	 Reserved5[9]; 	// 

+	AT91_REG	 PIO_OWER; 	// Output Write Enable Register

+	AT91_REG	 PIO_OWDR; 	// Output Write Disable Register

+	AT91_REG	 PIO_OWSR; 	// Output Write Status Register

+} AT91S_PIO, *AT91PS_PIO;

+

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+typedef struct _AT91S_CKGR {

+	AT91_REG	 CKGR_MOR; 	// Main Oscillator Register

+	AT91_REG	 CKGR_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 CKGR_PLLR; 	// PLL Register

+} AT91S_CKGR, *AT91PS_CKGR;

+

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN     ((unsigned int) 0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS  ((unsigned int) 0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT    ((unsigned int) 0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF      ((unsigned int) 0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY    ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV        ((unsigned int) 0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    ((unsigned int) 0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               ((unsigned int) 0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT   ((unsigned int) 0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT        ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL        ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV     ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+typedef struct _AT91S_PMC {

+	AT91_REG	 PMC_SCER; 	// System Clock Enable Register

+	AT91_REG	 PMC_SCDR; 	// System Clock Disable Register

+	AT91_REG	 PMC_SCSR; 	// System Clock Status Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 PMC_PCER; 	// Peripheral Clock Enable Register

+	AT91_REG	 PMC_PCDR; 	// Peripheral Clock Disable Register

+	AT91_REG	 PMC_PCSR; 	// Peripheral Clock Status Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 PMC_MOR; 	// Main Oscillator Register

+	AT91_REG	 PMC_MCFR; 	// Main Clock  Frequency Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 PMC_PLLR; 	// PLL Register

+	AT91_REG	 PMC_MCKR; 	// Master Clock Register

+	AT91_REG	 Reserved3[3]; 	// 

+	AT91_REG	 PMC_PCKR[4]; 	// Programmable Clock Register

+	AT91_REG	 Reserved4[4]; 	// 

+	AT91_REG	 PMC_IER; 	// Interrupt Enable Register

+	AT91_REG	 PMC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 PMC_SR; 	// Status Register

+	AT91_REG	 PMC_IMR; 	// Interrupt Mask Register

+} AT91S_PMC, *AT91PS_PMC;

+

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK         ((unsigned int) 0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP         ((unsigned int) 0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0        ((unsigned int) 0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1        ((unsigned int) 0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2        ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3        ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS         ((unsigned int) 0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             ((unsigned int) 0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             ((unsigned int) 0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              ((unsigned int) 0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES        ((unsigned int) 0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  ((unsigned int) 0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                ((unsigned int) 0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                ((unsigned int) 0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                ((unsigned int) 0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               ((unsigned int) 0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               ((unsigned int) 0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               ((unsigned int) 0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS       ((unsigned int) 0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK        ((unsigned int) 0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY      ((unsigned int) 0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY     ((unsigned int) 0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY     ((unsigned int) 0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY     ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY     ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RSTC {

+	AT91_REG	 RSTC_RCR; 	// Reset Control Register

+	AT91_REG	 RSTC_RSR; 	// Reset Status Register

+	AT91_REG	 RSTC_RMR; 	// Reset Mode Register

+} AT91S_RSTC, *AT91PS_RSTC;

+

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST    ((unsigned int) 0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST     ((unsigned int) 0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST     ((unsigned int) 0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY        ((unsigned int) 0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS      ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS     ((unsigned int) 0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP     ((unsigned int) 0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              ((unsigned int) 0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               ((unsigned int) 0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             ((unsigned int) 0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             ((unsigned int) 0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 ((unsigned int) 0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             ((unsigned int) 0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL      ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP      ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN     ((unsigned int) 0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN    ((unsigned int) 0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL      ((unsigned int) 0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN     ((unsigned int) 0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_RTTC {

+	AT91_REG	 RTTC_RTMR; 	// Real-time Mode Register

+	AT91_REG	 RTTC_RTAR; 	// Real-time Alarm Register

+	AT91_REG	 RTTC_RTVR; 	// Real-time Value Register

+	AT91_REG	 RTTC_RTSR; 	// Real-time Status Register

+} AT91S_RTTC, *AT91PS_RTTC;

+

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES     ((unsigned int) 0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN     ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN  ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST     ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV       ((unsigned int) 0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV       ((unsigned int) 0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS       ((unsigned int) 0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC     ((unsigned int) 0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PITC {

+	AT91_REG	 PITC_PIMR; 	// Period Interval Mode Register

+	AT91_REG	 PITC_PISR; 	// Period Interval Status Register

+	AT91_REG	 PITC_PIVR; 	// Period Interval Value Register

+	AT91_REG	 PITC_PIIR; 	// Period Interval Image Register

+} AT91S_PITC, *AT91PS_PITC;

+

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV        ((unsigned int) 0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN      ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN     ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS       ((unsigned int) 0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV       ((unsigned int) 0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT      ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_WDTC {

+	AT91_REG	 WDTC_WDCR; 	// Watchdog Control Register

+	AT91_REG	 WDTC_WDMR; 	// Watchdog Mode Register

+	AT91_REG	 WDTC_WDSR; 	// Watchdog Status Register

+} AT91S_WDTC, *AT91PS_WDTC;

+

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT     ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY        ((unsigned int) 0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV        ((unsigned int) 0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN     ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN    ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC    ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS      ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD        ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT   ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT  ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF      ((unsigned int) 0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR      ((unsigned int) 0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_VREG {

+	AT91_REG	 VREG_MR; 	// Voltage Regulator Mode Register

+} AT91S_VREG, *AT91PS_VREG;

+

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY     ((unsigned int) 0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_MC {

+	AT91_REG	 MC_RCR; 	// MC Remap Control Register

+	AT91_REG	 MC_ASR; 	// MC Abort Status Register

+	AT91_REG	 MC_AASR; 	// MC Abort Address Status Register

+	AT91_REG	 Reserved0[21]; 	// 

+	AT91_REG	 MC_FMR; 	// MC Flash Mode Register

+	AT91_REG	 MC_FCR; 	// MC Flash Command Register

+	AT91_REG	 MC_FSR; 	// MC Flash Status Register

+} AT91S_MC, *AT91PS_MC;

+

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB          ((unsigned int) 0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD       ((unsigned int) 0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD       ((unsigned int) 0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ        ((unsigned int) 0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 ((unsigned int) 0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                ((unsigned int) 0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 ((unsigned int) 0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP       ((unsigned int) 0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                ((unsigned int) 0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                ((unsigned int) 0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                ((unsigned int) 0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0         ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1         ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0       ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1       ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY         ((unsigned int) 0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE        ((unsigned int) 0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE        ((unsigned int) 0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP         ((unsigned int) 0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS          ((unsigned int) 0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 ((unsigned int) 0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 ((unsigned int) 0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 ((unsigned int) 0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 ((unsigned int) 0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN         ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD         ((unsigned int) 0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         ((unsigned int) 0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN        ((unsigned int) 0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY          ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY     ((unsigned int) 0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0       ((unsigned int) 0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1       ((unsigned int) 0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2       ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3       ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4       ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5       ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6       ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7       ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0       ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1       ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2       ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3       ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4       ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5       ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6       ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7       ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8       ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9       ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10      ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11      ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12      ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13      ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14      ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15      ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+typedef struct _AT91S_SPI {

+	AT91_REG	 SPI_CR; 	// Control Register

+	AT91_REG	 SPI_MR; 	// Mode Register

+	AT91_REG	 SPI_RDR; 	// Receive Data Register

+	AT91_REG	 SPI_TDR; 	// Transmit Data Register

+	AT91_REG	 SPI_SR; 	// Status Register

+	AT91_REG	 SPI_IER; 	// Interrupt Enable Register

+	AT91_REG	 SPI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SPI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91_REG	 SPI_CSR[4]; 	// Chip Select Register

+	AT91_REG	 Reserved1[48]; 	// 

+	AT91_REG	 SPI_RPR; 	// Receive Pointer Register

+	AT91_REG	 SPI_RCR; 	// Receive Counter Register

+	AT91_REG	 SPI_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SPI_TCR; 	// Transmit Counter Register

+	AT91_REG	 SPI_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SPI_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SPI_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SPI_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SPI_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SPI_PTSR; 	// PDC Transfer Status Register

+} AT91S_SPI, *AT91PS_SPI;

+

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN       ((unsigned int) 0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS      ((unsigned int) 0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST       ((unsigned int) 0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER    ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR        ((unsigned int) 0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS          ((unsigned int) 0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                ((unsigned int) 0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             ((unsigned int) 0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC      ((unsigned int) 0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV        ((unsigned int) 0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS     ((unsigned int) 0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB         ((unsigned int) 0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS         ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD          ((unsigned int) 0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD          ((unsigned int) 0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS        ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF        ((unsigned int) 0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE        ((unsigned int) 0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF        ((unsigned int) 0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES       ((unsigned int) 0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX       ((unsigned int) 0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX       ((unsigned int) 0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF      ((unsigned int) 0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE      ((unsigned int) 0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR        ((unsigned int) 0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY     ((unsigned int) 0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS      ((unsigned int) 0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL        ((unsigned int) 0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA       ((unsigned int) 0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT       ((unsigned int) 0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS        ((unsigned int) 0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    ((unsigned int) 0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    ((unsigned int) 0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   ((unsigned int) 0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   ((unsigned int) 0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   ((unsigned int) 0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   ((unsigned int) 0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   ((unsigned int) 0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   ((unsigned int) 0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   ((unsigned int) 0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR        ((unsigned int) 0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS       ((unsigned int) 0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT      ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+typedef struct _AT91S_USART {

+	AT91_REG	 US_CR; 	// Control Register

+	AT91_REG	 US_MR; 	// Mode Register

+	AT91_REG	 US_IER; 	// Interrupt Enable Register

+	AT91_REG	 US_IDR; 	// Interrupt Disable Register

+	AT91_REG	 US_IMR; 	// Interrupt Mask Register

+	AT91_REG	 US_CSR; 	// Channel Status Register

+	AT91_REG	 US_RHR; 	// Receiver Holding Register

+	AT91_REG	 US_THR; 	// Transmitter Holding Register

+	AT91_REG	 US_BRGR; 	// Baud Rate Generator Register

+	AT91_REG	 US_RTOR; 	// Receiver Time-out Register

+	AT91_REG	 US_TTGR; 	// Transmitter Time-guard Register

+	AT91_REG	 Reserved0[5]; 	// 

+	AT91_REG	 US_FIDI; 	// FI_DI_Ratio Register

+	AT91_REG	 US_NER; 	// Nb Errors Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 US_IF; 	// IRDA_FILTER Register

+	AT91_REG	 Reserved2[44]; 	// 

+	AT91_REG	 US_RPR; 	// Receive Pointer Register

+	AT91_REG	 US_RCR; 	// Receive Counter Register

+	AT91_REG	 US_TPR; 	// Transmit Pointer Register

+	AT91_REG	 US_TCR; 	// Transmit Counter Register

+	AT91_REG	 US_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 US_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 US_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 US_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 US_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 US_PTSR; 	// PDC Transfer Status Register

+} AT91S_USART, *AT91PS_USART;

+

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK       ((unsigned int) 0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK       ((unsigned int) 0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO        ((unsigned int) 0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA        ((unsigned int) 0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT        ((unsigned int) 0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK      ((unsigned int) 0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO        ((unsigned int) 0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN        ((unsigned int) 0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS       ((unsigned int) 0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN        ((unsigned int) 0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS       ((unsigned int) 0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE       ((unsigned int) 0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               ((unsigned int) 0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                ((unsigned int) 0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                ((unsigned int) 0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                ((unsigned int) 0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            ((unsigned int) 0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            ((unsigned int) 0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 ((unsigned int) 0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                ((unsigned int) 0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS         ((unsigned int) 0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                ((unsigned int) 0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                ((unsigned int) 0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 ((unsigned int) 0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  ((unsigned int) 0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL         ((unsigned int) 0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               ((unsigned int) 0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               ((unsigned int) 0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               ((unsigned int) 0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               ((unsigned int) 0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC         ((unsigned int) 0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP       ((unsigned int) 0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                ((unsigned int) 0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               ((unsigned int) 0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                ((unsigned int) 0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF         ((unsigned int) 0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9        ((unsigned int) 0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO         ((unsigned int) 0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER         ((unsigned int) 0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK        ((unsigned int) 0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK       ((unsigned int) 0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER     ((unsigned int) 0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER       ((unsigned int) 0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK        ((unsigned int) 0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT      ((unsigned int) 0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION    ((unsigned int) 0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK         ((unsigned int) 0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC         ((unsigned int) 0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC        ((unsigned int) 0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC        ((unsigned int) 0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC        ((unsigned int) 0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI           ((unsigned int) 0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR          ((unsigned int) 0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD          ((unsigned int) 0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS          ((unsigned int) 0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_SSC {

+	AT91_REG	 SSC_CR; 	// Control Register

+	AT91_REG	 SSC_CMR; 	// Clock Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 SSC_RCMR; 	// Receive Clock ModeRegister

+	AT91_REG	 SSC_RFMR; 	// Receive Frame Mode Register

+	AT91_REG	 SSC_TCMR; 	// Transmit Clock Mode Register

+	AT91_REG	 SSC_TFMR; 	// Transmit Frame Mode Register

+	AT91_REG	 SSC_RHR; 	// Receive Holding Register

+	AT91_REG	 SSC_THR; 	// Transmit Holding Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 SSC_RSHR; 	// Receive Sync Holding Register

+	AT91_REG	 SSC_TSHR; 	// Transmit Sync Holding Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 SSC_SR; 	// Status Register

+	AT91_REG	 SSC_IER; 	// Interrupt Enable Register

+	AT91_REG	 SSC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 SSC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 Reserved3[44]; 	// 

+	AT91_REG	 SSC_RPR; 	// Receive Pointer Register

+	AT91_REG	 SSC_RCR; 	// Receive Counter Register

+	AT91_REG	 SSC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 SSC_TCR; 	// Transmit Counter Register

+	AT91_REG	 SSC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 SSC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 SSC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 SSC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 SSC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 SSC_PTSR; 	// PDC Transfer Status Register

+} AT91S_SSC, *AT91PS_SSC;

+

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN        ((unsigned int) 0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS       ((unsigned int) 0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN        ((unsigned int) 0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS       ((unsigned int) 0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST       ((unsigned int) 0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS         ((unsigned int) 0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  ((unsigned int) 0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   ((unsigned int) 0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   ((unsigned int) 0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO         ((unsigned int) 0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 ((unsigned int) 0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            ((unsigned int) 0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              ((unsigned int) 0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI         ((unsigned int) 0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START       ((unsigned int) 0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            ((unsigned int) 0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   ((unsigned int) 0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               ((unsigned int) 0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              ((unsigned int) 0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              ((unsigned int) 0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              ((unsigned int) 0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             ((unsigned int) 0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              ((unsigned int) 0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    ((unsigned int) 0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY      ((unsigned int) 0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD      ((unsigned int) 0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN      ((unsigned int) 0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP        ((unsigned int) 0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF        ((unsigned int) 0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB       ((unsigned int) 0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN       ((unsigned int) 0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS        ((unsigned int) 0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 ((unsigned int) 0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             ((unsigned int) 0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             ((unsigned int) 0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  ((unsigned int) 0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 ((unsigned int) 0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               ((unsigned int) 0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE      ((unsigned int) 0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF      ((unsigned int) 0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN       ((unsigned int) 0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY       ((unsigned int) 0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY     ((unsigned int) 0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX       ((unsigned int) 0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE      ((unsigned int) 0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY       ((unsigned int) 0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN       ((unsigned int) 0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX       ((unsigned int) 0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF      ((unsigned int) 0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN       ((unsigned int) 0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN       ((unsigned int) 0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA       ((unsigned int) 0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA       ((unsigned int) 0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+typedef struct _AT91S_TWI {

+	AT91_REG	 TWI_CR; 	// Control Register

+	AT91_REG	 TWI_MMR; 	// Master Mode Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 TWI_IADR; 	// Internal Address Register

+	AT91_REG	 TWI_CWGR; 	// Clock Waveform Generator Register

+	AT91_REG	 Reserved1[3]; 	// 

+	AT91_REG	 TWI_SR; 	// Status Register

+	AT91_REG	 TWI_IER; 	// Interrupt Enable Register

+	AT91_REG	 TWI_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TWI_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TWI_RHR; 	// Receive Holding Register

+	AT91_REG	 TWI_THR; 	// Transmit Holding Register

+} AT91S_TWI, *AT91PS_TWI;

+

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START       ((unsigned int) 0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP        ((unsigned int) 0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN        ((unsigned int) 0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS       ((unsigned int) 0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST       ((unsigned int) 0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ      ((unsigned int) 0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   ((unsigned int) 0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               ((unsigned int) 0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               ((unsigned int) 0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               ((unsigned int) 0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD       ((unsigned int) 0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR        ((unsigned int) 0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV       ((unsigned int) 0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV       ((unsigned int) 0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV       ((unsigned int) 0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP      ((unsigned int) 0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY       ((unsigned int) 0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY       ((unsigned int) 0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE        ((unsigned int) 0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE        ((unsigned int) 0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK        ((unsigned int) 0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC_CH {

+	AT91_REG	 PWMC_CMR; 	// Channel Mode Register

+	AT91_REG	 PWMC_CDTYR; 	// Channel Duty Cycle Register

+	AT91_REG	 PWMC_CPRDR; 	// Channel Period Register

+	AT91_REG	 PWMC_CCNTR; 	// Channel Counter Register

+	AT91_REG	 PWMC_CUPDR; 	// Channel Update Register

+	AT91_REG	 PWMC_Reserved[3]; 	// Reserved

+} AT91S_PWMC_CH, *AT91PS_PWMC_CH;

+

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE       ((unsigned int) 0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  ((unsigned int) 0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 ((unsigned int) 0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 ((unsigned int) 0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG       ((unsigned int) 0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL       ((unsigned int) 0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD        ((unsigned int) 0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD       ((unsigned int) 0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+typedef struct _AT91S_PWMC {

+	AT91_REG	 PWMC_MR; 	// PWMC Mode Register

+	AT91_REG	 PWMC_ENA; 	// PWMC Enable Register

+	AT91_REG	 PWMC_DIS; 	// PWMC Disable Register

+	AT91_REG	 PWMC_SR; 	// PWMC Status Register

+	AT91_REG	 PWMC_IER; 	// PWMC Interrupt Enable Register

+	AT91_REG	 PWMC_IDR; 	// PWMC Interrupt Disable Register

+	AT91_REG	 PWMC_IMR; 	// PWMC Interrupt Mask Register

+	AT91_REG	 PWMC_ISR; 	// PWMC Interrupt Status Register

+	AT91_REG	 Reserved0[55]; 	// 

+	AT91_REG	 PWMC_VR; 	// PWMC Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_PWMC_CH	 PWMC_CH[4]; 	// PWMC Channel

+} AT91S_PWMC, *AT91PS_PWMC;

+

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA       ((unsigned int) 0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA       ((unsigned int) 0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  ((unsigned int) 0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB       ((unsigned int) 0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB       ((unsigned int) 0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  ((unsigned int) 0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0      ((unsigned int) 0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1      ((unsigned int) 0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2      ((unsigned int) 0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3      ((unsigned int) 0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+typedef struct _AT91S_UDP {

+	AT91_REG	 UDP_NUM; 	// Frame Number Register

+	AT91_REG	 UDP_GLBSTATE; 	// Global State Register

+	AT91_REG	 UDP_FADDR; 	// Function Address Register

+	AT91_REG	 Reserved0[1]; 	// 

+	AT91_REG	 UDP_IER; 	// Interrupt Enable Register

+	AT91_REG	 UDP_IDR; 	// Interrupt Disable Register

+	AT91_REG	 UDP_IMR; 	// Interrupt Mask Register

+	AT91_REG	 UDP_ISR; 	// Interrupt Status Register

+	AT91_REG	 UDP_ICR; 	// Interrupt Clear Register

+	AT91_REG	 Reserved1[1]; 	// 

+	AT91_REG	 UDP_RSTEP; 	// Reset Endpoint Register

+	AT91_REG	 Reserved2[1]; 	// 

+	AT91_REG	 UDP_CSR[6]; 	// Endpoint Control and Status Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 UDP_FDR[6]; 	// Endpoint FIFO Data Register

+	AT91_REG	 Reserved4[3]; 	// 

+	AT91_REG	 UDP_TXVC; 	// Transceiver Control Register

+} AT91S_UDP, *AT91PS_UDP;

+

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM     ((unsigned int) 0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR     ((unsigned int) 0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK      ((unsigned int) 0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN      ((unsigned int) 0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG       ((unsigned int) 0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR         ((unsigned int) 0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR     ((unsigned int) 0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE      ((unsigned int) 0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD        ((unsigned int) 0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN         ((unsigned int) 0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0      ((unsigned int) 0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1      ((unsigned int) 0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2      ((unsigned int) 0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3      ((unsigned int) 0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4      ((unsigned int) 0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5      ((unsigned int) 0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP      ((unsigned int) 0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM       ((unsigned int) 0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM      ((unsigned int) 0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT      ((unsigned int) 0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP      ((unsigned int) 0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES   ((unsigned int) 0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0         ((unsigned int) 0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1         ((unsigned int) 0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2         ((unsigned int) 0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3         ((unsigned int) 0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4         ((unsigned int) 0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5         ((unsigned int) 0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP      ((unsigned int) 0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0 ((unsigned int) 0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP     ((unsigned int) 0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR    ((unsigned int) 0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY    ((unsigned int) 0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL  ((unsigned int) 0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1 ((unsigned int) 0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR         ((unsigned int) 0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE      ((unsigned int) 0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 ((unsigned int) 0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              ((unsigned int) 0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             ((unsigned int) 0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              ((unsigned int) 0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               ((unsigned int) 0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              ((unsigned int) 0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               ((unsigned int) 0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE       ((unsigned int) 0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS       ((unsigned int) 0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT   ((unsigned int) 0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS      ((unsigned int) 0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON        ((unsigned int) 0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+typedef struct _AT91S_TC {

+	AT91_REG	 TC_CCR; 	// Channel Control Register

+	AT91_REG	 TC_CMR; 	// Channel Mode Register (Capture Mode / Waveform Mode)

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TC_CV; 	// Counter Value

+	AT91_REG	 TC_RA; 	// Register A

+	AT91_REG	 TC_RB; 	// Register B

+	AT91_REG	 TC_RC; 	// Register C

+	AT91_REG	 TC_SR; 	// Status Register

+	AT91_REG	 TC_IER; 	// Interrupt Enable Register

+	AT91_REG	 TC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TC_IMR; 	// Interrupt Mask Register

+} AT91S_TC, *AT91PS_TC;

+

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN        ((unsigned int) 0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS       ((unsigned int) 0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG        ((unsigned int) 0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS         ((unsigned int) 0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     ((unsigned int) 0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     ((unsigned int) 0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     ((unsigned int) 0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     ((unsigned int) 0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     ((unsigned int) 0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  ((unsigned int) 0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  ((unsigned int) 0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  ((unsigned int) 0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI         ((unsigned int) 0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST        ((unsigned int) 0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 ((unsigned int) 0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  ((unsigned int) 0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  ((unsigned int) 0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  ((unsigned int) 0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP      ((unsigned int) 0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS       ((unsigned int) 0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG      ((unsigned int) 0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG      ((unsigned int) 0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 ((unsigned int) 0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               ((unsigned int) 0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              ((unsigned int) 0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 ((unsigned int) 0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT         ((unsigned int) 0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 ((unsigned int) 0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  ((unsigned int) 0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  ((unsigned int) 0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  ((unsigned int) 0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG       ((unsigned int) 0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG       ((unsigned int) 0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL      ((unsigned int) 0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   ((unsigned int) 0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               ((unsigned int) 0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              ((unsigned int) 0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          ((unsigned int) 0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG       ((unsigned int) 0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE         ((unsigned int) 0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA         ((unsigned int) 0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  ((unsigned int) 0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                ((unsigned int) 0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               ((unsigned int) 0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA         ((unsigned int) 0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 ((unsigned int) 0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               ((unsigned int) 0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              ((unsigned int) 0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 ((unsigned int) 0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC         ((unsigned int) 0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 ((unsigned int) 0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  ((unsigned int) 0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                ((unsigned int) 0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               ((unsigned int) 0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB         ((unsigned int) 0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 ((unsigned int) 0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               ((unsigned int) 0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              ((unsigned int) 0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 ((unsigned int) 0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT        ((unsigned int) 0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 ((unsigned int) 0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  ((unsigned int) 0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                ((unsigned int) 0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               ((unsigned int) 0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG       ((unsigned int) 0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 ((unsigned int) 0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  ((unsigned int) 0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                ((unsigned int) 0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               ((unsigned int) 0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB         ((unsigned int) 0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 ((unsigned int) 0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  ((unsigned int) 0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                ((unsigned int) 0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               ((unsigned int) 0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC         ((unsigned int) 0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 ((unsigned int) 0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  ((unsigned int) 0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                ((unsigned int) 0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               ((unsigned int) 0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT        ((unsigned int) 0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 ((unsigned int) 0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  ((unsigned int) 0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                ((unsigned int) 0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               ((unsigned int) 0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG       ((unsigned int) 0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 ((unsigned int) 0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  ((unsigned int) 0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                ((unsigned int) 0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               ((unsigned int) 0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS        ((unsigned int) 0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS        ((unsigned int) 0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS         ((unsigned int) 0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS         ((unsigned int) 0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS         ((unsigned int) 0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS        ((unsigned int) 0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS        ((unsigned int) 0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS        ((unsigned int) 0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA       ((unsigned int) 0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA        ((unsigned int) 0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB        ((unsigned int) 0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+typedef struct _AT91S_TCB {

+	AT91S_TC	 TCB_TC0; 	// TC Channel 0

+	AT91_REG	 Reserved0[4]; 	// 

+	AT91S_TC	 TCB_TC1; 	// TC Channel 1

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91S_TC	 TCB_TC2; 	// TC Channel 2

+	AT91_REG	 Reserved2[4]; 	// 

+	AT91_REG	 TCB_BCR; 	// TC Block Control Register

+	AT91_REG	 TCB_BMR; 	// TC Block Mode Register

+} AT91S_TCB, *AT91PS_TCB;

+

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC        ((unsigned int) 0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S     ((unsigned int) 0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                ((unsigned int) 0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 ((unsigned int) 0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                ((unsigned int) 0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                ((unsigned int) 0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S     ((unsigned int) 0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                ((unsigned int) 0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 ((unsigned int) 0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                ((unsigned int) 0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                ((unsigned int) 0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S     ((unsigned int) 0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                ((unsigned int) 0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 ((unsigned int) 0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                ((unsigned int) 0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                ((unsigned int) 0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN_MB {

+	AT91_REG	 CAN_MB_MMR; 	// MailBox Mode Register

+	AT91_REG	 CAN_MB_MAM; 	// MailBox Acceptance Mask Register

+	AT91_REG	 CAN_MB_MID; 	// MailBox ID Register

+	AT91_REG	 CAN_MB_MFID; 	// MailBox Family ID Register

+	AT91_REG	 CAN_MB_MSR; 	// MailBox Status Register

+	AT91_REG	 CAN_MB_MDL; 	// MailBox Data Low Register

+	AT91_REG	 CAN_MB_MDH; 	// MailBox Data High Register

+	AT91_REG	 CAN_MB_MCR; 	// MailBox Control Register

+} AT91S_CAN_MB, *AT91PS_CAN_MB;

+

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK   ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR       ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT         ((unsigned int) 0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  ((unsigned int) 0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   ((unsigned int) 0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          ((unsigned int) 0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   ((unsigned int) 0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             ((unsigned int) 0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             ((unsigned int) 0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB       ((unsigned int) 0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA       ((unsigned int) 0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE        ((unsigned int) 0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP  ((unsigned int) 0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC        ((unsigned int) 0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR        ((unsigned int) 0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT        ((unsigned int) 0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI         ((unsigned int) 0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR        ((unsigned int) 0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR        ((unsigned int) 0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+typedef struct _AT91S_CAN {

+	AT91_REG	 CAN_MR; 	// Mode Register

+	AT91_REG	 CAN_IER; 	// Interrupt Enable Register

+	AT91_REG	 CAN_IDR; 	// Interrupt Disable Register

+	AT91_REG	 CAN_IMR; 	// Interrupt Mask Register

+	AT91_REG	 CAN_SR; 	// Status Register

+	AT91_REG	 CAN_BR; 	// Baudrate Register

+	AT91_REG	 CAN_TIM; 	// Timer Register

+	AT91_REG	 CAN_TIMESTP; 	// Time Stamp Register

+	AT91_REG	 CAN_ECR; 	// Error Counter Register

+	AT91_REG	 CAN_TCR; 	// Transfer Command Register

+	AT91_REG	 CAN_ACR; 	// Abort Command Register

+	AT91_REG	 Reserved0[52]; 	// 

+	AT91_REG	 CAN_VR; 	// Version Register

+	AT91_REG	 Reserved1[64]; 	// 

+	AT91S_CAN_MB	 CAN_MB0; 	// CAN Mailbox 0

+	AT91S_CAN_MB	 CAN_MB1; 	// CAN Mailbox 1

+	AT91S_CAN_MB	 CAN_MB2; 	// CAN Mailbox 2

+	AT91S_CAN_MB	 CAN_MB3; 	// CAN Mailbox 3

+	AT91S_CAN_MB	 CAN_MB4; 	// CAN Mailbox 4

+	AT91S_CAN_MB	 CAN_MB5; 	// CAN Mailbox 5

+	AT91S_CAN_MB	 CAN_MB6; 	// CAN Mailbox 6

+	AT91S_CAN_MB	 CAN_MB7; 	// CAN Mailbox 7

+	AT91S_CAN_MB	 CAN_MB8; 	// CAN Mailbox 8

+	AT91S_CAN_MB	 CAN_MB9; 	// CAN Mailbox 9

+	AT91S_CAN_MB	 CAN_MB10; 	// CAN Mailbox 10

+	AT91S_CAN_MB	 CAN_MB11; 	// CAN Mailbox 11

+	AT91S_CAN_MB	 CAN_MB12; 	// CAN Mailbox 12

+	AT91S_CAN_MB	 CAN_MB13; 	// CAN Mailbox 13

+	AT91S_CAN_MB	 CAN_MB14; 	// CAN Mailbox 14

+	AT91S_CAN_MB	 CAN_MB15; 	// CAN Mailbox 15

+} AT91S_CAN, *AT91PS_CAN;

+

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN       ((unsigned int) 0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM         ((unsigned int) 0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM         ((unsigned int) 0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL         ((unsigned int) 0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF        ((unsigned int) 0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM         ((unsigned int) 0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ      ((unsigned int) 0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT        ((unsigned int) 0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0         ((unsigned int) 0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1         ((unsigned int) 0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2         ((unsigned int) 0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3         ((unsigned int) 0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4         ((unsigned int) 0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5         ((unsigned int) 0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6         ((unsigned int) 0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7         ((unsigned int) 0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8         ((unsigned int) 0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9         ((unsigned int) 0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10        ((unsigned int) 0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11        ((unsigned int) 0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12        ((unsigned int) 0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13        ((unsigned int) 0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14        ((unsigned int) 0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15        ((unsigned int) 0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA        ((unsigned int) 0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN        ((unsigned int) 0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP        ((unsigned int) 0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF        ((unsigned int) 0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP       ((unsigned int) 0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP      ((unsigned int) 0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF        ((unsigned int) 0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP        ((unsigned int) 0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR        ((unsigned int) 0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR        ((unsigned int) 0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR        ((unsigned int) 0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR        ((unsigned int) 0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR        ((unsigned int) 0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY        ((unsigned int) 0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY        ((unsigned int) 0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY        ((unsigned int) 0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2      ((unsigned int) 0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1      ((unsigned int) 0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG      ((unsigned int) 0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC        ((unsigned int) 0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP         ((unsigned int) 0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP         ((unsigned int) 0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER       ((unsigned int) 0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC         ((unsigned int) 0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC         ((unsigned int) 0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST      ((unsigned int) 0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+typedef struct _AT91S_EMAC {

+	AT91_REG	 EMAC_NCR; 	// Network Control Register

+	AT91_REG	 EMAC_NCFGR; 	// Network Configuration Register

+	AT91_REG	 EMAC_NSR; 	// Network Status Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 EMAC_TSR; 	// Transmit Status Register

+	AT91_REG	 EMAC_RBQP; 	// Receive Buffer Queue Pointer

+	AT91_REG	 EMAC_TBQP; 	// Transmit Buffer Queue Pointer

+	AT91_REG	 EMAC_RSR; 	// Receive Status Register

+	AT91_REG	 EMAC_ISR; 	// Interrupt Status Register

+	AT91_REG	 EMAC_IER; 	// Interrupt Enable Register

+	AT91_REG	 EMAC_IDR; 	// Interrupt Disable Register

+	AT91_REG	 EMAC_IMR; 	// Interrupt Mask Register

+	AT91_REG	 EMAC_MAN; 	// PHY Maintenance Register

+	AT91_REG	 EMAC_PTR; 	// Pause Time Register

+	AT91_REG	 EMAC_PFR; 	// Pause Frames received Register

+	AT91_REG	 EMAC_FTO; 	// Frames Transmitted OK Register

+	AT91_REG	 EMAC_SCF; 	// Single Collision Frame Register

+	AT91_REG	 EMAC_MCF; 	// Multiple Collision Frame Register

+	AT91_REG	 EMAC_FRO; 	// Frames Received OK Register

+	AT91_REG	 EMAC_FCSE; 	// Frame Check Sequence Error Register

+	AT91_REG	 EMAC_ALE; 	// Alignment Error Register

+	AT91_REG	 EMAC_DTF; 	// Deferred Transmission Frame Register

+	AT91_REG	 EMAC_LCOL; 	// Late Collision Register

+	AT91_REG	 EMAC_ECOL; 	// Excessive Collision Register

+	AT91_REG	 EMAC_TUND; 	// Transmit Underrun Error Register

+	AT91_REG	 EMAC_CSE; 	// Carrier Sense Error Register

+	AT91_REG	 EMAC_RRE; 	// Receive Ressource Error Register

+	AT91_REG	 EMAC_ROV; 	// Receive Overrun Errors Register

+	AT91_REG	 EMAC_RSE; 	// Receive Symbol Errors Register

+	AT91_REG	 EMAC_ELE; 	// Excessive Length Errors Register

+	AT91_REG	 EMAC_RJA; 	// Receive Jabbers Register

+	AT91_REG	 EMAC_USF; 	// Undersize Frames Register

+	AT91_REG	 EMAC_STE; 	// SQE Test Error Register

+	AT91_REG	 EMAC_RLE; 	// Receive Length Field Mismatch Register

+	AT91_REG	 EMAC_TPF; 	// Transmitted Pause Frames Register

+	AT91_REG	 EMAC_HRB; 	// Hash Address Bottom[31:0]

+	AT91_REG	 EMAC_HRT; 	// Hash Address Top[63:32]

+	AT91_REG	 EMAC_SA1L; 	// Specific Address 1 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA1H; 	// Specific Address 1 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA2L; 	// Specific Address 2 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA2H; 	// Specific Address 2 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA3L; 	// Specific Address 3 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA3H; 	// Specific Address 3 Top, Last 2 bytes

+	AT91_REG	 EMAC_SA4L; 	// Specific Address 4 Bottom, First 4 bytes

+	AT91_REG	 EMAC_SA4H; 	// Specific Address 4 Top, Last 2 bytes

+	AT91_REG	 EMAC_TID; 	// Type ID Checking Register

+	AT91_REG	 EMAC_TPQ; 	// Transmit Pause Quantum Register

+	AT91_REG	 EMAC_USRIO; 	// USER Input/Output Register

+	AT91_REG	 EMAC_WOL; 	// Wake On LAN Register

+	AT91_REG	 Reserved1[13]; 	// 

+	AT91_REG	 EMAC_REV; 	// Revision Register

+} AT91S_EMAC, *AT91PS_EMAC;

+

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB         ((unsigned int) 0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB        ((unsigned int) 0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE         ((unsigned int) 0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE         ((unsigned int) 0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE        ((unsigned int) 0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT    ((unsigned int) 0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT    ((unsigned int) 0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT     ((unsigned int) 0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP         ((unsigned int) 0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART     ((unsigned int) 0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT      ((unsigned int) 0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR       ((unsigned int) 0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ        ((unsigned int) 0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD        ((unsigned int) 0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD         ((unsigned int) 0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME     ((unsigned int) 0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF        ((unsigned int) 0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC        ((unsigned int) 0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI        ((unsigned int) 0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI        ((unsigned int) 0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG        ((unsigned int) 0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE        ((unsigned int) 0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK        ((unsigned int) 0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               ((unsigned int) 0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              ((unsigned int) 0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              ((unsigned int) 0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              ((unsigned int) 0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY        ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE        ((unsigned int) 0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF       ((unsigned int) 0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             ((unsigned int) 0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             ((unsigned int) 0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             ((unsigned int) 0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             ((unsigned int) 0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE       ((unsigned int) 0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS      ((unsigned int) 0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD      ((unsigned int) 0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS     ((unsigned int) 0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR      ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO       ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE       ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES       ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO        ((unsigned int) 0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX        ((unsigned int) 0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND        ((unsigned int) 0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC        ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR        ((unsigned int) 0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD        ((unsigned int) 0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP      ((unsigned int) 0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR      ((unsigned int) 0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR      ((unsigned int) 0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR      ((unsigned int) 0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX       ((unsigned int) 0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR      ((unsigned int) 0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP      ((unsigned int) 0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK       ((unsigned int) 0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR       ((unsigned int) 0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP      ((unsigned int) 0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE       ((unsigned int) 0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ        ((unsigned int) 0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA       ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE       ((unsigned int) 0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA       ((unsigned int) 0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA       ((unsigned int) 0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW         ((unsigned int) 0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF        ((unsigned int) 0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII       ((unsigned int) 0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP         ((unsigned int) 0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG        ((unsigned int) 0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP        ((unsigned int) 0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1        ((unsigned int) 0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF     ((unsigned int) 0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF    ((unsigned int) 0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+typedef struct _AT91S_ADC {

+	AT91_REG	 ADC_CR; 	// ADC Control Register

+	AT91_REG	 ADC_MR; 	// ADC Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 ADC_CHER; 	// ADC Channel Enable Register

+	AT91_REG	 ADC_CHDR; 	// ADC Channel Disable Register

+	AT91_REG	 ADC_CHSR; 	// ADC Channel Status Register

+	AT91_REG	 ADC_SR; 	// ADC Status Register

+	AT91_REG	 ADC_LCDR; 	// ADC Last Converted Data Register

+	AT91_REG	 ADC_IER; 	// ADC Interrupt Enable Register

+	AT91_REG	 ADC_IDR; 	// ADC Interrupt Disable Register

+	AT91_REG	 ADC_IMR; 	// ADC Interrupt Mask Register

+	AT91_REG	 ADC_CDR0; 	// ADC Channel Data Register 0

+	AT91_REG	 ADC_CDR1; 	// ADC Channel Data Register 1

+	AT91_REG	 ADC_CDR2; 	// ADC Channel Data Register 2

+	AT91_REG	 ADC_CDR3; 	// ADC Channel Data Register 3

+	AT91_REG	 ADC_CDR4; 	// ADC Channel Data Register 4

+	AT91_REG	 ADC_CDR5; 	// ADC Channel Data Register 5

+	AT91_REG	 ADC_CDR6; 	// ADC Channel Data Register 6

+	AT91_REG	 ADC_CDR7; 	// ADC Channel Data Register 7

+	AT91_REG	 Reserved1[44]; 	// 

+	AT91_REG	 ADC_RPR; 	// Receive Pointer Register

+	AT91_REG	 ADC_RCR; 	// Receive Counter Register

+	AT91_REG	 ADC_TPR; 	// Transmit Pointer Register

+	AT91_REG	 ADC_TCR; 	// Transmit Counter Register

+	AT91_REG	 ADC_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 ADC_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 ADC_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 ADC_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 ADC_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 ADC_PTSR; 	// PDC Transfer Status Register

+} AT91S_ADC, *AT91PS_ADC;

+

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST       ((unsigned int) 0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START       ((unsigned int) 0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN       ((unsigned int) 0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  ((unsigned int) 0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   ((unsigned int) 0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL      ((unsigned int) 0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                ((unsigned int) 0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                ((unsigned int) 0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                ((unsigned int) 0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                ((unsigned int) 0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                ((unsigned int) 0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                ((unsigned int) 0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  ((unsigned int) 0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES      ((unsigned int) 0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               ((unsigned int) 0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                ((unsigned int) 0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP       ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          ((unsigned int) 0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 ((unsigned int) 0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL     ((unsigned int) 0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP     ((unsigned int) 0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM       ((unsigned int) 0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0         ((unsigned int) 0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1         ((unsigned int) 0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2         ((unsigned int) 0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3         ((unsigned int) 0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4         ((unsigned int) 0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5         ((unsigned int) 0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6         ((unsigned int) 0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7         ((unsigned int) 0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0        ((unsigned int) 0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1        ((unsigned int) 0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2        ((unsigned int) 0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3        ((unsigned int) 0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4        ((unsigned int) 0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5        ((unsigned int) 0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6        ((unsigned int) 0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7        ((unsigned int) 0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0       ((unsigned int) 0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1       ((unsigned int) 0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2       ((unsigned int) 0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3       ((unsigned int) 0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4       ((unsigned int) 0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5       ((unsigned int) 0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6       ((unsigned int) 0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7       ((unsigned int) 0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY        ((unsigned int) 0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE       ((unsigned int) 0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX       ((unsigned int) 0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF      ((unsigned int) 0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA       ((unsigned int) 0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA        ((unsigned int) 0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_AES {

+	AT91_REG	 AES_CR; 	// Control Register

+	AT91_REG	 AES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 AES_IER; 	// Interrupt Enable Register

+	AT91_REG	 AES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 AES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 AES_ISR; 	// Interrupt Status Register

+	AT91_REG	 AES_KEYWxR[4]; 	// Key Word x Register

+	AT91_REG	 Reserved1[4]; 	// 

+	AT91_REG	 AES_IDATAxR[4]; 	// Input Data x Register

+	AT91_REG	 AES_ODATAxR[4]; 	// Output Data x Register

+	AT91_REG	 AES_IVxR[4]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved2[35]; 	// 

+	AT91_REG	 AES_VR; 	// AES Version Register

+	AT91_REG	 AES_RPR; 	// Receive Pointer Register

+	AT91_REG	 AES_RCR; 	// Receive Counter Register

+	AT91_REG	 AES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 AES_TCR; 	// Transmit Counter Register

+	AT91_REG	 AES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 AES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 AES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 AES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 AES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 AES_PTSR; 	// PDC Transfer Status Register

+} AT91S_AES, *AT91PS_AES;

+

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START       ((unsigned int) 0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST       ((unsigned int) 0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED    ((unsigned int) 0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER      ((unsigned int) 0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY     ((unsigned int) 0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD        ((unsigned int) 0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD       ((unsigned int) 0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  ((unsigned int) 0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD         ((unsigned int) 0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS        ((unsigned int) 0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              ((unsigned int) 0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               ((unsigned int) 0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               ((unsigned int) 0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               ((unsigned int) 0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                ((unsigned int) 0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY        ((unsigned int) 0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE       ((unsigned int) 0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             ((unsigned int) 0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             ((unsigned int) 0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             ((unsigned int) 0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             ((unsigned int) 0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             ((unsigned int) 0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY      ((unsigned int) 0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX       ((unsigned int) 0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX       ((unsigned int) 0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF      ((unsigned int) 0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE      ((unsigned int) 0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD        ((unsigned int) 0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT        ((unsigned int) 0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  ((unsigned int) 0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY ((unsigned int) 0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          ((unsigned int) 0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+typedef struct _AT91S_TDES {

+	AT91_REG	 TDES_CR; 	// Control Register

+	AT91_REG	 TDES_MR; 	// Mode Register

+	AT91_REG	 Reserved0[2]; 	// 

+	AT91_REG	 TDES_IER; 	// Interrupt Enable Register

+	AT91_REG	 TDES_IDR; 	// Interrupt Disable Register

+	AT91_REG	 TDES_IMR; 	// Interrupt Mask Register

+	AT91_REG	 TDES_ISR; 	// Interrupt Status Register

+	AT91_REG	 TDES_KEY1WxR[2]; 	// Key 1 Word x Register

+	AT91_REG	 TDES_KEY2WxR[2]; 	// Key 2 Word x Register

+	AT91_REG	 TDES_KEY3WxR[2]; 	// Key 3 Word x Register

+	AT91_REG	 Reserved1[2]; 	// 

+	AT91_REG	 TDES_IDATAxR[2]; 	// Input Data x Register

+	AT91_REG	 Reserved2[2]; 	// 

+	AT91_REG	 TDES_ODATAxR[2]; 	// Output Data x Register

+	AT91_REG	 Reserved3[2]; 	// 

+	AT91_REG	 TDES_IVxR[2]; 	// Initialization Vector x Register

+	AT91_REG	 Reserved4[37]; 	// 

+	AT91_REG	 TDES_VR; 	// TDES Version Register

+	AT91_REG	 TDES_RPR; 	// Receive Pointer Register

+	AT91_REG	 TDES_RCR; 	// Receive Counter Register

+	AT91_REG	 TDES_TPR; 	// Transmit Pointer Register

+	AT91_REG	 TDES_TCR; 	// Transmit Counter Register

+	AT91_REG	 TDES_RNPR; 	// Receive Next Pointer Register

+	AT91_REG	 TDES_RNCR; 	// Receive Next Counter Register

+	AT91_REG	 TDES_TNPR; 	// Transmit Next Pointer Register

+	AT91_REG	 TDES_TNCR; 	// Transmit Next Counter Register

+	AT91_REG	 TDES_PTCR; 	// PDC Transfer Control Register

+	AT91_REG	 TDES_PTSR; 	// PDC Transfer Status Register

+} AT91S_TDES, *AT91PS_TDES;

+

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START      ((unsigned int) 0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST      ((unsigned int) 0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER     ((unsigned int) 0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD    ((unsigned int) 0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD     ((unsigned int) 0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD       ((unsigned int) 0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               ((unsigned int) 0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 ((unsigned int) 0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  ((unsigned int) 0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD      ((unsigned int) 0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  ((unsigned int) 0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  ((unsigned int) 0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  ((unsigned int) 0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  ((unsigned int) 0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD        ((unsigned int) 0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS       ((unsigned int) 0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               ((unsigned int) 0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               ((unsigned int) 0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               ((unsigned int) 0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                ((unsigned int) 0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY     ((unsigned int) 0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX      ((unsigned int) 0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX      ((unsigned int) 0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF     ((unsigned int) 0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE     ((unsigned int) 0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD       ((unsigned int) 0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT       ((unsigned int) 0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC ((unsigned int) 0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC ((unsigned int) 0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC ((unsigned int) 0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          ((unsigned int) 0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X256

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR   ((AT91_REG *) 	0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR   ((AT91_REG *) 	0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR   ((AT91_REG *) 	0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR   ((AT91_REG *) 	0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR ((AT91_REG *) 	0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR   ((AT91_REG *) 	0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR  ((AT91_REG *) 	0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR  ((AT91_REG *) 	0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR   ((AT91_REG *) 	0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR   ((AT91_REG *) 	0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR   ((AT91_REG *) 	0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER  ((AT91_REG *) 	0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR  ((AT91_REG *) 	0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR  ((AT91_REG *) 	0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR  ((AT91_REG *) 	0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR  ((AT91_REG *) 	0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR  ((AT91_REG *) 	0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU   ((AT91_REG *) 	0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR  ((AT91_REG *) 	0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR ((AT91_REG *) 	0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR ((AT91_REG *) 	0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR  ((AT91_REG *) 	0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR  ((AT91_REG *) 	0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR  ((AT91_REG *) 	0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR ((AT91_REG *) 	0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR ((AT91_REG *) 	0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR ((AT91_REG *) 	0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR ((AT91_REG *) 	0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID ((AT91_REG *) 	0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR ((AT91_REG *) 	0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR  ((AT91_REG *) 	0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR  ((AT91_REG *) 	0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR ((AT91_REG *) 	0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR   ((AT91_REG *) 	0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR  ((AT91_REG *) 	0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR   ((AT91_REG *) 	0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR ((AT91_REG *) 	0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR  ((AT91_REG *) 	0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR  ((AT91_REG *) 	0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER  ((AT91_REG *) 	0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR  ((AT91_REG *) 	0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR ((AT91_REG *) 	0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR  ((AT91_REG *) 	0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR ((AT91_REG *) 	0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER  ((AT91_REG *) 	0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR ((AT91_REG *) 	0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR  ((AT91_REG *) 	0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER  ((AT91_REG *) 	0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR ((AT91_REG *) 	0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR ((AT91_REG *) 	0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR ((AT91_REG *) 	0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR  ((AT91_REG *) 	0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR ((AT91_REG *) 	0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR ((AT91_REG *) 	0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR ((AT91_REG *) 	0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR  ((AT91_REG *) 	0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER ((AT91_REG *) 	0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER ((AT91_REG *) 	0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR ((AT91_REG *) 	0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER ((AT91_REG *) 	0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR  ((AT91_REG *) 	0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR  ((AT91_REG *) 	0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR ((AT91_REG *) 	0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR ((AT91_REG *) 	0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER ((AT91_REG *) 	0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR  ((AT91_REG *) 	0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR ((AT91_REG *) 	0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER  ((AT91_REG *) 	0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR  ((AT91_REG *) 	0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR ((AT91_REG *) 	0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER ((AT91_REG *) 	0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR ((AT91_REG *) 	0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR  ((AT91_REG *) 	0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR  ((AT91_REG *) 	0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR ((AT91_REG *) 	0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR  ((AT91_REG *) 	0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER  ((AT91_REG *) 	0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR ((AT91_REG *) 	0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER ((AT91_REG *) 	0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR ((AT91_REG *) 	0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR ((AT91_REG *) 	0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR ((AT91_REG *) 	0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR  ((AT91_REG *) 	0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR ((AT91_REG *) 	0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR  ((AT91_REG *) 	0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR  ((AT91_REG *) 	0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR ((AT91_REG *) 	0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER ((AT91_REG *) 	0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR ((AT91_REG *) 	0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR  ((AT91_REG *) 	0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR ((AT91_REG *) 	0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR  ((AT91_REG *) 	0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR ((AT91_REG *) 	0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER ((AT91_REG *) 	0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR  ((AT91_REG *) 	0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR ((AT91_REG *) 	0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER  ((AT91_REG *) 	0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER  ((AT91_REG *) 	0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR  ((AT91_REG *) 	0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR ((AT91_REG *) 	0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR ((AT91_REG *) 	0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR   ((AT91_REG *) 	0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR   ((AT91_REG *) 	0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR  ((AT91_REG *) 	0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER  ((AT91_REG *) 	0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR  ((AT91_REG *) 	0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR  ((AT91_REG *) 	0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR  ((AT91_REG *) 	0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR  ((AT91_REG *) 	0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR  ((AT91_REG *) 	0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR  ((AT91_REG *) 	0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR  ((AT91_REG *) 	0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER  ((AT91_REG *) 	0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR   ((AT91_REG *) 	0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER   ((AT91_REG *) 	0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR    ((AT91_REG *) 	0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR  ((AT91_REG *) 	0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR  ((AT91_REG *) 	0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR  ((AT91_REG *) 	0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR ((AT91_REG *) 	0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR ((AT91_REG *) 	0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR ((AT91_REG *) 	0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR ((AT91_REG *) 	0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR ((AT91_REG *) 	0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR ((AT91_REG *) 	0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR ((AT91_REG *) 	0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR ((AT91_REG *) 	0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR ((AT91_REG *) 	0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR ((AT91_REG *) 	0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR ((AT91_REG *) 	0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR   ((AT91_REG *) 	0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR    ((AT91_REG *) 	0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR    ((AT91_REG *) 	0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR    ((AT91_REG *) 	0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR   ((AT91_REG *) 	0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR    ((AT91_REG *) 	0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR    ((AT91_REG *) 	0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR ((AT91_REG *) 	0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR  ((AT91_REG *) 	0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR ((AT91_REG *) 	0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR  ((AT91_REG *) 	0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR ((AT91_REG *) 	0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR  ((AT91_REG *) 	0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR  ((AT91_REG *) 	0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR ((AT91_REG *) 	0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR ((AT91_REG *) 	0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR ((AT91_REG *) 	0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR  ((AT91_REG *) 	0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER  ((AT91_REG *) 	0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR   ((AT91_REG *) 	0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR  ((AT91_REG *) 	0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR  ((AT91_REG *) 	0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR   ((AT91_REG *) 	0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR  ((AT91_REG *) 	0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR   ((AT91_REG *) 	0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR  ((AT91_REG *) 	0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR ((AT91_REG *) 	0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR  ((AT91_REG *) 	0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR  ((AT91_REG *) 	0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR  ((AT91_REG *) 	0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR ((AT91_REG *) 	0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR ((AT91_REG *) 	0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR  ((AT91_REG *) 	0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR ((AT91_REG *) 	0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR ((AT91_REG *) 	0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR ((AT91_REG *) 	0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER  ((AT91_REG *) 	0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR   ((AT91_REG *) 	0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR  ((AT91_REG *) 	0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR   ((AT91_REG *) 	0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR   ((AT91_REG *) 	0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR  ((AT91_REG *) 	0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR  ((AT91_REG *) 	0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR  ((AT91_REG *) 	0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR  ((AT91_REG *) 	0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR  ((AT91_REG *) 	0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR  ((AT91_REG *) 	0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR   ((AT91_REG *) 	0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR  ((AT91_REG *) 	0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR  ((AT91_REG *) 	0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR   ((AT91_REG *) 	0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR  ((AT91_REG *) 	0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR   ((AT91_REG *) 	0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR  ((AT91_REG *) 	0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR   ((AT91_REG *) 	0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF    ((AT91_REG *) 	0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER   ((AT91_REG *) 	0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR  ((AT91_REG *) 	0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR   ((AT91_REG *) 	0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR   ((AT91_REG *) 	0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER   ((AT91_REG *) 	0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR   ((AT91_REG *) 	0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR  ((AT91_REG *) 	0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR   ((AT91_REG *) 	0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR  ((AT91_REG *) 	0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR   ((AT91_REG *) 	0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI  ((AT91_REG *) 	0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR    ((AT91_REG *) 	0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR    ((AT91_REG *) 	0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR  ((AT91_REG *) 	0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR  ((AT91_REG *) 	0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR   ((AT91_REG *) 	0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR  ((AT91_REG *) 	0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR  ((AT91_REG *) 	0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR  ((AT91_REG *) 	0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR   ((AT91_REG *) 	0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR   ((AT91_REG *) 	0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR   ((AT91_REG *) 	0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR  ((AT91_REG *) 	0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR  ((AT91_REG *) 	0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER   ((AT91_REG *) 	0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR    ((AT91_REG *) 	0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR   ((AT91_REG *) 	0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI  ((AT91_REG *) 	0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR  ((AT91_REG *) 	0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR    ((AT91_REG *) 	0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR  ((AT91_REG *) 	0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR   ((AT91_REG *) 	0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR   ((AT91_REG *) 	0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR   ((AT91_REG *) 	0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR   ((AT91_REG *) 	0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF    ((AT91_REG *) 	0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER   ((AT91_REG *) 	0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR  ((AT91_REG *) 	0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR   ((AT91_REG *) 	0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR  ((AT91_REG *) 	0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR   ((AT91_REG *) 	0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR  ((AT91_REG *) 	0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR   ((AT91_REG *) 	0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR   ((AT91_REG *) 	0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR  ((AT91_REG *) 	0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR  ((AT91_REG *) 	0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR  ((AT91_REG *) 	0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR   ((AT91_REG *) 	0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR  ((AT91_REG *) 	0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR  ((AT91_REG *) 	0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR   ((AT91_REG *) 	0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR   ((AT91_REG *) 	0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR  ((AT91_REG *) 	0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER   ((AT91_REG *) 	0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR  ((AT91_REG *) 	0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR    ((AT91_REG *) 	0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR   ((AT91_REG *) 	0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR  ((AT91_REG *) 	0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR    ((AT91_REG *) 	0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR   ((AT91_REG *) 	0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR  ((AT91_REG *) 	0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER   ((AT91_REG *) 	0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR    ((AT91_REG *) 	0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR    ((AT91_REG *) 	0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR   ((AT91_REG *) 	0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR   ((AT91_REG *) 	0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR   ((AT91_REG *) 	0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR  ((AT91_REG *) 	0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR   ((AT91_REG *) 	0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR  ((AT91_REG *) 	0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR   ((AT91_REG *) 	0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR ((AT91_REG *) 	0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved ((AT91_REG *) 	0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR ((AT91_REG *) 	0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR ((AT91_REG *) 	0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR ((AT91_REG *) 	0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR ((AT91_REG *) 	0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved ((AT91_REG *) 	0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR ((AT91_REG *) 	0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR ((AT91_REG *) 	0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR ((AT91_REG *) 	0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR ((AT91_REG *) 	0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR ((AT91_REG *) 	0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved ((AT91_REG *) 	0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR ((AT91_REG *) 	0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR ((AT91_REG *) 	0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR ((AT91_REG *) 	0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR ((AT91_REG *) 	0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR ((AT91_REG *) 	0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved ((AT91_REG *) 	0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR ((AT91_REG *) 	0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR ((AT91_REG *) 	0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR ((AT91_REG *) 	0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR ((AT91_REG *) 	0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR ((AT91_REG *) 	0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR  ((AT91_REG *) 	0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS  ((AT91_REG *) 	0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER  ((AT91_REG *) 	0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR   ((AT91_REG *) 	0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR  ((AT91_REG *) 	0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR   ((AT91_REG *) 	0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR  ((AT91_REG *) 	0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR   ((AT91_REG *) 	0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA  ((AT91_REG *) 	0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR   ((AT91_REG *) 	0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR ((AT91_REG *) 	0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM   ((AT91_REG *) 	0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR   ((AT91_REG *) 	0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR   ((AT91_REG *) 	0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR   ((AT91_REG *) 	0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR   ((AT91_REG *) 	0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR   ((AT91_REG *) 	0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP ((AT91_REG *) 	0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC  ((AT91_REG *) 	0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE ((AT91_REG *) 	0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER   ((AT91_REG *) 	0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR    ((AT91_REG *) 	0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC    ((AT91_REG *) 	0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB    ((AT91_REG *) 	0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR   ((AT91_REG *) 	0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR   ((AT91_REG *) 	0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER   ((AT91_REG *) 	0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA    ((AT91_REG *) 	0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR   ((AT91_REG *) 	0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV    ((AT91_REG *) 	0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR   ((AT91_REG *) 	0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB    ((AT91_REG *) 	0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR   ((AT91_REG *) 	0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER   ((AT91_REG *) 	0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR   ((AT91_REG *) 	0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR    ((AT91_REG *) 	0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR   ((AT91_REG *) 	0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA    ((AT91_REG *) 	0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC    ((AT91_REG *) 	0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR   ((AT91_REG *) 	0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV    ((AT91_REG *) 	0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR   ((AT91_REG *) 	0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR   ((AT91_REG *) 	0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV    ((AT91_REG *) 	0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA    ((AT91_REG *) 	0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB    ((AT91_REG *) 	0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR   ((AT91_REG *) 	0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR   ((AT91_REG *) 	0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC    ((AT91_REG *) 	0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER   ((AT91_REG *) 	0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR    ((AT91_REG *) 	0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR   ((AT91_REG *) 	0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR   ((AT91_REG *) 	0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL ((AT91_REG *) 	0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM ((AT91_REG *) 	0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR ((AT91_REG *) 	0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID ((AT91_REG *) 	0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR ((AT91_REG *) 	0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID ((AT91_REG *) 	0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH ((AT91_REG *) 	0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR ((AT91_REG *) 	0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL ((AT91_REG *) 	0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID ((AT91_REG *) 	0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR ((AT91_REG *) 	0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR ((AT91_REG *) 	0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM ((AT91_REG *) 	0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH ((AT91_REG *) 	0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR ((AT91_REG *) 	0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID ((AT91_REG *) 	0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR ((AT91_REG *) 	0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH ((AT91_REG *) 	0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID ((AT91_REG *) 	0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL ((AT91_REG *) 	0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR ((AT91_REG *) 	0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM ((AT91_REG *) 	0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID ((AT91_REG *) 	0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR ((AT91_REG *) 	0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID ((AT91_REG *) 	0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM ((AT91_REG *) 	0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID ((AT91_REG *) 	0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR ((AT91_REG *) 	0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR ((AT91_REG *) 	0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR ((AT91_REG *) 	0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL ((AT91_REG *) 	0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH ((AT91_REG *) 	0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID ((AT91_REG *) 	0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR ((AT91_REG *) 	0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH ((AT91_REG *) 	0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID ((AT91_REG *) 	0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR ((AT91_REG *) 	0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR ((AT91_REG *) 	0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL ((AT91_REG *) 	0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM ((AT91_REG *) 	0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR ((AT91_REG *) 	0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR ((AT91_REG *) 	0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID ((AT91_REG *) 	0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH ((AT91_REG *) 	0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID ((AT91_REG *) 	0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR ((AT91_REG *) 	0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL ((AT91_REG *) 	0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM ((AT91_REG *) 	0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID ((AT91_REG *) 	0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID ((AT91_REG *) 	0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM ((AT91_REG *) 	0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR ((AT91_REG *) 	0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL ((AT91_REG *) 	0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR ((AT91_REG *) 	0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH ((AT91_REG *) 	0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR ((AT91_REG *) 	0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR ((AT91_REG *) 	0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH ((AT91_REG *) 	0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID ((AT91_REG *) 	0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL ((AT91_REG *) 	0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID ((AT91_REG *) 	0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR ((AT91_REG *) 	0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM ((AT91_REG *) 	0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR ((AT91_REG *) 	0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR   ((AT91_REG *) 	0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR   ((AT91_REG *) 	0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER   ((AT91_REG *) 	0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR   ((AT91_REG *) 	0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP ((AT91_REG *) 	0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR    ((AT91_REG *) 	0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR   ((AT91_REG *) 	0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR   ((AT91_REG *) 	0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM   ((AT91_REG *) 	0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR    ((AT91_REG *) 	0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR    ((AT91_REG *) 	0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR    ((AT91_REG *) 	0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR  ((AT91_REG *) 	0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H ((AT91_REG *) 	0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L ((AT91_REG *) 	0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE  ((AT91_REG *) 	0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL ((AT91_REG *) 	0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE  ((AT91_REG *) 	0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL  ((AT91_REG *) 	0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF  ((AT91_REG *) 	0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND ((AT91_REG *) 	0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR  ((AT91_REG *) 	0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L ((AT91_REG *) 	0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR  ((AT91_REG *) 	0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L ((AT91_REG *) 	0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR  ((AT91_REG *) 	0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR  ((AT91_REG *) 	0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE  ((AT91_REG *) 	0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL ((AT91_REG *) 	0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID  ((AT91_REG *) 	0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB  ((AT91_REG *) 	0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP ((AT91_REG *) 	0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO ((AT91_REG *) 	0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR  ((AT91_REG *) 	0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H ((AT91_REG *) 	0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV  ((AT91_REG *) 	0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE  ((AT91_REG *) 	0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA  ((AT91_REG *) 	0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP ((AT91_REG *) 	0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF  ((AT91_REG *) 	0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR ((AT91_REG *) 	0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT  ((AT91_REG *) 	0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF  ((AT91_REG *) 	0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE ((AT91_REG *) 	0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ  ((AT91_REG *) 	0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN  ((AT91_REG *) 	0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO  ((AT91_REG *) 	0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV  ((AT91_REG *) 	0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR  ((AT91_REG *) 	0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF  ((AT91_REG *) 	0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR  ((AT91_REG *) 	0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF  ((AT91_REG *) 	0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR  ((AT91_REG *) 	0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L ((AT91_REG *) 	0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO  ((AT91_REG *) 	0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER  ((AT91_REG *) 	0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H ((AT91_REG *) 	0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE  ((AT91_REG *) 	0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H ((AT91_REG *) 	0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE  ((AT91_REG *) 	0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE  ((AT91_REG *) 	0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR  ((AT91_REG *) 	0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR  ((AT91_REG *) 	0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR  ((AT91_REG *) 	0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR  ((AT91_REG *) 	0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR  ((AT91_REG *) 	0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR  ((AT91_REG *) 	0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR   ((AT91_REG *) 	0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR   ((AT91_REG *) 	0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR   ((AT91_REG *) 	0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR   ((AT91_REG *) 	0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2  ((AT91_REG *) 	0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3  ((AT91_REG *) 	0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0  ((AT91_REG *) 	0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5  ((AT91_REG *) 	0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR  ((AT91_REG *) 	0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR    ((AT91_REG *) 	0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4  ((AT91_REG *) 	0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1  ((AT91_REG *) 	0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR  ((AT91_REG *) 	0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR   ((AT91_REG *) 	0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR    ((AT91_REG *) 	0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7  ((AT91_REG *) 	0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6  ((AT91_REG *) 	0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER   ((AT91_REG *) 	0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER  ((AT91_REG *) 	0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR  ((AT91_REG *) 	0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR    ((AT91_REG *) 	0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR   ((AT91_REG *) 	0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR   ((AT91_REG *) 	0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR  ((AT91_REG *) 	0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR  ((AT91_REG *) 	0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR  ((AT91_REG *) 	0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR   ((AT91_REG *) 	0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR   ((AT91_REG *) 	0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR  ((AT91_REG *) 	0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR  ((AT91_REG *) 	0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR   ((AT91_REG *) 	0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR  ((AT91_REG *) 	0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR  ((AT91_REG *) 	0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR    ((AT91_REG *) 	0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR    ((AT91_REG *) 	0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR ((AT91_REG *) 	0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR ((AT91_REG *) 	0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR    ((AT91_REG *) 	0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR   ((AT91_REG *) 	0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR   ((AT91_REG *) 	0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER   ((AT91_REG *) 	0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR ((AT91_REG *) 	0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR   ((AT91_REG *) 	0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR ((AT91_REG *) 	0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR  ((AT91_REG *) 	0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR  ((AT91_REG *) 	0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR ((AT91_REG *) 	0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR ((AT91_REG *) 	0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR  ((AT91_REG *) 	0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR ((AT91_REG *) 	0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR  ((AT91_REG *) 	0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR ((AT91_REG *) 	0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR ((AT91_REG *) 	0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR ((AT91_REG *) 	0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR ((AT91_REG *) 	0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR  ((AT91_REG *) 	0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR   ((AT91_REG *) 	0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR ((AT91_REG *) 	0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR ((AT91_REG *) 	0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR  ((AT91_REG *) 	0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR   ((AT91_REG *) 	0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR   ((AT91_REG *) 	0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER  ((AT91_REG *) 	0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR  ((AT91_REG *) 	0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR ((AT91_REG *) 	0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR ((AT91_REG *) 	0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_PIO_PA0        ((unsigned int) 1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0     ((unsigned int) AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1        ((unsigned int) 1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0     ((unsigned int) AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10       ((unsigned int) 1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD      ((unsigned int) AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11       ((unsigned int) 1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK     ((unsigned int) AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12       ((unsigned int) 1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00   ((unsigned int) AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13       ((unsigned int) 1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01   ((unsigned int) AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1     ((unsigned int) AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14       ((unsigned int) 1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02   ((unsigned int) AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1     ((unsigned int) AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15       ((unsigned int) 1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03   ((unsigned int) AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2    ((unsigned int) AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16       ((unsigned int) 1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0    ((unsigned int) AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17       ((unsigned int) 1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0    ((unsigned int) AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18       ((unsigned int) 1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0    ((unsigned int) AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19       ((unsigned int) 1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX    ((unsigned int) AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2        ((unsigned int) 1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0     ((unsigned int) AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11   ((unsigned int) AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20       ((unsigned int) 1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX    ((unsigned int) AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21       ((unsigned int) 1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF       ((unsigned int) AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10   ((unsigned int) AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22       ((unsigned int) 1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK       ((unsigned int) AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1    ((unsigned int) AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23       ((unsigned int) 1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD       ((unsigned int) AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1    ((unsigned int) AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24       ((unsigned int) 1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD       ((unsigned int) AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1    ((unsigned int) AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25       ((unsigned int) 1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK       ((unsigned int) AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11   ((unsigned int) AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26       ((unsigned int) 1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF       ((unsigned int) AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12   ((unsigned int) AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27       ((unsigned int) 1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD     ((unsigned int) AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3     ((unsigned int) AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28       ((unsigned int) 1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD     ((unsigned int) AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29       ((unsigned int) 1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ      ((unsigned int) AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13   ((unsigned int) AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3        ((unsigned int) 1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0     ((unsigned int) AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12   ((unsigned int) AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30       ((unsigned int) 1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0     ((unsigned int) AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2     ((unsigned int) AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4        ((unsigned int) 1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0     ((unsigned int) AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13   ((unsigned int) AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5        ((unsigned int) 1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1     ((unsigned int) AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6        ((unsigned int) 1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1     ((unsigned int) AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7        ((unsigned int) 1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1     ((unsigned int) AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01   ((unsigned int) AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8        ((unsigned int) 1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1     ((unsigned int) AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02   ((unsigned int) AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9        ((unsigned int) 1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1     ((unsigned int) AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03   ((unsigned int) AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0        ((unsigned int) 1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK ((unsigned int) AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0     ((unsigned int) AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1        ((unsigned int) 1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN    ((unsigned int) AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10       ((unsigned int) 1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2     ((unsigned int) AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11   ((unsigned int) AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11       ((unsigned int) 1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3     ((unsigned int) AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12   ((unsigned int) AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12       ((unsigned int) 1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER    ((unsigned int) AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0    ((unsigned int) AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13       ((unsigned int) 1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2     ((unsigned int) AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01   ((unsigned int) AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14       ((unsigned int) 1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3     ((unsigned int) AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02   ((unsigned int) AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15       ((unsigned int) 1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV    ((unsigned int) AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16       ((unsigned int) 1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL     ((unsigned int) AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13   ((unsigned int) AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17       ((unsigned int) 1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK    ((unsigned int) AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03   ((unsigned int) AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18       ((unsigned int) 1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100    ((unsigned int) AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG    ((unsigned int) AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19       ((unsigned int) 1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0     ((unsigned int) AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1    ((unsigned int) AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2        ((unsigned int) 1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0     ((unsigned int) AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20       ((unsigned int) 1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1     ((unsigned int) AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0     ((unsigned int) AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21       ((unsigned int) 1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2     ((unsigned int) AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1     ((unsigned int) AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22       ((unsigned int) 1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3     ((unsigned int) AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2     ((unsigned int) AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23       ((unsigned int) 1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0    ((unsigned int) AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1     ((unsigned int) AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24       ((unsigned int) 1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0    ((unsigned int) AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1     ((unsigned int) AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25       ((unsigned int) 1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1    ((unsigned int) AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1     ((unsigned int) AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26       ((unsigned int) 1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1    ((unsigned int) AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1      ((unsigned int) AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27       ((unsigned int) 1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2    ((unsigned int) AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0     ((unsigned int) AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28       ((unsigned int) 1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2    ((unsigned int) AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1     ((unsigned int) AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29       ((unsigned int) 1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1     ((unsigned int) AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2     ((unsigned int) AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3        ((unsigned int) 1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1     ((unsigned int) AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30       ((unsigned int) 1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2     ((unsigned int) AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3     ((unsigned int) AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4        ((unsigned int) 1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV ((unsigned int) AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5        ((unsigned int) 1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0     ((unsigned int) AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6        ((unsigned int) 1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1     ((unsigned int) AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7        ((unsigned int) 1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER    ((unsigned int) AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8        ((unsigned int) 1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC     ((unsigned int) AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9        ((unsigned int) 1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO    ((unsigned int) AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ID_FIQ    ((unsigned int)  0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS    ((unsigned int)  1) // System Peripheral

+#define AT91C_ID_PIOA   ((unsigned int)  2) // Parallel IO Controller A

+#define AT91C_ID_PIOB   ((unsigned int)  3) // Parallel IO Controller B

+#define AT91C_ID_SPI0   ((unsigned int)  4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1   ((unsigned int)  5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0    ((unsigned int)  6) // USART 0

+#define AT91C_ID_US1    ((unsigned int)  7) // USART 1

+#define AT91C_ID_SSC    ((unsigned int)  8) // Serial Synchronous Controller

+#define AT91C_ID_TWI    ((unsigned int)  9) // Two-Wire Interface

+#define AT91C_ID_PWMC   ((unsigned int) 10) // PWM Controller

+#define AT91C_ID_UDP    ((unsigned int) 11) // USB Device Port

+#define AT91C_ID_TC0    ((unsigned int) 12) // Timer Counter 0

+#define AT91C_ID_TC1    ((unsigned int) 13) // Timer Counter 1

+#define AT91C_ID_TC2    ((unsigned int) 14) // Timer Counter 2

+#define AT91C_ID_CAN    ((unsigned int) 15) // Control Area Network Controller

+#define AT91C_ID_EMAC   ((unsigned int) 16) // Ethernet MAC

+#define AT91C_ID_ADC    ((unsigned int) 17) // Analog-to-Digital Converter

+#define AT91C_ID_AES    ((unsigned int) 18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES   ((unsigned int) 19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved ((unsigned int) 20) // Reserved

+#define AT91C_ID_21_Reserved ((unsigned int) 21) // Reserved

+#define AT91C_ID_22_Reserved ((unsigned int) 22) // Reserved

+#define AT91C_ID_23_Reserved ((unsigned int) 23) // Reserved

+#define AT91C_ID_24_Reserved ((unsigned int) 24) // Reserved

+#define AT91C_ID_25_Reserved ((unsigned int) 25) // Reserved

+#define AT91C_ID_26_Reserved ((unsigned int) 26) // Reserved

+#define AT91C_ID_27_Reserved ((unsigned int) 27) // Reserved

+#define AT91C_ID_28_Reserved ((unsigned int) 28) // Reserved

+#define AT91C_ID_29_Reserved ((unsigned int) 29) // Reserved

+#define AT91C_ID_IRQ0   ((unsigned int) 30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1   ((unsigned int) 31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_BASE_SYS       ((AT91PS_SYS) 	0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC       ((AT91PS_AIC) 	0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU  ((AT91PS_PDC) 	0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU      ((AT91PS_DBGU) 	0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA      ((AT91PS_PIO) 	0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB      ((AT91PS_PIO) 	0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR      ((AT91PS_CKGR) 	0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC       ((AT91PS_PMC) 	0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC      ((AT91PS_RSTC) 	0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC      ((AT91PS_RTTC) 	0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC      ((AT91PS_PITC) 	0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC      ((AT91PS_WDTC) 	0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG      ((AT91PS_VREG) 	0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC        ((AT91PS_MC) 	0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1  ((AT91PS_PDC) 	0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1      ((AT91PS_SPI) 	0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0  ((AT91PS_PDC) 	0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0      ((AT91PS_SPI) 	0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1   ((AT91PS_PDC) 	0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1       ((AT91PS_USART) 	0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0   ((AT91PS_PDC) 	0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0       ((AT91PS_USART) 	0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC   ((AT91PS_PDC) 	0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC       ((AT91PS_SSC) 	0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI       ((AT91PS_TWI) 	0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3  ((AT91PS_PWMC_CH) 	0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2  ((AT91PS_PWMC_CH) 	0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1  ((AT91PS_PWMC_CH) 	0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0  ((AT91PS_PWMC_CH) 	0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC      ((AT91PS_PWMC) 	0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP       ((AT91PS_UDP) 	0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0       ((AT91PS_TC) 	0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1       ((AT91PS_TC) 	0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2       ((AT91PS_TC) 	0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB       ((AT91PS_TCB) 	0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0   ((AT91PS_CAN_MB) 	0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1   ((AT91PS_CAN_MB) 	0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2   ((AT91PS_CAN_MB) 	0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3   ((AT91PS_CAN_MB) 	0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4   ((AT91PS_CAN_MB) 	0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5   ((AT91PS_CAN_MB) 	0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6   ((AT91PS_CAN_MB) 	0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7   ((AT91PS_CAN_MB) 	0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN       ((AT91PS_CAN) 	0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC      ((AT91PS_EMAC) 	0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC   ((AT91PS_PDC) 	0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC       ((AT91PS_ADC) 	0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES   ((AT91PS_PDC) 	0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES       ((AT91PS_AES) 	0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES  ((AT91PS_PDC) 	0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES      ((AT91PS_TDES) 	0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ISRAM	 ((char *) 	0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	 ((unsigned int) 0x00010000) // Internal SRAM size in byte (64 Kbyte)

+#define AT91C_IFLASH	 ((char *) 	0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	 ((unsigned int) 0x00040000) // Internal ROM size in byte (256 Kbyte)

+

+#endif

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256_inc.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256_inc.h
new file mode 100644
index 0000000..5b8dfe8
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/AT91SAM7X256_inc.h
@@ -0,0 +1,2446 @@
+//  ----------------------------------------------------------------------------

+//          ATMEL Microcontroller Software Support  -  ROUSSET  -

+//  ----------------------------------------------------------------------------

+//  DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//  IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//  DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//  ----------------------------------------------------------------------------

+// File Name           : AT91SAM7X256.h

+// Object              : AT91SAM7X256 definitions

+// Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+// 

+// CVS Reference       : /AT91SAM7X256.pl/1.11/Tue May 10 12:15:32 2005//

+// CVS Reference       : /SYS_SAM7X.pl/1.3/Tue Feb  1 17:01:43 2005//

+// CVS Reference       : /MC_SAM7X.pl/1.2/Fri May 20 14:13:04 2005//

+// CVS Reference       : /PMC_SAM7X.pl/1.4/Tue Feb  8 13:58:10 2005//

+// CVS Reference       : /RSTC_SAM7X.pl/1.1/Tue Feb  1 16:16:26 2005//

+// CVS Reference       : /UDP_SAM7X.pl/1.1/Tue May 10 11:35:35 2005//

+// CVS Reference       : /PWM_SAM7X.pl/1.1/Tue May 10 11:53:07 2005//

+// CVS Reference       : /AIC_6075B.pl/1.3/Fri May 20 14:01:30 2005//

+// CVS Reference       : /PIO_6057A.pl/1.2/Thu Feb  3 10:18:28 2005//

+// CVS Reference       : /RTTC_6081A.pl/1.2/Tue Nov  9 14:43:58 2004//

+// CVS Reference       : /PITC_6079A.pl/1.2/Tue Nov  9 14:43:56 2004//

+// CVS Reference       : /WDTC_6080A.pl/1.3/Tue Nov  9 14:44:00 2004//

+// CVS Reference       : /VREG_6085B.pl/1.1/Tue Feb  1 16:05:48 2005//

+// CVS Reference       : /PDC_6074C.pl/1.2/Thu Feb  3 08:48:54 2005//

+// CVS Reference       : /DBGU_6059D.pl/1.1/Mon Jan 31 13:15:32 2005//

+// CVS Reference       : /SPI_6088D.pl/1.3/Fri May 20 14:08:59 2005//

+// CVS Reference       : /US_6089C.pl/1.1/Mon Jul 12 18:23:26 2004//

+// CVS Reference       : /SSC_6078A.pl/1.1/Tue Jul 13 07:45:40 2004//

+// CVS Reference       : /TWI_6061A.pl/1.1/Tue Jul 13 07:38:06 2004//

+// CVS Reference       : /TC_6082A.pl/1.7/Fri Mar 11 12:52:17 2005//

+// CVS Reference       : /CAN_6019B.pl/1.1/Tue Mar  8 12:42:22 2005//

+// CVS Reference       : /EMACB_6119A.pl/1.5/Thu Feb  3 15:52:04 2005//

+// CVS Reference       : /ADC_6051C.pl/1.1/Fri Oct 17 09:12:38 2003//

+// CVS Reference       : /AES_6149A.pl/1.10/Mon Feb  7 09:44:25 2005//

+// CVS Reference       : /DES3_6150A.pl/1.1/Mon Jan 17 08:34:31 2005//

+//  ----------------------------------------------------------------------------

+

+// Hardware register definition

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR System Peripherals

+// *****************************************************************************

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced Interrupt Controller

+// *****************************************************************************

+// *** Register offset in AT91S_AIC structure ***

+#define AIC_SMR         ( 0) // Source Mode Register

+#define AIC_SVR         (128) // Source Vector Register

+#define AIC_IVR         (256) // IRQ Vector Register

+#define AIC_FVR         (260) // FIQ Vector Register

+#define AIC_ISR         (264) // Interrupt Status Register

+#define AIC_IPR         (268) // Interrupt Pending Register

+#define AIC_IMR         (272) // Interrupt Mask Register

+#define AIC_CISR        (276) // Core Interrupt Status Register

+#define AIC_IECR        (288) // Interrupt Enable Command Register

+#define AIC_IDCR        (292) // Interrupt Disable Command Register

+#define AIC_ICCR        (296) // Interrupt Clear Command Register

+#define AIC_ISCR        (300) // Interrupt Set Command Register

+#define AIC_EOICR       (304) // End of Interrupt Command Register

+#define AIC_SPU         (308) // Spurious Vector Register

+#define AIC_DCR         (312) // Debug Control Register (Protect)

+#define AIC_FFER        (320) // Fast Forcing Enable Register

+#define AIC_FFDR        (324) // Fast Forcing Disable Register

+#define AIC_FFSR        (328) // Fast Forcing Status Register

+// -------- AIC_SMR : (AIC Offset: 0x0) Control Register -------- 

+#define AT91C_AIC_PRIOR           (0x7 <<  0) // (AIC) Priority Level

+#define 	AT91C_AIC_PRIOR_LOWEST               (0x0) // (AIC) Lowest priority level

+#define 	AT91C_AIC_PRIOR_HIGHEST              (0x7) // (AIC) Highest priority level

+#define AT91C_AIC_SRCTYPE         (0x3 <<  5) // (AIC) Interrupt Source Type

+#define 	AT91C_AIC_SRCTYPE_INT_HIGH_LEVEL       (0x0 <<  5) // (AIC) Internal Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_EXT_LOW_LEVEL        (0x0 <<  5) // (AIC) External Sources Code Label Low-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE    (0x1 <<  5) // (AIC) Internal Sources Code Label Positive Edge triggered

+#define 	AT91C_AIC_SRCTYPE_EXT_NEGATIVE_EDGE    (0x1 <<  5) // (AIC) External Sources Code Label Negative Edge triggered

+#define 	AT91C_AIC_SRCTYPE_HIGH_LEVEL           (0x2 <<  5) // (AIC) Internal Or External Sources Code Label High-level Sensitive

+#define 	AT91C_AIC_SRCTYPE_POSITIVE_EDGE        (0x3 <<  5) // (AIC) Internal Or External Sources Code Label Positive Edge triggered

+// -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register -------- 

+#define AT91C_AIC_NFIQ            (0x1 <<  0) // (AIC) NFIQ Status

+#define AT91C_AIC_NIRQ            (0x1 <<  1) // (AIC) NIRQ Status

+// -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) -------- 

+#define AT91C_AIC_DCR_PROT        (0x1 <<  0) // (AIC) Protection Mode

+#define AT91C_AIC_DCR_GMSK        (0x1 <<  1) // (AIC) General Mask

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Peripheral DMA Controller

+// *****************************************************************************

+// *** Register offset in AT91S_PDC structure ***

+#define PDC_RPR         ( 0) // Receive Pointer Register

+#define PDC_RCR         ( 4) // Receive Counter Register

+#define PDC_TPR         ( 8) // Transmit Pointer Register

+#define PDC_TCR         (12) // Transmit Counter Register

+#define PDC_RNPR        (16) // Receive Next Pointer Register

+#define PDC_RNCR        (20) // Receive Next Counter Register

+#define PDC_TNPR        (24) // Transmit Next Pointer Register

+#define PDC_TNCR        (28) // Transmit Next Counter Register

+#define PDC_PTCR        (32) // PDC Transfer Control Register

+#define PDC_PTSR        (36) // PDC Transfer Status Register

+// -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register -------- 

+#define AT91C_PDC_RXTEN           (0x1 <<  0) // (PDC) Receiver Transfer Enable

+#define AT91C_PDC_RXTDIS          (0x1 <<  1) // (PDC) Receiver Transfer Disable

+#define AT91C_PDC_TXTEN           (0x1 <<  8) // (PDC) Transmitter Transfer Enable

+#define AT91C_PDC_TXTDIS          (0x1 <<  9) // (PDC) Transmitter Transfer Disable

+// -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Debug Unit

+// *****************************************************************************

+// *** Register offset in AT91S_DBGU structure ***

+#define DBGU_CR         ( 0) // Control Register

+#define DBGU_MR         ( 4) // Mode Register

+#define DBGU_IER        ( 8) // Interrupt Enable Register

+#define DBGU_IDR        (12) // Interrupt Disable Register

+#define DBGU_IMR        (16) // Interrupt Mask Register

+#define DBGU_CSR        (20) // Channel Status Register

+#define DBGU_RHR        (24) // Receiver Holding Register

+#define DBGU_THR        (28) // Transmitter Holding Register

+#define DBGU_BRGR       (32) // Baud Rate Generator Register

+#define DBGU_CIDR       (64) // Chip ID Register

+#define DBGU_EXID       (68) // Chip ID Extension Register

+#define DBGU_FNTR       (72) // Force NTRST Register

+#define DBGU_RPR        (256) // Receive Pointer Register

+#define DBGU_RCR        (260) // Receive Counter Register

+#define DBGU_TPR        (264) // Transmit Pointer Register

+#define DBGU_TCR        (268) // Transmit Counter Register

+#define DBGU_RNPR       (272) // Receive Next Pointer Register

+#define DBGU_RNCR       (276) // Receive Next Counter Register

+#define DBGU_TNPR       (280) // Transmit Next Pointer Register

+#define DBGU_TNCR       (284) // Transmit Next Counter Register

+#define DBGU_PTCR       (288) // PDC Transfer Control Register

+#define DBGU_PTSR       (292) // PDC Transfer Status Register

+// -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_RSTRX            (0x1 <<  2) // (DBGU) Reset Receiver

+#define AT91C_US_RSTTX            (0x1 <<  3) // (DBGU) Reset Transmitter

+#define AT91C_US_RXEN             (0x1 <<  4) // (DBGU) Receiver Enable

+#define AT91C_US_RXDIS            (0x1 <<  5) // (DBGU) Receiver Disable

+#define AT91C_US_TXEN             (0x1 <<  6) // (DBGU) Transmitter Enable

+#define AT91C_US_TXDIS            (0x1 <<  7) // (DBGU) Transmitter Disable

+#define AT91C_US_RSTSTA           (0x1 <<  8) // (DBGU) Reset Status Bits

+// -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_PAR              (0x7 <<  9) // (DBGU) Parity type

+#define 	AT91C_US_PAR_EVEN                 (0x0 <<  9) // (DBGU) Even Parity

+#define 	AT91C_US_PAR_ODD                  (0x1 <<  9) // (DBGU) Odd Parity

+#define 	AT91C_US_PAR_SPACE                (0x2 <<  9) // (DBGU) Parity forced to 0 (Space)

+#define 	AT91C_US_PAR_MARK                 (0x3 <<  9) // (DBGU) Parity forced to 1 (Mark)

+#define 	AT91C_US_PAR_NONE                 (0x4 <<  9) // (DBGU) No Parity

+#define 	AT91C_US_PAR_MULTI_DROP           (0x6 <<  9) // (DBGU) Multi-drop mode

+#define AT91C_US_CHMODE           (0x3 << 14) // (DBGU) Channel Mode

+#define 	AT91C_US_CHMODE_NORMAL               (0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.

+#define 	AT91C_US_CHMODE_AUTO                 (0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.

+#define 	AT91C_US_CHMODE_LOCAL                (0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.

+#define 	AT91C_US_CHMODE_REMOTE               (0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.

+// -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXRDY            (0x1 <<  0) // (DBGU) RXRDY Interrupt

+#define AT91C_US_TXRDY            (0x1 <<  1) // (DBGU) TXRDY Interrupt

+#define AT91C_US_ENDRX            (0x1 <<  3) // (DBGU) End of Receive Transfer Interrupt

+#define AT91C_US_ENDTX            (0x1 <<  4) // (DBGU) End of Transmit Interrupt

+#define AT91C_US_OVRE             (0x1 <<  5) // (DBGU) Overrun Interrupt

+#define AT91C_US_FRAME            (0x1 <<  6) // (DBGU) Framing Error Interrupt

+#define AT91C_US_PARE             (0x1 <<  7) // (DBGU) Parity Error Interrupt

+#define AT91C_US_TXEMPTY          (0x1 <<  9) // (DBGU) TXEMPTY Interrupt

+#define AT91C_US_TXBUFE           (0x1 << 11) // (DBGU) TXBUFE Interrupt

+#define AT91C_US_RXBUFF           (0x1 << 12) // (DBGU) RXBUFF Interrupt

+#define AT91C_US_COMM_TX          (0x1 << 30) // (DBGU) COMM_TX Interrupt

+#define AT91C_US_COMM_RX          (0x1 << 31) // (DBGU) COMM_RX Interrupt

+// -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register -------- 

+// -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register -------- 

+#define AT91C_US_FORCE_NTRST      (0x1 <<  0) // (DBGU) Force NTRST in JTAG

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Parallel Input Output Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PIO structure ***

+#define PIO_PER         ( 0) // PIO Enable Register

+#define PIO_PDR         ( 4) // PIO Disable Register

+#define PIO_PSR         ( 8) // PIO Status Register

+#define PIO_OER         (16) // Output Enable Register

+#define PIO_ODR         (20) // Output Disable Registerr

+#define PIO_OSR         (24) // Output Status Register

+#define PIO_IFER        (32) // Input Filter Enable Register

+#define PIO_IFDR        (36) // Input Filter Disable Register

+#define PIO_IFSR        (40) // Input Filter Status Register

+#define PIO_SODR        (48) // Set Output Data Register

+#define PIO_CODR        (52) // Clear Output Data Register

+#define PIO_ODSR        (56) // Output Data Status Register

+#define PIO_PDSR        (60) // Pin Data Status Register

+#define PIO_IER         (64) // Interrupt Enable Register

+#define PIO_IDR         (68) // Interrupt Disable Register

+#define PIO_IMR         (72) // Interrupt Mask Register

+#define PIO_ISR         (76) // Interrupt Status Register

+#define PIO_MDER        (80) // Multi-driver Enable Register

+#define PIO_MDDR        (84) // Multi-driver Disable Register

+#define PIO_MDSR        (88) // Multi-driver Status Register

+#define PIO_PPUDR       (96) // Pull-up Disable Register

+#define PIO_PPUER       (100) // Pull-up Enable Register

+#define PIO_PPUSR       (104) // Pull-up Status Register

+#define PIO_ASR         (112) // Select A Register

+#define PIO_BSR         (116) // Select B Register

+#define PIO_ABSR        (120) // AB Select Status Register

+#define PIO_OWER        (160) // Output Write Enable Register

+#define PIO_OWDR        (164) // Output Write Disable Register

+#define PIO_OWSR        (168) // Output Write Status Register

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Clock Generator Controler

+// *****************************************************************************

+// *** Register offset in AT91S_CKGR structure ***

+#define CKGR_MOR        ( 0) // Main Oscillator Register

+#define CKGR_MCFR       ( 4) // Main Clock  Frequency Register

+#define CKGR_PLLR       (12) // PLL Register

+// -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register -------- 

+#define AT91C_CKGR_MOSCEN         (0x1 <<  0) // (CKGR) Main Oscillator Enable

+#define AT91C_CKGR_OSCBYPASS      (0x1 <<  1) // (CKGR) Main Oscillator Bypass

+#define AT91C_CKGR_OSCOUNT        (0xFF <<  8) // (CKGR) Main Oscillator Start-up Time

+// -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register -------- 

+#define AT91C_CKGR_MAINF          (0xFFFF <<  0) // (CKGR) Main Clock Frequency

+#define AT91C_CKGR_MAINRDY        (0x1 << 16) // (CKGR) Main Clock Ready

+// -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register -------- 

+#define AT91C_CKGR_DIV            (0xFF <<  0) // (CKGR) Divider Selected

+#define 	AT91C_CKGR_DIV_0                    (0x0) // (CKGR) Divider output is 0

+#define 	AT91C_CKGR_DIV_BYPASS               (0x1) // (CKGR) Divider is bypassed

+#define AT91C_CKGR_PLLCOUNT       (0x3F <<  8) // (CKGR) PLL Counter

+#define AT91C_CKGR_OUT            (0x3 << 14) // (CKGR) PLL Output Frequency Range

+#define 	AT91C_CKGR_OUT_0                    (0x0 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_1                    (0x1 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_2                    (0x2 << 14) // (CKGR) Please refer to the PLL datasheet

+#define 	AT91C_CKGR_OUT_3                    (0x3 << 14) // (CKGR) Please refer to the PLL datasheet

+#define AT91C_CKGR_MUL            (0x7FF << 16) // (CKGR) PLL Multiplier

+#define AT91C_CKGR_USBDIV         (0x3 << 28) // (CKGR) Divider for USB Clocks

+#define 	AT91C_CKGR_USBDIV_0                    (0x0 << 28) // (CKGR) Divider output is PLL clock output

+#define 	AT91C_CKGR_USBDIV_1                    (0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2

+#define 	AT91C_CKGR_USBDIV_2                    (0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Power Management Controler

+// *****************************************************************************

+// *** Register offset in AT91S_PMC structure ***

+#define PMC_SCER        ( 0) // System Clock Enable Register

+#define PMC_SCDR        ( 4) // System Clock Disable Register

+#define PMC_SCSR        ( 8) // System Clock Status Register

+#define PMC_PCER        (16) // Peripheral Clock Enable Register

+#define PMC_PCDR        (20) // Peripheral Clock Disable Register

+#define PMC_PCSR        (24) // Peripheral Clock Status Register

+#define PMC_MOR         (32) // Main Oscillator Register

+#define PMC_MCFR        (36) // Main Clock  Frequency Register

+#define PMC_PLLR        (44) // PLL Register

+#define PMC_MCKR        (48) // Master Clock Register

+#define PMC_PCKR        (64) // Programmable Clock Register

+#define PMC_IER         (96) // Interrupt Enable Register

+#define PMC_IDR         (100) // Interrupt Disable Register

+#define PMC_SR          (104) // Status Register

+#define PMC_IMR         (108) // Interrupt Mask Register

+// -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register -------- 

+#define AT91C_PMC_PCK             (0x1 <<  0) // (PMC) Processor Clock

+#define AT91C_PMC_UDP             (0x1 <<  7) // (PMC) USB Device Port Clock

+#define AT91C_PMC_PCK0            (0x1 <<  8) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK1            (0x1 <<  9) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK2            (0x1 << 10) // (PMC) Programmable Clock Output

+#define AT91C_PMC_PCK3            (0x1 << 11) // (PMC) Programmable Clock Output

+// -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register -------- 

+// -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register -------- 

+// -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register -------- 

+// -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register -------- 

+// -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register -------- 

+// -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register -------- 

+#define AT91C_PMC_CSS             (0x3 <<  0) // (PMC) Programmable Clock Selection

+#define 	AT91C_PMC_CSS_SLOW_CLK             (0x0) // (PMC) Slow Clock is selected

+#define 	AT91C_PMC_CSS_MAIN_CLK             (0x1) // (PMC) Main Clock is selected

+#define 	AT91C_PMC_CSS_PLL_CLK              (0x3) // (PMC) Clock from PLL is selected

+#define AT91C_PMC_PRES            (0x7 <<  2) // (PMC) Programmable Clock Prescaler

+#define 	AT91C_PMC_PRES_CLK                  (0x0 <<  2) // (PMC) Selected clock

+#define 	AT91C_PMC_PRES_CLK_2                (0x1 <<  2) // (PMC) Selected clock divided by 2

+#define 	AT91C_PMC_PRES_CLK_4                (0x2 <<  2) // (PMC) Selected clock divided by 4

+#define 	AT91C_PMC_PRES_CLK_8                (0x3 <<  2) // (PMC) Selected clock divided by 8

+#define 	AT91C_PMC_PRES_CLK_16               (0x4 <<  2) // (PMC) Selected clock divided by 16

+#define 	AT91C_PMC_PRES_CLK_32               (0x5 <<  2) // (PMC) Selected clock divided by 32

+#define 	AT91C_PMC_PRES_CLK_64               (0x6 <<  2) // (PMC) Selected clock divided by 64

+// -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register -------- 

+// -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register -------- 

+#define AT91C_PMC_MOSCS           (0x1 <<  0) // (PMC) MOSC Status/Enable/Disable/Mask

+#define AT91C_PMC_LOCK            (0x1 <<  2) // (PMC) PLL Status/Enable/Disable/Mask

+#define AT91C_PMC_MCKRDY          (0x1 <<  3) // (PMC) MCK_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK0RDY         (0x1 <<  8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK1RDY         (0x1 <<  9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK2RDY         (0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask

+#define AT91C_PMC_PCK3RDY         (0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask

+// -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register -------- 

+// -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register -------- 

+// -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Reset Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RSTC structure ***

+#define RSTC_RCR        ( 0) // Reset Control Register

+#define RSTC_RSR        ( 4) // Reset Status Register

+#define RSTC_RMR        ( 8) // Reset Mode Register

+// -------- RSTC_RCR : (RSTC Offset: 0x0) Reset Control Register -------- 

+#define AT91C_RSTC_PROCRST        (0x1 <<  0) // (RSTC) Processor Reset

+#define AT91C_RSTC_PERRST         (0x1 <<  2) // (RSTC) Peripheral Reset

+#define AT91C_RSTC_EXTRST         (0x1 <<  3) // (RSTC) External Reset

+#define AT91C_RSTC_KEY            (0xFF << 24) // (RSTC) Password

+// -------- RSTC_RSR : (RSTC Offset: 0x4) Reset Status Register -------- 

+#define AT91C_RSTC_URSTS          (0x1 <<  0) // (RSTC) User Reset Status

+#define AT91C_RSTC_BODSTS         (0x1 <<  1) // (RSTC) Brownout Detection Status

+#define AT91C_RSTC_RSTTYP         (0x7 <<  8) // (RSTC) Reset Type

+#define 	AT91C_RSTC_RSTTYP_POWERUP              (0x0 <<  8) // (RSTC) Power-up Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WAKEUP               (0x1 <<  8) // (RSTC) WakeUp Reset. VDDCORE rising.

+#define 	AT91C_RSTC_RSTTYP_WATCHDOG             (0x2 <<  8) // (RSTC) Watchdog Reset. Watchdog overflow occured.

+#define 	AT91C_RSTC_RSTTYP_SOFTWARE             (0x3 <<  8) // (RSTC) Software Reset. Processor reset required by the software.

+#define 	AT91C_RSTC_RSTTYP_USER                 (0x4 <<  8) // (RSTC) User Reset. NRST pin detected low.

+#define 	AT91C_RSTC_RSTTYP_BROWNOUT             (0x5 <<  8) // (RSTC) Brownout Reset occured.

+#define AT91C_RSTC_NRSTL          (0x1 << 16) // (RSTC) NRST pin level

+#define AT91C_RSTC_SRCMP          (0x1 << 17) // (RSTC) Software Reset Command in Progress.

+// -------- RSTC_RMR : (RSTC Offset: 0x8) Reset Mode Register -------- 

+#define AT91C_RSTC_URSTEN         (0x1 <<  0) // (RSTC) User Reset Enable

+#define AT91C_RSTC_URSTIEN        (0x1 <<  4) // (RSTC) User Reset Interrupt Enable

+#define AT91C_RSTC_ERSTL          (0xF <<  8) // (RSTC) User Reset Enable

+#define AT91C_RSTC_BODIEN         (0x1 << 16) // (RSTC) Brownout Detection Interrupt Enable

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Real Time Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_RTTC structure ***

+#define RTTC_RTMR       ( 0) // Real-time Mode Register

+#define RTTC_RTAR       ( 4) // Real-time Alarm Register

+#define RTTC_RTVR       ( 8) // Real-time Value Register

+#define RTTC_RTSR       (12) // Real-time Status Register

+// -------- RTTC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register -------- 

+#define AT91C_RTTC_RTPRES         (0xFFFF <<  0) // (RTTC) Real-time Timer Prescaler Value

+#define AT91C_RTTC_ALMIEN         (0x1 << 16) // (RTTC) Alarm Interrupt Enable

+#define AT91C_RTTC_RTTINCIEN      (0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable

+#define AT91C_RTTC_RTTRST         (0x1 << 18) // (RTTC) Real Time Timer Restart

+// -------- RTTC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register -------- 

+#define AT91C_RTTC_ALMV           (0x0 <<  0) // (RTTC) Alarm Value

+// -------- RTTC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register -------- 

+#define AT91C_RTTC_CRTV           (0x0 <<  0) // (RTTC) Current Real-time Value

+// -------- RTTC_RTSR : (RTTC Offset: 0xc) Real-time Status Register -------- 

+#define AT91C_RTTC_ALMS           (0x1 <<  0) // (RTTC) Real-time Alarm Status

+#define AT91C_RTTC_RTTINC         (0x1 <<  1) // (RTTC) Real-time Timer Increment

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Periodic Interval Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PITC structure ***

+#define PITC_PIMR       ( 0) // Period Interval Mode Register

+#define PITC_PISR       ( 4) // Period Interval Status Register

+#define PITC_PIVR       ( 8) // Period Interval Value Register

+#define PITC_PIIR       (12) // Period Interval Image Register

+// -------- PITC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register -------- 

+#define AT91C_PITC_PIV            (0xFFFFF <<  0) // (PITC) Periodic Interval Value

+#define AT91C_PITC_PITEN          (0x1 << 24) // (PITC) Periodic Interval Timer Enabled

+#define AT91C_PITC_PITIEN         (0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable

+// -------- PITC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register -------- 

+#define AT91C_PITC_PITS           (0x1 <<  0) // (PITC) Periodic Interval Timer Status

+// -------- PITC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register -------- 

+#define AT91C_PITC_CPIV           (0xFFFFF <<  0) // (PITC) Current Periodic Interval Value

+#define AT91C_PITC_PICNT          (0xFFF << 20) // (PITC) Periodic Interval Counter

+// -------- PITC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Watchdog Timer Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_WDTC structure ***

+#define WDTC_WDCR       ( 0) // Watchdog Control Register

+#define WDTC_WDMR       ( 4) // Watchdog Mode Register

+#define WDTC_WDSR       ( 8) // Watchdog Status Register

+// -------- WDTC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register -------- 

+#define AT91C_WDTC_WDRSTT         (0x1 <<  0) // (WDTC) Watchdog Restart

+#define AT91C_WDTC_KEY            (0xFF << 24) // (WDTC) Watchdog KEY Password

+// -------- WDTC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register -------- 

+#define AT91C_WDTC_WDV            (0xFFF <<  0) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDFIEN         (0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable

+#define AT91C_WDTC_WDRSTEN        (0x1 << 13) // (WDTC) Watchdog Reset Enable

+#define AT91C_WDTC_WDRPROC        (0x1 << 14) // (WDTC) Watchdog Timer Restart

+#define AT91C_WDTC_WDDIS          (0x1 << 15) // (WDTC) Watchdog Disable

+#define AT91C_WDTC_WDD            (0xFFF << 16) // (WDTC) Watchdog Delta Value

+#define AT91C_WDTC_WDDBGHLT       (0x1 << 28) // (WDTC) Watchdog Debug Halt

+#define AT91C_WDTC_WDIDLEHLT      (0x1 << 29) // (WDTC) Watchdog Idle Halt

+// -------- WDTC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register -------- 

+#define AT91C_WDTC_WDUNF          (0x1 <<  0) // (WDTC) Watchdog Underflow

+#define AT91C_WDTC_WDERR          (0x1 <<  1) // (WDTC) Watchdog Error

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Voltage Regulator Mode Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_VREG structure ***

+#define VREG_MR         ( 0) // Voltage Regulator Mode Register

+// -------- VREG_MR : (VREG Offset: 0x0) Voltage Regulator Mode Register -------- 

+#define AT91C_VREG_PSTDBY         (0x1 <<  0) // (VREG) Voltage Regulator Power Standby Mode

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Memory Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_MC structure ***

+#define MC_RCR          ( 0) // MC Remap Control Register

+#define MC_ASR          ( 4) // MC Abort Status Register

+#define MC_AASR         ( 8) // MC Abort Address Status Register

+#define MC_FMR          (96) // MC Flash Mode Register

+#define MC_FCR          (100) // MC Flash Command Register

+#define MC_FSR          (104) // MC Flash Status Register

+// -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register -------- 

+#define AT91C_MC_RCB              (0x1 <<  0) // (MC) Remap Command Bit

+// -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register -------- 

+#define AT91C_MC_UNDADD           (0x1 <<  0) // (MC) Undefined Addess Abort Status

+#define AT91C_MC_MISADD           (0x1 <<  1) // (MC) Misaligned Addess Abort Status

+#define AT91C_MC_ABTSZ            (0x3 <<  8) // (MC) Abort Size Status

+#define 	AT91C_MC_ABTSZ_BYTE                 (0x0 <<  8) // (MC) Byte

+#define 	AT91C_MC_ABTSZ_HWORD                (0x1 <<  8) // (MC) Half-word

+#define 	AT91C_MC_ABTSZ_WORD                 (0x2 <<  8) // (MC) Word

+#define AT91C_MC_ABTTYP           (0x3 << 10) // (MC) Abort Type Status

+#define 	AT91C_MC_ABTTYP_DATAR                (0x0 << 10) // (MC) Data Read

+#define 	AT91C_MC_ABTTYP_DATAW                (0x1 << 10) // (MC) Data Write

+#define 	AT91C_MC_ABTTYP_FETCH                (0x2 << 10) // (MC) Code Fetch

+#define AT91C_MC_MST0             (0x1 << 16) // (MC) Master 0 Abort Source

+#define AT91C_MC_MST1             (0x1 << 17) // (MC) Master 1 Abort Source

+#define AT91C_MC_SVMST0           (0x1 << 24) // (MC) Saved Master 0 Abort Source

+#define AT91C_MC_SVMST1           (0x1 << 25) // (MC) Saved Master 1 Abort Source

+// -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register -------- 

+#define AT91C_MC_FRDY             (0x1 <<  0) // (MC) Flash Ready

+#define AT91C_MC_LOCKE            (0x1 <<  2) // (MC) Lock Error

+#define AT91C_MC_PROGE            (0x1 <<  3) // (MC) Programming Error

+#define AT91C_MC_NEBP             (0x1 <<  7) // (MC) No Erase Before Programming

+#define AT91C_MC_FWS              (0x3 <<  8) // (MC) Flash Wait State

+#define 	AT91C_MC_FWS_0FWS                 (0x0 <<  8) // (MC) 1 cycle for Read, 2 for Write operations

+#define 	AT91C_MC_FWS_1FWS                 (0x1 <<  8) // (MC) 2 cycles for Read, 3 for Write operations

+#define 	AT91C_MC_FWS_2FWS                 (0x2 <<  8) // (MC) 3 cycles for Read, 4 for Write operations

+#define 	AT91C_MC_FWS_3FWS                 (0x3 <<  8) // (MC) 4 cycles for Read, 4 for Write operations

+#define AT91C_MC_FMCN             (0xFF << 16) // (MC) Flash Microsecond Cycle Number

+// -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register -------- 

+#define AT91C_MC_FCMD             (0xF <<  0) // (MC) Flash Command

+#define 	AT91C_MC_FCMD_START_PROG           (0x1) // (MC) Starts the programming of th epage specified by PAGEN.

+#define 	AT91C_MC_FCMD_LOCK                 (0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_PROG_AND_LOCK        (0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.

+#define 	AT91C_MC_FCMD_UNLOCK               (0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.

+#define 	AT91C_MC_FCMD_ERASE_ALL            (0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.

+#define 	AT91C_MC_FCMD_SET_GP_NVM           (0xB) // (MC) Set General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_CLR_GP_NVM           (0xD) // (MC) Clear General Purpose NVM bits.

+#define 	AT91C_MC_FCMD_SET_SECURITY         (0xF) // (MC) Set Security Bit.

+#define AT91C_MC_PAGEN            (0x3FF <<  8) // (MC) Page Number

+#define AT91C_MC_KEY              (0xFF << 24) // (MC) Writing Protect Key

+// -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register -------- 

+#define AT91C_MC_SECURITY         (0x1 <<  4) // (MC) Security Bit Status

+#define AT91C_MC_GPNVM0           (0x1 <<  8) // (MC) Sector 0 Lock Status

+#define AT91C_MC_GPNVM1           (0x1 <<  9) // (MC) Sector 1 Lock Status

+#define AT91C_MC_GPNVM2           (0x1 << 10) // (MC) Sector 2 Lock Status

+#define AT91C_MC_GPNVM3           (0x1 << 11) // (MC) Sector 3 Lock Status

+#define AT91C_MC_GPNVM4           (0x1 << 12) // (MC) Sector 4 Lock Status

+#define AT91C_MC_GPNVM5           (0x1 << 13) // (MC) Sector 5 Lock Status

+#define AT91C_MC_GPNVM6           (0x1 << 14) // (MC) Sector 6 Lock Status

+#define AT91C_MC_GPNVM7           (0x1 << 15) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS0           (0x1 << 16) // (MC) Sector 0 Lock Status

+#define AT91C_MC_LOCKS1           (0x1 << 17) // (MC) Sector 1 Lock Status

+#define AT91C_MC_LOCKS2           (0x1 << 18) // (MC) Sector 2 Lock Status

+#define AT91C_MC_LOCKS3           (0x1 << 19) // (MC) Sector 3 Lock Status

+#define AT91C_MC_LOCKS4           (0x1 << 20) // (MC) Sector 4 Lock Status

+#define AT91C_MC_LOCKS5           (0x1 << 21) // (MC) Sector 5 Lock Status

+#define AT91C_MC_LOCKS6           (0x1 << 22) // (MC) Sector 6 Lock Status

+#define AT91C_MC_LOCKS7           (0x1 << 23) // (MC) Sector 7 Lock Status

+#define AT91C_MC_LOCKS8           (0x1 << 24) // (MC) Sector 8 Lock Status

+#define AT91C_MC_LOCKS9           (0x1 << 25) // (MC) Sector 9 Lock Status

+#define AT91C_MC_LOCKS10          (0x1 << 26) // (MC) Sector 10 Lock Status

+#define AT91C_MC_LOCKS11          (0x1 << 27) // (MC) Sector 11 Lock Status

+#define AT91C_MC_LOCKS12          (0x1 << 28) // (MC) Sector 12 Lock Status

+#define AT91C_MC_LOCKS13          (0x1 << 29) // (MC) Sector 13 Lock Status

+#define AT91C_MC_LOCKS14          (0x1 << 30) // (MC) Sector 14 Lock Status

+#define AT91C_MC_LOCKS15          (0x1 << 31) // (MC) Sector 15 Lock Status

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Serial Parallel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SPI structure ***

+#define SPI_CR          ( 0) // Control Register

+#define SPI_MR          ( 4) // Mode Register

+#define SPI_RDR         ( 8) // Receive Data Register

+#define SPI_TDR         (12) // Transmit Data Register

+#define SPI_SR          (16) // Status Register

+#define SPI_IER         (20) // Interrupt Enable Register

+#define SPI_IDR         (24) // Interrupt Disable Register

+#define SPI_IMR         (28) // Interrupt Mask Register

+#define SPI_CSR         (48) // Chip Select Register

+#define SPI_RPR         (256) // Receive Pointer Register

+#define SPI_RCR         (260) // Receive Counter Register

+#define SPI_TPR         (264) // Transmit Pointer Register

+#define SPI_TCR         (268) // Transmit Counter Register

+#define SPI_RNPR        (272) // Receive Next Pointer Register

+#define SPI_RNCR        (276) // Receive Next Counter Register

+#define SPI_TNPR        (280) // Transmit Next Pointer Register

+#define SPI_TNCR        (284) // Transmit Next Counter Register

+#define SPI_PTCR        (288) // PDC Transfer Control Register

+#define SPI_PTSR        (292) // PDC Transfer Status Register

+// -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register -------- 

+#define AT91C_SPI_SPIEN           (0x1 <<  0) // (SPI) SPI Enable

+#define AT91C_SPI_SPIDIS          (0x1 <<  1) // (SPI) SPI Disable

+#define AT91C_SPI_SWRST           (0x1 <<  7) // (SPI) SPI Software reset

+#define AT91C_SPI_LASTXFER        (0x1 << 24) // (SPI) SPI Last Transfer

+// -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register -------- 

+#define AT91C_SPI_MSTR            (0x1 <<  0) // (SPI) Master/Slave Mode

+#define AT91C_SPI_PS              (0x1 <<  1) // (SPI) Peripheral Select

+#define 	AT91C_SPI_PS_FIXED                (0x0 <<  1) // (SPI) Fixed Peripheral Select

+#define 	AT91C_SPI_PS_VARIABLE             (0x1 <<  1) // (SPI) Variable Peripheral Select

+#define AT91C_SPI_PCSDEC          (0x1 <<  2) // (SPI) Chip Select Decode

+#define AT91C_SPI_FDIV            (0x1 <<  3) // (SPI) Clock Selection

+#define AT91C_SPI_MODFDIS         (0x1 <<  4) // (SPI) Mode Fault Detection

+#define AT91C_SPI_LLB             (0x1 <<  7) // (SPI) Clock Selection

+#define AT91C_SPI_PCS             (0xF << 16) // (SPI) Peripheral Chip Select

+#define AT91C_SPI_DLYBCS          (0xFF << 24) // (SPI) Delay Between Chip Selects

+// -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register -------- 

+#define AT91C_SPI_RD              (0xFFFF <<  0) // (SPI) Receive Data

+#define AT91C_SPI_RPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register -------- 

+#define AT91C_SPI_TD              (0xFFFF <<  0) // (SPI) Transmit Data

+#define AT91C_SPI_TPCS            (0xF << 16) // (SPI) Peripheral Chip Select Status

+// -------- SPI_SR : (SPI Offset: 0x10) Status Register -------- 

+#define AT91C_SPI_RDRF            (0x1 <<  0) // (SPI) Receive Data Register Full

+#define AT91C_SPI_TDRE            (0x1 <<  1) // (SPI) Transmit Data Register Empty

+#define AT91C_SPI_MODF            (0x1 <<  2) // (SPI) Mode Fault Error

+#define AT91C_SPI_OVRES           (0x1 <<  3) // (SPI) Overrun Error Status

+#define AT91C_SPI_ENDRX           (0x1 <<  4) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_ENDTX           (0x1 <<  5) // (SPI) End of Receiver Transfer

+#define AT91C_SPI_RXBUFF          (0x1 <<  6) // (SPI) RXBUFF Interrupt

+#define AT91C_SPI_TXBUFE          (0x1 <<  7) // (SPI) TXBUFE Interrupt

+#define AT91C_SPI_NSSR            (0x1 <<  8) // (SPI) NSSR Interrupt

+#define AT91C_SPI_TXEMPTY         (0x1 <<  9) // (SPI) TXEMPTY Interrupt

+#define AT91C_SPI_SPIENS          (0x1 << 16) // (SPI) Enable Status

+// -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register -------- 

+// -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register -------- 

+// -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register -------- 

+// -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register -------- 

+#define AT91C_SPI_CPOL            (0x1 <<  0) // (SPI) Clock Polarity

+#define AT91C_SPI_NCPHA           (0x1 <<  1) // (SPI) Clock Phase

+#define AT91C_SPI_CSAAT           (0x1 <<  3) // (SPI) Chip Select Active After Transfer

+#define AT91C_SPI_BITS            (0xF <<  4) // (SPI) Bits Per Transfer

+#define 	AT91C_SPI_BITS_8                    (0x0 <<  4) // (SPI) 8 Bits Per transfer

+#define 	AT91C_SPI_BITS_9                    (0x1 <<  4) // (SPI) 9 Bits Per transfer

+#define 	AT91C_SPI_BITS_10                   (0x2 <<  4) // (SPI) 10 Bits Per transfer

+#define 	AT91C_SPI_BITS_11                   (0x3 <<  4) // (SPI) 11 Bits Per transfer

+#define 	AT91C_SPI_BITS_12                   (0x4 <<  4) // (SPI) 12 Bits Per transfer

+#define 	AT91C_SPI_BITS_13                   (0x5 <<  4) // (SPI) 13 Bits Per transfer

+#define 	AT91C_SPI_BITS_14                   (0x6 <<  4) // (SPI) 14 Bits Per transfer

+#define 	AT91C_SPI_BITS_15                   (0x7 <<  4) // (SPI) 15 Bits Per transfer

+#define 	AT91C_SPI_BITS_16                   (0x8 <<  4) // (SPI) 16 Bits Per transfer

+#define AT91C_SPI_SCBR            (0xFF <<  8) // (SPI) Serial Clock Baud Rate

+#define AT91C_SPI_DLYBS           (0xFF << 16) // (SPI) Delay Before SPCK

+#define AT91C_SPI_DLYBCT          (0xFF << 24) // (SPI) Delay Between Consecutive Transfers

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Usart

+// *****************************************************************************

+// *** Register offset in AT91S_USART structure ***

+#define US_CR           ( 0) // Control Register

+#define US_MR           ( 4) // Mode Register

+#define US_IER          ( 8) // Interrupt Enable Register

+#define US_IDR          (12) // Interrupt Disable Register

+#define US_IMR          (16) // Interrupt Mask Register

+#define US_CSR          (20) // Channel Status Register

+#define US_RHR          (24) // Receiver Holding Register

+#define US_THR          (28) // Transmitter Holding Register

+#define US_BRGR         (32) // Baud Rate Generator Register

+#define US_RTOR         (36) // Receiver Time-out Register

+#define US_TTGR         (40) // Transmitter Time-guard Register

+#define US_FIDI         (64) // FI_DI_Ratio Register

+#define US_NER          (68) // Nb Errors Register

+#define US_IF           (76) // IRDA_FILTER Register

+#define US_RPR          (256) // Receive Pointer Register

+#define US_RCR          (260) // Receive Counter Register

+#define US_TPR          (264) // Transmit Pointer Register

+#define US_TCR          (268) // Transmit Counter Register

+#define US_RNPR         (272) // Receive Next Pointer Register

+#define US_RNCR         (276) // Receive Next Counter Register

+#define US_TNPR         (280) // Transmit Next Pointer Register

+#define US_TNCR         (284) // Transmit Next Counter Register

+#define US_PTCR         (288) // PDC Transfer Control Register

+#define US_PTSR         (292) // PDC Transfer Status Register

+// -------- US_CR : (USART Offset: 0x0) Debug Unit Control Register -------- 

+#define AT91C_US_STTBRK           (0x1 <<  9) // (USART) Start Break

+#define AT91C_US_STPBRK           (0x1 << 10) // (USART) Stop Break

+#define AT91C_US_STTTO            (0x1 << 11) // (USART) Start Time-out

+#define AT91C_US_SENDA            (0x1 << 12) // (USART) Send Address

+#define AT91C_US_RSTIT            (0x1 << 13) // (USART) Reset Iterations

+#define AT91C_US_RSTNACK          (0x1 << 14) // (USART) Reset Non Acknowledge

+#define AT91C_US_RETTO            (0x1 << 15) // (USART) Rearm Time-out

+#define AT91C_US_DTREN            (0x1 << 16) // (USART) Data Terminal ready Enable

+#define AT91C_US_DTRDIS           (0x1 << 17) // (USART) Data Terminal ready Disable

+#define AT91C_US_RTSEN            (0x1 << 18) // (USART) Request to Send enable

+#define AT91C_US_RTSDIS           (0x1 << 19) // (USART) Request to Send Disable

+// -------- US_MR : (USART Offset: 0x4) Debug Unit Mode Register -------- 

+#define AT91C_US_USMODE           (0xF <<  0) // (USART) Usart mode

+#define 	AT91C_US_USMODE_NORMAL               (0x0) // (USART) Normal

+#define 	AT91C_US_USMODE_RS485                (0x1) // (USART) RS485

+#define 	AT91C_US_USMODE_HWHSH                (0x2) // (USART) Hardware Handshaking

+#define 	AT91C_US_USMODE_MODEM                (0x3) // (USART) Modem

+#define 	AT91C_US_USMODE_ISO7816_0            (0x4) // (USART) ISO7816 protocol: T = 0

+#define 	AT91C_US_USMODE_ISO7816_1            (0x6) // (USART) ISO7816 protocol: T = 1

+#define 	AT91C_US_USMODE_IRDA                 (0x8) // (USART) IrDA

+#define 	AT91C_US_USMODE_SWHSH                (0xC) // (USART) Software Handshaking

+#define AT91C_US_CLKS             (0x3 <<  4) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CLKS_CLOCK                (0x0 <<  4) // (USART) Clock

+#define 	AT91C_US_CLKS_FDIV1                (0x1 <<  4) // (USART) fdiv1

+#define 	AT91C_US_CLKS_SLOW                 (0x2 <<  4) // (USART) slow_clock (ARM)

+#define 	AT91C_US_CLKS_EXT                  (0x3 <<  4) // (USART) External (SCK)

+#define AT91C_US_CHRL             (0x3 <<  6) // (USART) Clock Selection (Baud Rate generator Input Clock

+#define 	AT91C_US_CHRL_5_BITS               (0x0 <<  6) // (USART) Character Length: 5 bits

+#define 	AT91C_US_CHRL_6_BITS               (0x1 <<  6) // (USART) Character Length: 6 bits

+#define 	AT91C_US_CHRL_7_BITS               (0x2 <<  6) // (USART) Character Length: 7 bits

+#define 	AT91C_US_CHRL_8_BITS               (0x3 <<  6) // (USART) Character Length: 8 bits

+#define AT91C_US_SYNC             (0x1 <<  8) // (USART) Synchronous Mode Select

+#define AT91C_US_NBSTOP           (0x3 << 12) // (USART) Number of Stop bits

+#define 	AT91C_US_NBSTOP_1_BIT                (0x0 << 12) // (USART) 1 stop bit

+#define 	AT91C_US_NBSTOP_15_BIT               (0x1 << 12) // (USART) Asynchronous (SYNC=0) 2 stop bits Synchronous (SYNC=1) 2 stop bits

+#define 	AT91C_US_NBSTOP_2_BIT                (0x2 << 12) // (USART) 2 stop bits

+#define AT91C_US_MSBF             (0x1 << 16) // (USART) Bit Order

+#define AT91C_US_MODE9            (0x1 << 17) // (USART) 9-bit Character length

+#define AT91C_US_CKLO             (0x1 << 18) // (USART) Clock Output Select

+#define AT91C_US_OVER             (0x1 << 19) // (USART) Over Sampling Mode

+#define AT91C_US_INACK            (0x1 << 20) // (USART) Inhibit Non Acknowledge

+#define AT91C_US_DSNACK           (0x1 << 21) // (USART) Disable Successive NACK

+#define AT91C_US_MAX_ITER         (0x1 << 24) // (USART) Number of Repetitions

+#define AT91C_US_FILTER           (0x1 << 28) // (USART) Receive Line Filter

+// -------- US_IER : (USART Offset: 0x8) Debug Unit Interrupt Enable Register -------- 

+#define AT91C_US_RXBRK            (0x1 <<  2) // (USART) Break Received/End of Break

+#define AT91C_US_TIMEOUT          (0x1 <<  8) // (USART) Receiver Time-out

+#define AT91C_US_ITERATION        (0x1 << 10) // (USART) Max number of Repetitions Reached

+#define AT91C_US_NACK             (0x1 << 13) // (USART) Non Acknowledge

+#define AT91C_US_RIIC             (0x1 << 16) // (USART) Ring INdicator Input Change Flag

+#define AT91C_US_DSRIC            (0x1 << 17) // (USART) Data Set Ready Input Change Flag

+#define AT91C_US_DCDIC            (0x1 << 18) // (USART) Data Carrier Flag

+#define AT91C_US_CTSIC            (0x1 << 19) // (USART) Clear To Send Input Change Flag

+// -------- US_IDR : (USART Offset: 0xc) Debug Unit Interrupt Disable Register -------- 

+// -------- US_IMR : (USART Offset: 0x10) Debug Unit Interrupt Mask Register -------- 

+// -------- US_CSR : (USART Offset: 0x14) Debug Unit Channel Status Register -------- 

+#define AT91C_US_RI               (0x1 << 20) // (USART) Image of RI Input

+#define AT91C_US_DSR              (0x1 << 21) // (USART) Image of DSR Input

+#define AT91C_US_DCD              (0x1 << 22) // (USART) Image of DCD Input

+#define AT91C_US_CTS              (0x1 << 23) // (USART) Image of CTS Input

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Synchronous Serial Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_SSC structure ***

+#define SSC_CR          ( 0) // Control Register

+#define SSC_CMR         ( 4) // Clock Mode Register

+#define SSC_RCMR        (16) // Receive Clock ModeRegister

+#define SSC_RFMR        (20) // Receive Frame Mode Register

+#define SSC_TCMR        (24) // Transmit Clock Mode Register

+#define SSC_TFMR        (28) // Transmit Frame Mode Register

+#define SSC_RHR         (32) // Receive Holding Register

+#define SSC_THR         (36) // Transmit Holding Register

+#define SSC_RSHR        (48) // Receive Sync Holding Register

+#define SSC_TSHR        (52) // Transmit Sync Holding Register

+#define SSC_SR          (64) // Status Register

+#define SSC_IER         (68) // Interrupt Enable Register

+#define SSC_IDR         (72) // Interrupt Disable Register

+#define SSC_IMR         (76) // Interrupt Mask Register

+#define SSC_RPR         (256) // Receive Pointer Register

+#define SSC_RCR         (260) // Receive Counter Register

+#define SSC_TPR         (264) // Transmit Pointer Register

+#define SSC_TCR         (268) // Transmit Counter Register

+#define SSC_RNPR        (272) // Receive Next Pointer Register

+#define SSC_RNCR        (276) // Receive Next Counter Register

+#define SSC_TNPR        (280) // Transmit Next Pointer Register

+#define SSC_TNCR        (284) // Transmit Next Counter Register

+#define SSC_PTCR        (288) // PDC Transfer Control Register

+#define SSC_PTSR        (292) // PDC Transfer Status Register

+// -------- SSC_CR : (SSC Offset: 0x0) SSC Control Register -------- 

+#define AT91C_SSC_RXEN            (0x1 <<  0) // (SSC) Receive Enable

+#define AT91C_SSC_RXDIS           (0x1 <<  1) // (SSC) Receive Disable

+#define AT91C_SSC_TXEN            (0x1 <<  8) // (SSC) Transmit Enable

+#define AT91C_SSC_TXDIS           (0x1 <<  9) // (SSC) Transmit Disable

+#define AT91C_SSC_SWRST           (0x1 << 15) // (SSC) Software Reset

+// -------- SSC_RCMR : (SSC Offset: 0x10) SSC Receive Clock Mode Register -------- 

+#define AT91C_SSC_CKS             (0x3 <<  0) // (SSC) Receive/Transmit Clock Selection

+#define 	AT91C_SSC_CKS_DIV                  (0x0) // (SSC) Divided Clock

+#define 	AT91C_SSC_CKS_TK                   (0x1) // (SSC) TK Clock signal

+#define 	AT91C_SSC_CKS_RK                   (0x2) // (SSC) RK pin

+#define AT91C_SSC_CKO             (0x7 <<  2) // (SSC) Receive/Transmit Clock Output Mode Selection

+#define 	AT91C_SSC_CKO_NONE                 (0x0 <<  2) // (SSC) Receive/Transmit Clock Output Mode: None RK pin: Input-only

+#define 	AT91C_SSC_CKO_CONTINOUS            (0x1 <<  2) // (SSC) Continuous Receive/Transmit Clock RK pin: Output

+#define 	AT91C_SSC_CKO_DATA_TX              (0x2 <<  2) // (SSC) Receive/Transmit Clock only during data transfers RK pin: Output

+#define AT91C_SSC_CKI             (0x1 <<  5) // (SSC) Receive/Transmit Clock Inversion

+#define AT91C_SSC_START           (0xF <<  8) // (SSC) Receive/Transmit Start Selection

+#define 	AT91C_SSC_START_CONTINOUS            (0x0 <<  8) // (SSC) Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data.

+#define 	AT91C_SSC_START_TX                   (0x1 <<  8) // (SSC) Transmit/Receive start

+#define 	AT91C_SSC_START_LOW_RF               (0x2 <<  8) // (SSC) Detection of a low level on RF input

+#define 	AT91C_SSC_START_HIGH_RF              (0x3 <<  8) // (SSC) Detection of a high level on RF input

+#define 	AT91C_SSC_START_FALL_RF              (0x4 <<  8) // (SSC) Detection of a falling edge on RF input

+#define 	AT91C_SSC_START_RISE_RF              (0x5 <<  8) // (SSC) Detection of a rising edge on RF input

+#define 	AT91C_SSC_START_LEVEL_RF             (0x6 <<  8) // (SSC) Detection of any level change on RF input

+#define 	AT91C_SSC_START_EDGE_RF              (0x7 <<  8) // (SSC) Detection of any edge on RF input

+#define 	AT91C_SSC_START_0                    (0x8 <<  8) // (SSC) Compare 0

+#define AT91C_SSC_STTDLY          (0xFF << 16) // (SSC) Receive/Transmit Start Delay

+#define AT91C_SSC_PERIOD          (0xFF << 24) // (SSC) Receive/Transmit Period Divider Selection

+// -------- SSC_RFMR : (SSC Offset: 0x14) SSC Receive Frame Mode Register -------- 

+#define AT91C_SSC_DATLEN          (0x1F <<  0) // (SSC) Data Length

+#define AT91C_SSC_LOOP            (0x1 <<  5) // (SSC) Loop Mode

+#define AT91C_SSC_MSBF            (0x1 <<  7) // (SSC) Most Significant Bit First

+#define AT91C_SSC_DATNB           (0xF <<  8) // (SSC) Data Number per Frame

+#define AT91C_SSC_FSLEN           (0xF << 16) // (SSC) Receive/Transmit Frame Sync length

+#define AT91C_SSC_FSOS            (0x7 << 20) // (SSC) Receive/Transmit Frame Sync Output Selection

+#define 	AT91C_SSC_FSOS_NONE                 (0x0 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: None RK pin Input-only

+#define 	AT91C_SSC_FSOS_NEGATIVE             (0x1 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Negative Pulse

+#define 	AT91C_SSC_FSOS_POSITIVE             (0x2 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Positive Pulse

+#define 	AT91C_SSC_FSOS_LOW                  (0x3 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver Low during data transfer

+#define 	AT91C_SSC_FSOS_HIGH                 (0x4 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Driver High during data transfer

+#define 	AT91C_SSC_FSOS_TOGGLE               (0x5 << 20) // (SSC) Selected Receive/Transmit Frame Sync Signal: Toggling at each start of data transfer

+#define AT91C_SSC_FSEDGE          (0x1 << 24) // (SSC) Frame Sync Edge Detection

+// -------- SSC_TCMR : (SSC Offset: 0x18) SSC Transmit Clock Mode Register -------- 

+// -------- SSC_TFMR : (SSC Offset: 0x1c) SSC Transmit Frame Mode Register -------- 

+#define AT91C_SSC_DATDEF          (0x1 <<  5) // (SSC) Data Default Value

+#define AT91C_SSC_FSDEN           (0x1 << 23) // (SSC) Frame Sync Data Enable

+// -------- SSC_SR : (SSC Offset: 0x40) SSC Status Register -------- 

+#define AT91C_SSC_TXRDY           (0x1 <<  0) // (SSC) Transmit Ready

+#define AT91C_SSC_TXEMPTY         (0x1 <<  1) // (SSC) Transmit Empty

+#define AT91C_SSC_ENDTX           (0x1 <<  2) // (SSC) End Of Transmission

+#define AT91C_SSC_TXBUFE          (0x1 <<  3) // (SSC) Transmit Buffer Empty

+#define AT91C_SSC_RXRDY           (0x1 <<  4) // (SSC) Receive Ready

+#define AT91C_SSC_OVRUN           (0x1 <<  5) // (SSC) Receive Overrun

+#define AT91C_SSC_ENDRX           (0x1 <<  6) // (SSC) End of Reception

+#define AT91C_SSC_RXBUFF          (0x1 <<  7) // (SSC) Receive Buffer Full

+#define AT91C_SSC_TXSYN           (0x1 << 10) // (SSC) Transmit Sync

+#define AT91C_SSC_RXSYN           (0x1 << 11) // (SSC) Receive Sync

+#define AT91C_SSC_TXENA           (0x1 << 16) // (SSC) Transmit Enable

+#define AT91C_SSC_RXENA           (0x1 << 17) // (SSC) Receive Enable

+// -------- SSC_IER : (SSC Offset: 0x44) SSC Interrupt Enable Register -------- 

+// -------- SSC_IDR : (SSC Offset: 0x48) SSC Interrupt Disable Register -------- 

+// -------- SSC_IMR : (SSC Offset: 0x4c) SSC Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Two-wire Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TWI structure ***

+#define TWI_CR          ( 0) // Control Register

+#define TWI_MMR         ( 4) // Master Mode Register

+#define TWI_IADR        (12) // Internal Address Register

+#define TWI_CWGR        (16) // Clock Waveform Generator Register

+#define TWI_SR          (32) // Status Register

+#define TWI_IER         (36) // Interrupt Enable Register

+#define TWI_IDR         (40) // Interrupt Disable Register

+#define TWI_IMR         (44) // Interrupt Mask Register

+#define TWI_RHR         (48) // Receive Holding Register

+#define TWI_THR         (52) // Transmit Holding Register

+// -------- TWI_CR : (TWI Offset: 0x0) TWI Control Register -------- 

+#define AT91C_TWI_START           (0x1 <<  0) // (TWI) Send a START Condition

+#define AT91C_TWI_STOP            (0x1 <<  1) // (TWI) Send a STOP Condition

+#define AT91C_TWI_MSEN            (0x1 <<  2) // (TWI) TWI Master Transfer Enabled

+#define AT91C_TWI_MSDIS           (0x1 <<  3) // (TWI) TWI Master Transfer Disabled

+#define AT91C_TWI_SWRST           (0x1 <<  7) // (TWI) Software Reset

+// -------- TWI_MMR : (TWI Offset: 0x4) TWI Master Mode Register -------- 

+#define AT91C_TWI_IADRSZ          (0x3 <<  8) // (TWI) Internal Device Address Size

+#define 	AT91C_TWI_IADRSZ_NO                   (0x0 <<  8) // (TWI) No internal device address

+#define 	AT91C_TWI_IADRSZ_1_BYTE               (0x1 <<  8) // (TWI) One-byte internal device address

+#define 	AT91C_TWI_IADRSZ_2_BYTE               (0x2 <<  8) // (TWI) Two-byte internal device address

+#define 	AT91C_TWI_IADRSZ_3_BYTE               (0x3 <<  8) // (TWI) Three-byte internal device address

+#define AT91C_TWI_MREAD           (0x1 << 12) // (TWI) Master Read Direction

+#define AT91C_TWI_DADR            (0x7F << 16) // (TWI) Device Address

+// -------- TWI_CWGR : (TWI Offset: 0x10) TWI Clock Waveform Generator Register -------- 

+#define AT91C_TWI_CLDIV           (0xFF <<  0) // (TWI) Clock Low Divider

+#define AT91C_TWI_CHDIV           (0xFF <<  8) // (TWI) Clock High Divider

+#define AT91C_TWI_CKDIV           (0x7 << 16) // (TWI) Clock Divider

+// -------- TWI_SR : (TWI Offset: 0x20) TWI Status Register -------- 

+#define AT91C_TWI_TXCOMP          (0x1 <<  0) // (TWI) Transmission Completed

+#define AT91C_TWI_RXRDY           (0x1 <<  1) // (TWI) Receive holding register ReaDY

+#define AT91C_TWI_TXRDY           (0x1 <<  2) // (TWI) Transmit holding register ReaDY

+#define AT91C_TWI_OVRE            (0x1 <<  6) // (TWI) Overrun Error

+#define AT91C_TWI_UNRE            (0x1 <<  7) // (TWI) Underrun Error

+#define AT91C_TWI_NACK            (0x1 <<  8) // (TWI) Not Acknowledged

+// -------- TWI_IER : (TWI Offset: 0x24) TWI Interrupt Enable Register -------- 

+// -------- TWI_IDR : (TWI Offset: 0x28) TWI Interrupt Disable Register -------- 

+// -------- TWI_IMR : (TWI Offset: 0x2c) TWI Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR PWMC Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC_CH structure ***

+#define PWMC_CMR        ( 0) // Channel Mode Register

+#define PWMC_CDTYR      ( 4) // Channel Duty Cycle Register

+#define PWMC_CPRDR      ( 8) // Channel Period Register

+#define PWMC_CCNTR      (12) // Channel Counter Register

+#define PWMC_CUPDR      (16) // Channel Update Register

+#define PWMC_Reserved   (20) // Reserved

+// -------- PWMC_CMR : (PWMC_CH Offset: 0x0) PWMC Channel Mode Register -------- 

+#define AT91C_PWMC_CPRE           (0xF <<  0) // (PWMC_CH) Channel Pre-scaler : PWMC_CLKx

+#define 	AT91C_PWMC_CPRE_MCK                  (0x0) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKA                 (0xB) // (PWMC_CH) 

+#define 	AT91C_PWMC_CPRE_MCKB                 (0xC) // (PWMC_CH) 

+#define AT91C_PWMC_CALG           (0x1 <<  8) // (PWMC_CH) Channel Alignment

+#define AT91C_PWMC_CPOL           (0x1 <<  9) // (PWMC_CH) Channel Polarity

+#define AT91C_PWMC_CPD            (0x1 << 10) // (PWMC_CH) Channel Update Period

+// -------- PWMC_CDTYR : (PWMC_CH Offset: 0x4) PWMC Channel Duty Cycle Register -------- 

+#define AT91C_PWMC_CDTY           (0x0 <<  0) // (PWMC_CH) Channel Duty Cycle

+// -------- PWMC_CPRDR : (PWMC_CH Offset: 0x8) PWMC Channel Period Register -------- 

+#define AT91C_PWMC_CPRD           (0x0 <<  0) // (PWMC_CH) Channel Period

+// -------- PWMC_CCNTR : (PWMC_CH Offset: 0xc) PWMC Channel Counter Register -------- 

+#define AT91C_PWMC_CCNT           (0x0 <<  0) // (PWMC_CH) Channel Counter

+// -------- PWMC_CUPDR : (PWMC_CH Offset: 0x10) PWMC Channel Update Register -------- 

+#define AT91C_PWMC_CUPD           (0x0 <<  0) // (PWMC_CH) Channel Update

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Pulse Width Modulation Controller Interface

+// *****************************************************************************

+// *** Register offset in AT91S_PWMC structure ***

+#define PWMC_MR         ( 0) // PWMC Mode Register

+#define PWMC_ENA        ( 4) // PWMC Enable Register

+#define PWMC_DIS        ( 8) // PWMC Disable Register

+#define PWMC_SR         (12) // PWMC Status Register

+#define PWMC_IER        (16) // PWMC Interrupt Enable Register

+#define PWMC_IDR        (20) // PWMC Interrupt Disable Register

+#define PWMC_IMR        (24) // PWMC Interrupt Mask Register

+#define PWMC_ISR        (28) // PWMC Interrupt Status Register

+#define PWMC_VR         (252) // PWMC Version Register

+#define PWMC_CH         (512) // PWMC Channel

+// -------- PWMC_MR : (PWMC Offset: 0x0) PWMC Mode Register -------- 

+#define AT91C_PWMC_DIVA           (0xFF <<  0) // (PWMC) CLKA divide factor.

+#define AT91C_PWMC_PREA           (0xF <<  8) // (PWMC) Divider Input Clock Prescaler A

+#define 	AT91C_PWMC_PREA_MCK                  (0x0 <<  8) // (PWMC) 

+#define AT91C_PWMC_DIVB           (0xFF << 16) // (PWMC) CLKB divide factor.

+#define AT91C_PWMC_PREB           (0xF << 24) // (PWMC) Divider Input Clock Prescaler B

+#define 	AT91C_PWMC_PREB_MCK                  (0x0 << 24) // (PWMC) 

+// -------- PWMC_ENA : (PWMC Offset: 0x4) PWMC Enable Register -------- 

+#define AT91C_PWMC_CHID0          (0x1 <<  0) // (PWMC) Channel ID 0

+#define AT91C_PWMC_CHID1          (0x1 <<  1) // (PWMC) Channel ID 1

+#define AT91C_PWMC_CHID2          (0x1 <<  2) // (PWMC) Channel ID 2

+#define AT91C_PWMC_CHID3          (0x1 <<  3) // (PWMC) Channel ID 3

+// -------- PWMC_DIS : (PWMC Offset: 0x8) PWMC Disable Register -------- 

+// -------- PWMC_SR : (PWMC Offset: 0xc) PWMC Status Register -------- 

+// -------- PWMC_IER : (PWMC Offset: 0x10) PWMC Interrupt Enable Register -------- 

+// -------- PWMC_IDR : (PWMC Offset: 0x14) PWMC Interrupt Disable Register -------- 

+// -------- PWMC_IMR : (PWMC Offset: 0x18) PWMC Interrupt Mask Register -------- 

+// -------- PWMC_ISR : (PWMC Offset: 0x1c) PWMC Interrupt Status Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR USB Device Interface

+// *****************************************************************************

+// *** Register offset in AT91S_UDP structure ***

+#define UDP_NUM         ( 0) // Frame Number Register

+#define UDP_GLBSTATE    ( 4) // Global State Register

+#define UDP_FADDR       ( 8) // Function Address Register

+#define UDP_IER         (16) // Interrupt Enable Register

+#define UDP_IDR         (20) // Interrupt Disable Register

+#define UDP_IMR         (24) // Interrupt Mask Register

+#define UDP_ISR         (28) // Interrupt Status Register

+#define UDP_ICR         (32) // Interrupt Clear Register

+#define UDP_RSTEP       (40) // Reset Endpoint Register

+#define UDP_CSR         (48) // Endpoint Control and Status Register

+#define UDP_FDR         (80) // Endpoint FIFO Data Register

+#define UDP_TXVC        (116) // Transceiver Control Register

+// -------- UDP_FRM_NUM : (UDP Offset: 0x0) USB Frame Number Register -------- 

+#define AT91C_UDP_FRM_NUM         (0x7FF <<  0) // (UDP) Frame Number as Defined in the Packet Field Formats

+#define AT91C_UDP_FRM_ERR         (0x1 << 16) // (UDP) Frame Error

+#define AT91C_UDP_FRM_OK          (0x1 << 17) // (UDP) Frame OK

+// -------- UDP_GLB_STATE : (UDP Offset: 0x4) USB Global State Register -------- 

+#define AT91C_UDP_FADDEN          (0x1 <<  0) // (UDP) Function Address Enable

+#define AT91C_UDP_CONFG           (0x1 <<  1) // (UDP) Configured

+#define AT91C_UDP_ESR             (0x1 <<  2) // (UDP) Enable Send Resume

+#define AT91C_UDP_RSMINPR         (0x1 <<  3) // (UDP) A Resume Has Been Sent to the Host

+#define AT91C_UDP_RMWUPE          (0x1 <<  4) // (UDP) Remote Wake Up Enable

+// -------- UDP_FADDR : (UDP Offset: 0x8) USB Function Address Register -------- 

+#define AT91C_UDP_FADD            (0xFF <<  0) // (UDP) Function Address Value

+#define AT91C_UDP_FEN             (0x1 <<  8) // (UDP) Function Enable

+// -------- UDP_IER : (UDP Offset: 0x10) USB Interrupt Enable Register -------- 

+#define AT91C_UDP_EPINT0          (0x1 <<  0) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT1          (0x1 <<  1) // (UDP) Endpoint 0 Interrupt

+#define AT91C_UDP_EPINT2          (0x1 <<  2) // (UDP) Endpoint 2 Interrupt

+#define AT91C_UDP_EPINT3          (0x1 <<  3) // (UDP) Endpoint 3 Interrupt

+#define AT91C_UDP_EPINT4          (0x1 <<  4) // (UDP) Endpoint 4 Interrupt

+#define AT91C_UDP_EPINT5          (0x1 <<  5) // (UDP) Endpoint 5 Interrupt

+#define AT91C_UDP_RXSUSP          (0x1 <<  8) // (UDP) USB Suspend Interrupt

+#define AT91C_UDP_RXRSM           (0x1 <<  9) // (UDP) USB Resume Interrupt

+#define AT91C_UDP_EXTRSM          (0x1 << 10) // (UDP) USB External Resume Interrupt

+#define AT91C_UDP_SOFINT          (0x1 << 11) // (UDP) USB Start Of frame Interrupt

+#define AT91C_UDP_WAKEUP          (0x1 << 13) // (UDP) USB Resume Interrupt

+// -------- UDP_IDR : (UDP Offset: 0x14) USB Interrupt Disable Register -------- 

+// -------- UDP_IMR : (UDP Offset: 0x18) USB Interrupt Mask Register -------- 

+// -------- UDP_ISR : (UDP Offset: 0x1c) USB Interrupt Status Register -------- 

+#define AT91C_UDP_ENDBUSRES       (0x1 << 12) // (UDP) USB End Of Bus Reset Interrupt

+// -------- UDP_ICR : (UDP Offset: 0x20) USB Interrupt Clear Register -------- 

+// -------- UDP_RST_EP : (UDP Offset: 0x28) USB Reset Endpoint Register -------- 

+#define AT91C_UDP_EP0             (0x1 <<  0) // (UDP) Reset Endpoint 0

+#define AT91C_UDP_EP1             (0x1 <<  1) // (UDP) Reset Endpoint 1

+#define AT91C_UDP_EP2             (0x1 <<  2) // (UDP) Reset Endpoint 2

+#define AT91C_UDP_EP3             (0x1 <<  3) // (UDP) Reset Endpoint 3

+#define AT91C_UDP_EP4             (0x1 <<  4) // (UDP) Reset Endpoint 4

+#define AT91C_UDP_EP5             (0x1 <<  5) // (UDP) Reset Endpoint 5

+// -------- UDP_CSR : (UDP Offset: 0x30) USB Endpoint Control and Status Register -------- 

+#define AT91C_UDP_TXCOMP          (0x1 <<  0) // (UDP) Generates an IN packet with data previously written in the DPR

+#define AT91C_UDP_RX_DATA_BK0     (0x1 <<  1) // (UDP) Receive Data Bank 0

+#define AT91C_UDP_RXSETUP         (0x1 <<  2) // (UDP) Sends STALL to the Host (Control endpoints)

+#define AT91C_UDP_ISOERROR        (0x1 <<  3) // (UDP) Isochronous error (Isochronous endpoints)

+#define AT91C_UDP_TXPKTRDY        (0x1 <<  4) // (UDP) Transmit Packet Ready

+#define AT91C_UDP_FORCESTALL      (0x1 <<  5) // (UDP) Force Stall (used by Control, Bulk and Isochronous endpoints).

+#define AT91C_UDP_RX_DATA_BK1     (0x1 <<  6) // (UDP) Receive Data Bank 1 (only used by endpoints with ping-pong attributes).

+#define AT91C_UDP_DIR             (0x1 <<  7) // (UDP) Transfer Direction

+#define AT91C_UDP_EPTYPE          (0x7 <<  8) // (UDP) Endpoint type

+#define 	AT91C_UDP_EPTYPE_CTRL                 (0x0 <<  8) // (UDP) Control

+#define 	AT91C_UDP_EPTYPE_ISO_OUT              (0x1 <<  8) // (UDP) Isochronous OUT

+#define 	AT91C_UDP_EPTYPE_BULK_OUT             (0x2 <<  8) // (UDP) Bulk OUT

+#define 	AT91C_UDP_EPTYPE_INT_OUT              (0x3 <<  8) // (UDP) Interrupt OUT

+#define 	AT91C_UDP_EPTYPE_ISO_IN               (0x5 <<  8) // (UDP) Isochronous IN

+#define 	AT91C_UDP_EPTYPE_BULK_IN              (0x6 <<  8) // (UDP) Bulk IN

+#define 	AT91C_UDP_EPTYPE_INT_IN               (0x7 <<  8) // (UDP) Interrupt IN

+#define AT91C_UDP_DTGLE           (0x1 << 11) // (UDP) Data Toggle

+#define AT91C_UDP_EPEDS           (0x1 << 15) // (UDP) Endpoint Enable Disable

+#define AT91C_UDP_RXBYTECNT       (0x7FF << 16) // (UDP) Number Of Bytes Available in the FIFO

+// -------- UDP_TXVC : (UDP Offset: 0x74) Transceiver Control Register -------- 

+#define AT91C_UDP_TXVDIS          (0x1 <<  8) // (UDP) 

+#define AT91C_UDP_PUON            (0x1 <<  9) // (UDP) Pull-up ON

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Channel Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TC structure ***

+#define TC_CCR          ( 0) // Channel Control Register

+#define TC_CMR          ( 4) // Channel Mode Register (Capture Mode / Waveform Mode)

+#define TC_CV           (16) // Counter Value

+#define TC_RA           (20) // Register A

+#define TC_RB           (24) // Register B

+#define TC_RC           (28) // Register C

+#define TC_SR           (32) // Status Register

+#define TC_IER          (36) // Interrupt Enable Register

+#define TC_IDR          (40) // Interrupt Disable Register

+#define TC_IMR          (44) // Interrupt Mask Register

+// -------- TC_CCR : (TC Offset: 0x0) TC Channel Control Register -------- 

+#define AT91C_TC_CLKEN            (0x1 <<  0) // (TC) Counter Clock Enable Command

+#define AT91C_TC_CLKDIS           (0x1 <<  1) // (TC) Counter Clock Disable Command

+#define AT91C_TC_SWTRG            (0x1 <<  2) // (TC) Software Trigger Command

+// -------- TC_CMR : (TC Offset: 0x4) TC Channel Mode Register: Capture Mode / Waveform Mode -------- 

+#define AT91C_TC_CLKS             (0x7 <<  0) // (TC) Clock Selection

+#define 	AT91C_TC_CLKS_TIMER_DIV1_CLOCK     (0x0) // (TC) Clock selected: TIMER_DIV1_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV2_CLOCK     (0x1) // (TC) Clock selected: TIMER_DIV2_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV3_CLOCK     (0x2) // (TC) Clock selected: TIMER_DIV3_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV4_CLOCK     (0x3) // (TC) Clock selected: TIMER_DIV4_CLOCK

+#define 	AT91C_TC_CLKS_TIMER_DIV5_CLOCK     (0x4) // (TC) Clock selected: TIMER_DIV5_CLOCK

+#define 	AT91C_TC_CLKS_XC0                  (0x5) // (TC) Clock selected: XC0

+#define 	AT91C_TC_CLKS_XC1                  (0x6) // (TC) Clock selected: XC1

+#define 	AT91C_TC_CLKS_XC2                  (0x7) // (TC) Clock selected: XC2

+#define AT91C_TC_CLKI             (0x1 <<  3) // (TC) Clock Invert

+#define AT91C_TC_BURST            (0x3 <<  4) // (TC) Burst Signal Selection

+#define 	AT91C_TC_BURST_NONE                 (0x0 <<  4) // (TC) The clock is not gated by an external signal

+#define 	AT91C_TC_BURST_XC0                  (0x1 <<  4) // (TC) XC0 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC1                  (0x2 <<  4) // (TC) XC1 is ANDed with the selected clock

+#define 	AT91C_TC_BURST_XC2                  (0x3 <<  4) // (TC) XC2 is ANDed with the selected clock

+#define AT91C_TC_CPCSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RC Compare

+#define AT91C_TC_LDBSTOP          (0x1 <<  6) // (TC) Counter Clock Stopped with RB Loading

+#define AT91C_TC_CPCDIS           (0x1 <<  7) // (TC) Counter Clock Disable with RC Compare

+#define AT91C_TC_LDBDIS           (0x1 <<  7) // (TC) Counter Clock Disabled with RB Loading

+#define AT91C_TC_ETRGEDG          (0x3 <<  8) // (TC) External Trigger Edge Selection

+#define 	AT91C_TC_ETRGEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_ETRGEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_ETRGEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_ETRGEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVTEDG          (0x3 <<  8) // (TC) External Event Edge Selection

+#define 	AT91C_TC_EEVTEDG_NONE                 (0x0 <<  8) // (TC) Edge: None

+#define 	AT91C_TC_EEVTEDG_RISING               (0x1 <<  8) // (TC) Edge: rising edge

+#define 	AT91C_TC_EEVTEDG_FALLING              (0x2 <<  8) // (TC) Edge: falling edge

+#define 	AT91C_TC_EEVTEDG_BOTH                 (0x3 <<  8) // (TC) Edge: each edge

+#define AT91C_TC_EEVT             (0x3 << 10) // (TC) External Event  Selection

+#define 	AT91C_TC_EEVT_TIOB                 (0x0 << 10) // (TC) Signal selected as external event: TIOB TIOB direction: input

+#define 	AT91C_TC_EEVT_XC0                  (0x1 << 10) // (TC) Signal selected as external event: XC0 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC1                  (0x2 << 10) // (TC) Signal selected as external event: XC1 TIOB direction: output

+#define 	AT91C_TC_EEVT_XC2                  (0x3 << 10) // (TC) Signal selected as external event: XC2 TIOB direction: output

+#define AT91C_TC_ABETRG           (0x1 << 10) // (TC) TIOA or TIOB External Trigger Selection

+#define AT91C_TC_ENETRG           (0x1 << 12) // (TC) External Event Trigger enable

+#define AT91C_TC_WAVESEL          (0x3 << 13) // (TC) Waveform  Selection

+#define 	AT91C_TC_WAVESEL_UP                   (0x0 << 13) // (TC) UP mode without atomatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN               (0x1 << 13) // (TC) UPDOWN mode without automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UP_AUTO              (0x2 << 13) // (TC) UP mode with automatic trigger on RC Compare

+#define 	AT91C_TC_WAVESEL_UPDOWN_AUTO          (0x3 << 13) // (TC) UPDOWN mode with automatic trigger on RC Compare

+#define AT91C_TC_CPCTRG           (0x1 << 14) // (TC) RC Compare Trigger Enable

+#define AT91C_TC_WAVE             (0x1 << 15) // (TC) 

+#define AT91C_TC_ACPA             (0x3 << 16) // (TC) RA Compare Effect on TIOA

+#define 	AT91C_TC_ACPA_NONE                 (0x0 << 16) // (TC) Effect: none

+#define 	AT91C_TC_ACPA_SET                  (0x1 << 16) // (TC) Effect: set

+#define 	AT91C_TC_ACPA_CLEAR                (0x2 << 16) // (TC) Effect: clear

+#define 	AT91C_TC_ACPA_TOGGLE               (0x3 << 16) // (TC) Effect: toggle

+#define AT91C_TC_LDRA             (0x3 << 16) // (TC) RA Loading Selection

+#define 	AT91C_TC_LDRA_NONE                 (0x0 << 16) // (TC) Edge: None

+#define 	AT91C_TC_LDRA_RISING               (0x1 << 16) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRA_FALLING              (0x2 << 16) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRA_BOTH                 (0x3 << 16) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_ACPC             (0x3 << 18) // (TC) RC Compare Effect on TIOA

+#define 	AT91C_TC_ACPC_NONE                 (0x0 << 18) // (TC) Effect: none

+#define 	AT91C_TC_ACPC_SET                  (0x1 << 18) // (TC) Effect: set

+#define 	AT91C_TC_ACPC_CLEAR                (0x2 << 18) // (TC) Effect: clear

+#define 	AT91C_TC_ACPC_TOGGLE               (0x3 << 18) // (TC) Effect: toggle

+#define AT91C_TC_LDRB             (0x3 << 18) // (TC) RB Loading Selection

+#define 	AT91C_TC_LDRB_NONE                 (0x0 << 18) // (TC) Edge: None

+#define 	AT91C_TC_LDRB_RISING               (0x1 << 18) // (TC) Edge: rising edge of TIOA

+#define 	AT91C_TC_LDRB_FALLING              (0x2 << 18) // (TC) Edge: falling edge of TIOA

+#define 	AT91C_TC_LDRB_BOTH                 (0x3 << 18) // (TC) Edge: each edge of TIOA

+#define AT91C_TC_AEEVT            (0x3 << 20) // (TC) External Event Effect on TIOA

+#define 	AT91C_TC_AEEVT_NONE                 (0x0 << 20) // (TC) Effect: none

+#define 	AT91C_TC_AEEVT_SET                  (0x1 << 20) // (TC) Effect: set

+#define 	AT91C_TC_AEEVT_CLEAR                (0x2 << 20) // (TC) Effect: clear

+#define 	AT91C_TC_AEEVT_TOGGLE               (0x3 << 20) // (TC) Effect: toggle

+#define AT91C_TC_ASWTRG           (0x3 << 22) // (TC) Software Trigger Effect on TIOA

+#define 	AT91C_TC_ASWTRG_NONE                 (0x0 << 22) // (TC) Effect: none

+#define 	AT91C_TC_ASWTRG_SET                  (0x1 << 22) // (TC) Effect: set

+#define 	AT91C_TC_ASWTRG_CLEAR                (0x2 << 22) // (TC) Effect: clear

+#define 	AT91C_TC_ASWTRG_TOGGLE               (0x3 << 22) // (TC) Effect: toggle

+#define AT91C_TC_BCPB             (0x3 << 24) // (TC) RB Compare Effect on TIOB

+#define 	AT91C_TC_BCPB_NONE                 (0x0 << 24) // (TC) Effect: none

+#define 	AT91C_TC_BCPB_SET                  (0x1 << 24) // (TC) Effect: set

+#define 	AT91C_TC_BCPB_CLEAR                (0x2 << 24) // (TC) Effect: clear

+#define 	AT91C_TC_BCPB_TOGGLE               (0x3 << 24) // (TC) Effect: toggle

+#define AT91C_TC_BCPC             (0x3 << 26) // (TC) RC Compare Effect on TIOB

+#define 	AT91C_TC_BCPC_NONE                 (0x0 << 26) // (TC) Effect: none

+#define 	AT91C_TC_BCPC_SET                  (0x1 << 26) // (TC) Effect: set

+#define 	AT91C_TC_BCPC_CLEAR                (0x2 << 26) // (TC) Effect: clear

+#define 	AT91C_TC_BCPC_TOGGLE               (0x3 << 26) // (TC) Effect: toggle

+#define AT91C_TC_BEEVT            (0x3 << 28) // (TC) External Event Effect on TIOB

+#define 	AT91C_TC_BEEVT_NONE                 (0x0 << 28) // (TC) Effect: none

+#define 	AT91C_TC_BEEVT_SET                  (0x1 << 28) // (TC) Effect: set

+#define 	AT91C_TC_BEEVT_CLEAR                (0x2 << 28) // (TC) Effect: clear

+#define 	AT91C_TC_BEEVT_TOGGLE               (0x3 << 28) // (TC) Effect: toggle

+#define AT91C_TC_BSWTRG           (0x3 << 30) // (TC) Software Trigger Effect on TIOB

+#define 	AT91C_TC_BSWTRG_NONE                 (0x0 << 30) // (TC) Effect: none

+#define 	AT91C_TC_BSWTRG_SET                  (0x1 << 30) // (TC) Effect: set

+#define 	AT91C_TC_BSWTRG_CLEAR                (0x2 << 30) // (TC) Effect: clear

+#define 	AT91C_TC_BSWTRG_TOGGLE               (0x3 << 30) // (TC) Effect: toggle

+// -------- TC_SR : (TC Offset: 0x20) TC Channel Status Register -------- 

+#define AT91C_TC_COVFS            (0x1 <<  0) // (TC) Counter Overflow

+#define AT91C_TC_LOVRS            (0x1 <<  1) // (TC) Load Overrun

+#define AT91C_TC_CPAS             (0x1 <<  2) // (TC) RA Compare

+#define AT91C_TC_CPBS             (0x1 <<  3) // (TC) RB Compare

+#define AT91C_TC_CPCS             (0x1 <<  4) // (TC) RC Compare

+#define AT91C_TC_LDRAS            (0x1 <<  5) // (TC) RA Loading

+#define AT91C_TC_LDRBS            (0x1 <<  6) // (TC) RB Loading

+#define AT91C_TC_ETRGS            (0x1 <<  7) // (TC) External Trigger

+#define AT91C_TC_CLKSTA           (0x1 << 16) // (TC) Clock Enabling

+#define AT91C_TC_MTIOA            (0x1 << 17) // (TC) TIOA Mirror

+#define AT91C_TC_MTIOB            (0x1 << 18) // (TC) TIOA Mirror

+// -------- TC_IER : (TC Offset: 0x24) TC Channel Interrupt Enable Register -------- 

+// -------- TC_IDR : (TC Offset: 0x28) TC Channel Interrupt Disable Register -------- 

+// -------- TC_IMR : (TC Offset: 0x2c) TC Channel Interrupt Mask Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Timer Counter Interface

+// *****************************************************************************

+// *** Register offset in AT91S_TCB structure ***

+#define TCB_TC0         ( 0) // TC Channel 0

+#define TCB_TC1         (64) // TC Channel 1

+#define TCB_TC2         (128) // TC Channel 2

+#define TCB_BCR         (192) // TC Block Control Register

+#define TCB_BMR         (196) // TC Block Mode Register

+// -------- TCB_BCR : (TCB Offset: 0xc0) TC Block Control Register -------- 

+#define AT91C_TCB_SYNC            (0x1 <<  0) // (TCB) Synchro Command

+// -------- TCB_BMR : (TCB Offset: 0xc4) TC Block Mode Register -------- 

+#define AT91C_TCB_TC0XC0S         (0x3 <<  0) // (TCB) External Clock Signal 0 Selection

+#define 	AT91C_TCB_TC0XC0S_TCLK0                (0x0) // (TCB) TCLK0 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_NONE                 (0x1) // (TCB) None signal connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA1                (0x2) // (TCB) TIOA1 connected to XC0

+#define 	AT91C_TCB_TC0XC0S_TIOA2                (0x3) // (TCB) TIOA2 connected to XC0

+#define AT91C_TCB_TC1XC1S         (0x3 <<  2) // (TCB) External Clock Signal 1 Selection

+#define 	AT91C_TCB_TC1XC1S_TCLK1                (0x0 <<  2) // (TCB) TCLK1 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_NONE                 (0x1 <<  2) // (TCB) None signal connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA0                (0x2 <<  2) // (TCB) TIOA0 connected to XC1

+#define 	AT91C_TCB_TC1XC1S_TIOA2                (0x3 <<  2) // (TCB) TIOA2 connected to XC1

+#define AT91C_TCB_TC2XC2S         (0x3 <<  4) // (TCB) External Clock Signal 2 Selection

+#define 	AT91C_TCB_TC2XC2S_TCLK2                (0x0 <<  4) // (TCB) TCLK2 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_NONE                 (0x1 <<  4) // (TCB) None signal connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA0                (0x2 <<  4) // (TCB) TIOA0 connected to XC2

+#define 	AT91C_TCB_TC2XC2S_TIOA1                (0x3 <<  4) // (TCB) TIOA2 connected to XC2

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network MailBox Interface

+// *****************************************************************************

+// *** Register offset in AT91S_CAN_MB structure ***

+#define CAN_MB_MMR      ( 0) // MailBox Mode Register

+#define CAN_MB_MAM      ( 4) // MailBox Acceptance Mask Register

+#define CAN_MB_MID      ( 8) // MailBox ID Register

+#define CAN_MB_MFID     (12) // MailBox Family ID Register

+#define CAN_MB_MSR      (16) // MailBox Status Register

+#define CAN_MB_MDL      (20) // MailBox Data Low Register

+#define CAN_MB_MDH      (24) // MailBox Data High Register

+#define CAN_MB_MCR      (28) // MailBox Control Register

+// -------- CAN_MMR : (CAN_MB Offset: 0x0) CAN Message Mode Register -------- 

+#define AT91C_CAN_MTIMEMARK       (0xFFFF <<  0) // (CAN_MB) Mailbox Timemark

+#define AT91C_CAN_PRIOR           (0xF << 16) // (CAN_MB) Mailbox Priority

+#define AT91C_CAN_MOT             (0x7 << 24) // (CAN_MB) Mailbox Object Type

+#define 	AT91C_CAN_MOT_DIS                  (0x0 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RX                   (0x1 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_RXOVERWRITE          (0x2 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_TX                   (0x3 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_CONSUMER             (0x4 << 24) // (CAN_MB) 

+#define 	AT91C_CAN_MOT_PRODUCER             (0x5 << 24) // (CAN_MB) 

+// -------- CAN_MAM : (CAN_MB Offset: 0x4) CAN Message Acceptance Mask Register -------- 

+#define AT91C_CAN_MIDvB           (0x3FFFF <<  0) // (CAN_MB) Complementary bits for identifier in extended mode

+#define AT91C_CAN_MIDvA           (0x7FF << 18) // (CAN_MB) Identifier for standard frame mode

+#define AT91C_CAN_MIDE            (0x1 << 29) // (CAN_MB) Identifier Version

+// -------- CAN_MID : (CAN_MB Offset: 0x8) CAN Message ID Register -------- 

+// -------- CAN_MFID : (CAN_MB Offset: 0xc) CAN Message Family ID Register -------- 

+// -------- CAN_MSR : (CAN_MB Offset: 0x10) CAN Message Status Register -------- 

+#define AT91C_CAN_MTIMESTAMP      (0xFFFF <<  0) // (CAN_MB) Timer Value

+#define AT91C_CAN_MDLC            (0xF << 16) // (CAN_MB) Mailbox Data Length Code

+#define AT91C_CAN_MRTR            (0x1 << 20) // (CAN_MB) Mailbox Remote Transmission Request

+#define AT91C_CAN_MABT            (0x1 << 22) // (CAN_MB) Mailbox Message Abort

+#define AT91C_CAN_MRDY            (0x1 << 23) // (CAN_MB) Mailbox Ready

+#define AT91C_CAN_MMI             (0x1 << 24) // (CAN_MB) Mailbox Message Ignored

+// -------- CAN_MDL : (CAN_MB Offset: 0x14) CAN Message Data Low Register -------- 

+// -------- CAN_MDH : (CAN_MB Offset: 0x18) CAN Message Data High Register -------- 

+// -------- CAN_MCR : (CAN_MB Offset: 0x1c) CAN Message Control Register -------- 

+#define AT91C_CAN_MACR            (0x1 << 22) // (CAN_MB) Abort Request for Mailbox

+#define AT91C_CAN_MTCR            (0x1 << 23) // (CAN_MB) Mailbox Transfer Command

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Control Area Network Interface

+// *****************************************************************************

+// *** Register offset in AT91S_CAN structure ***

+#define CAN_MR          ( 0) // Mode Register

+#define CAN_IER         ( 4) // Interrupt Enable Register

+#define CAN_IDR         ( 8) // Interrupt Disable Register

+#define CAN_IMR         (12) // Interrupt Mask Register

+#define CAN_SR          (16) // Status Register

+#define CAN_BR          (20) // Baudrate Register

+#define CAN_TIM         (24) // Timer Register

+#define CAN_TIMESTP     (28) // Time Stamp Register

+#define CAN_ECR         (32) // Error Counter Register

+#define CAN_TCR         (36) // Transfer Command Register

+#define CAN_ACR         (40) // Abort Command Register

+#define CAN_VR          (252) // Version Register

+#define CAN_MB0         (512) // CAN Mailbox 0

+#define CAN_MB1         (544) // CAN Mailbox 1

+#define CAN_MB2         (576) // CAN Mailbox 2

+#define CAN_MB3         (608) // CAN Mailbox 3

+#define CAN_MB4         (640) // CAN Mailbox 4

+#define CAN_MB5         (672) // CAN Mailbox 5

+#define CAN_MB6         (704) // CAN Mailbox 6

+#define CAN_MB7         (736) // CAN Mailbox 7

+#define CAN_MB8         (768) // CAN Mailbox 8

+#define CAN_MB9         (800) // CAN Mailbox 9

+#define CAN_MB10        (832) // CAN Mailbox 10

+#define CAN_MB11        (864) // CAN Mailbox 11

+#define CAN_MB12        (896) // CAN Mailbox 12

+#define CAN_MB13        (928) // CAN Mailbox 13

+#define CAN_MB14        (960) // CAN Mailbox 14

+#define CAN_MB15        (992) // CAN Mailbox 15

+// -------- CAN_MR : (CAN Offset: 0x0) CAN Mode Register -------- 

+#define AT91C_CAN_CANEN           (0x1 <<  0) // (CAN) CAN Controller Enable

+#define AT91C_CAN_LPM             (0x1 <<  1) // (CAN) Disable/Enable Low Power Mode

+#define AT91C_CAN_ABM             (0x1 <<  2) // (CAN) Disable/Enable Autobaud/Listen Mode

+#define AT91C_CAN_OVL             (0x1 <<  3) // (CAN) Disable/Enable Overload Frame

+#define AT91C_CAN_TEOF            (0x1 <<  4) // (CAN) Time Stamp messages at each end of Frame

+#define AT91C_CAN_TTM             (0x1 <<  5) // (CAN) Disable/Enable Time Trigger Mode

+#define AT91C_CAN_TIMFRZ          (0x1 <<  6) // (CAN) Enable Timer Freeze

+#define AT91C_CAN_DRPT            (0x1 <<  7) // (CAN) Disable Repeat

+// -------- CAN_IER : (CAN Offset: 0x4) CAN Interrupt Enable Register -------- 

+#define AT91C_CAN_MB0             (0x1 <<  0) // (CAN) Mailbox 0 Flag

+#define AT91C_CAN_MB1             (0x1 <<  1) // (CAN) Mailbox 1 Flag

+#define AT91C_CAN_MB2             (0x1 <<  2) // (CAN) Mailbox 2 Flag

+#define AT91C_CAN_MB3             (0x1 <<  3) // (CAN) Mailbox 3 Flag

+#define AT91C_CAN_MB4             (0x1 <<  4) // (CAN) Mailbox 4 Flag

+#define AT91C_CAN_MB5             (0x1 <<  5) // (CAN) Mailbox 5 Flag

+#define AT91C_CAN_MB6             (0x1 <<  6) // (CAN) Mailbox 6 Flag

+#define AT91C_CAN_MB7             (0x1 <<  7) // (CAN) Mailbox 7 Flag

+#define AT91C_CAN_MB8             (0x1 <<  8) // (CAN) Mailbox 8 Flag

+#define AT91C_CAN_MB9             (0x1 <<  9) // (CAN) Mailbox 9 Flag

+#define AT91C_CAN_MB10            (0x1 << 10) // (CAN) Mailbox 10 Flag

+#define AT91C_CAN_MB11            (0x1 << 11) // (CAN) Mailbox 11 Flag

+#define AT91C_CAN_MB12            (0x1 << 12) // (CAN) Mailbox 12 Flag

+#define AT91C_CAN_MB13            (0x1 << 13) // (CAN) Mailbox 13 Flag

+#define AT91C_CAN_MB14            (0x1 << 14) // (CAN) Mailbox 14 Flag

+#define AT91C_CAN_MB15            (0x1 << 15) // (CAN) Mailbox 15 Flag

+#define AT91C_CAN_ERRA            (0x1 << 16) // (CAN) Error Active Mode Flag

+#define AT91C_CAN_WARN            (0x1 << 17) // (CAN) Warning Limit Flag

+#define AT91C_CAN_ERRP            (0x1 << 18) // (CAN) Error Passive Mode Flag

+#define AT91C_CAN_BOFF            (0x1 << 19) // (CAN) Bus Off Mode Flag

+#define AT91C_CAN_SLEEP           (0x1 << 20) // (CAN) Sleep Flag

+#define AT91C_CAN_WAKEUP          (0x1 << 21) // (CAN) Wakeup Flag

+#define AT91C_CAN_TOVF            (0x1 << 22) // (CAN) Timer Overflow Flag

+#define AT91C_CAN_TSTP            (0x1 << 23) // (CAN) Timestamp Flag

+#define AT91C_CAN_CERR            (0x1 << 24) // (CAN) CRC Error

+#define AT91C_CAN_SERR            (0x1 << 25) // (CAN) Stuffing Error

+#define AT91C_CAN_AERR            (0x1 << 26) // (CAN) Acknowledgment Error

+#define AT91C_CAN_FERR            (0x1 << 27) // (CAN) Form Error

+#define AT91C_CAN_BERR            (0x1 << 28) // (CAN) Bit Error

+// -------- CAN_IDR : (CAN Offset: 0x8) CAN Interrupt Disable Register -------- 

+// -------- CAN_IMR : (CAN Offset: 0xc) CAN Interrupt Mask Register -------- 

+// -------- CAN_SR : (CAN Offset: 0x10) CAN Status Register -------- 

+#define AT91C_CAN_RBSY            (0x1 << 29) // (CAN) Receiver Busy

+#define AT91C_CAN_TBSY            (0x1 << 30) // (CAN) Transmitter Busy

+#define AT91C_CAN_OVLY            (0x1 << 31) // (CAN) Overload Busy

+// -------- CAN_BR : (CAN Offset: 0x14) CAN Baudrate Register -------- 

+#define AT91C_CAN_PHASE2          (0x7 <<  0) // (CAN) Phase 2 segment

+#define AT91C_CAN_PHASE1          (0x7 <<  4) // (CAN) Phase 1 segment

+#define AT91C_CAN_PROPAG          (0x7 <<  8) // (CAN) Programmation time segment

+#define AT91C_CAN_SYNC            (0x3 << 12) // (CAN) Re-synchronization jump width segment

+#define AT91C_CAN_BRP             (0x7F << 16) // (CAN) Baudrate Prescaler

+#define AT91C_CAN_SMP             (0x1 << 24) // (CAN) Sampling mode

+// -------- CAN_TIM : (CAN Offset: 0x18) CAN Timer Register -------- 

+#define AT91C_CAN_TIMER           (0xFFFF <<  0) // (CAN) Timer field

+// -------- CAN_TIMESTP : (CAN Offset: 0x1c) CAN Timestamp Register -------- 

+// -------- CAN_ECR : (CAN Offset: 0x20) CAN Error Counter Register -------- 

+#define AT91C_CAN_REC             (0xFF <<  0) // (CAN) Receive Error Counter

+#define AT91C_CAN_TEC             (0xFF << 16) // (CAN) Transmit Error Counter

+// -------- CAN_TCR : (CAN Offset: 0x24) CAN Transfer Command Register -------- 

+#define AT91C_CAN_TIMRST          (0x1 << 31) // (CAN) Timer Reset Field

+// -------- CAN_ACR : (CAN Offset: 0x28) CAN Abort Command Register -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Ethernet MAC 10/100

+// *****************************************************************************

+// *** Register offset in AT91S_EMAC structure ***

+#define EMAC_NCR        ( 0) // Network Control Register

+#define EMAC_NCFGR      ( 4) // Network Configuration Register

+#define EMAC_NSR        ( 8) // Network Status Register

+#define EMAC_TSR        (20) // Transmit Status Register

+#define EMAC_RBQP       (24) // Receive Buffer Queue Pointer

+#define EMAC_TBQP       (28) // Transmit Buffer Queue Pointer

+#define EMAC_RSR        (32) // Receive Status Register

+#define EMAC_ISR        (36) // Interrupt Status Register

+#define EMAC_IER        (40) // Interrupt Enable Register

+#define EMAC_IDR        (44) // Interrupt Disable Register

+#define EMAC_IMR        (48) // Interrupt Mask Register

+#define EMAC_MAN        (52) // PHY Maintenance Register

+#define EMAC_PTR        (56) // Pause Time Register

+#define EMAC_PFR        (60) // Pause Frames received Register

+#define EMAC_FTO        (64) // Frames Transmitted OK Register

+#define EMAC_SCF        (68) // Single Collision Frame Register

+#define EMAC_MCF        (72) // Multiple Collision Frame Register

+#define EMAC_FRO        (76) // Frames Received OK Register

+#define EMAC_FCSE       (80) // Frame Check Sequence Error Register

+#define EMAC_ALE        (84) // Alignment Error Register

+#define EMAC_DTF        (88) // Deferred Transmission Frame Register

+#define EMAC_LCOL       (92) // Late Collision Register

+#define EMAC_ECOL       (96) // Excessive Collision Register

+#define EMAC_TUND       (100) // Transmit Underrun Error Register

+#define EMAC_CSE        (104) // Carrier Sense Error Register

+#define EMAC_RRE        (108) // Receive Ressource Error Register

+#define EMAC_ROV        (112) // Receive Overrun Errors Register

+#define EMAC_RSE        (116) // Receive Symbol Errors Register

+#define EMAC_ELE        (120) // Excessive Length Errors Register

+#define EMAC_RJA        (124) // Receive Jabbers Register

+#define EMAC_USF        (128) // Undersize Frames Register

+#define EMAC_STE        (132) // SQE Test Error Register

+#define EMAC_RLE        (136) // Receive Length Field Mismatch Register

+#define EMAC_TPF        (140) // Transmitted Pause Frames Register

+#define EMAC_HRB        (144) // Hash Address Bottom[31:0]

+#define EMAC_HRT        (148) // Hash Address Top[63:32]

+#define EMAC_SA1L       (152) // Specific Address 1 Bottom, First 4 bytes

+#define EMAC_SA1H       (156) // Specific Address 1 Top, Last 2 bytes

+#define EMAC_SA2L       (160) // Specific Address 2 Bottom, First 4 bytes

+#define EMAC_SA2H       (164) // Specific Address 2 Top, Last 2 bytes

+#define EMAC_SA3L       (168) // Specific Address 3 Bottom, First 4 bytes

+#define EMAC_SA3H       (172) // Specific Address 3 Top, Last 2 bytes

+#define EMAC_SA4L       (176) // Specific Address 4 Bottom, First 4 bytes

+#define EMAC_SA4H       (180) // Specific Address 4 Top, Last 2 bytes

+#define EMAC_TID        (184) // Type ID Checking Register

+#define EMAC_TPQ        (188) // Transmit Pause Quantum Register

+#define EMAC_USRIO      (192) // USER Input/Output Register

+#define EMAC_WOL        (196) // Wake On LAN Register

+#define EMAC_REV        (252) // Revision Register

+// -------- EMAC_NCR : (EMAC Offset: 0x0)  -------- 

+#define AT91C_EMAC_LB             (0x1 <<  0) // (EMAC) Loopback. Optional. When set, loopback signal is at high level.

+#define AT91C_EMAC_LLB            (0x1 <<  1) // (EMAC) Loopback local. 

+#define AT91C_EMAC_RE             (0x1 <<  2) // (EMAC) Receive enable. 

+#define AT91C_EMAC_TE             (0x1 <<  3) // (EMAC) Transmit enable. 

+#define AT91C_EMAC_MPE            (0x1 <<  4) // (EMAC) Management port enable. 

+#define AT91C_EMAC_CLRSTAT        (0x1 <<  5) // (EMAC) Clear statistics registers. 

+#define AT91C_EMAC_INCSTAT        (0x1 <<  6) // (EMAC) Increment statistics registers. 

+#define AT91C_EMAC_WESTAT         (0x1 <<  7) // (EMAC) Write enable for statistics registers. 

+#define AT91C_EMAC_BP             (0x1 <<  8) // (EMAC) Back pressure. 

+#define AT91C_EMAC_TSTART         (0x1 <<  9) // (EMAC) Start Transmission. 

+#define AT91C_EMAC_THALT          (0x1 << 10) // (EMAC) Transmission Halt. 

+#define AT91C_EMAC_TPFR           (0x1 << 11) // (EMAC) Transmit pause frame 

+#define AT91C_EMAC_TZQ            (0x1 << 12) // (EMAC) Transmit zero quantum pause frame

+// -------- EMAC_NCFGR : (EMAC Offset: 0x4) Network Configuration Register -------- 

+#define AT91C_EMAC_SPD            (0x1 <<  0) // (EMAC) Speed. 

+#define AT91C_EMAC_FD             (0x1 <<  1) // (EMAC) Full duplex. 

+#define AT91C_EMAC_JFRAME         (0x1 <<  3) // (EMAC) Jumbo Frames. 

+#define AT91C_EMAC_CAF            (0x1 <<  4) // (EMAC) Copy all frames. 

+#define AT91C_EMAC_NBC            (0x1 <<  5) // (EMAC) No broadcast. 

+#define AT91C_EMAC_MTI            (0x1 <<  6) // (EMAC) Multicast hash event enable

+#define AT91C_EMAC_UNI            (0x1 <<  7) // (EMAC) Unicast hash enable. 

+#define AT91C_EMAC_BIG            (0x1 <<  8) // (EMAC) Receive 1522 bytes. 

+#define AT91C_EMAC_EAE            (0x1 <<  9) // (EMAC) External address match enable. 

+#define AT91C_EMAC_CLK            (0x3 << 10) // (EMAC) 

+#define 	AT91C_EMAC_CLK_HCLK_8               (0x0 << 10) // (EMAC) HCLK divided by 8

+#define 	AT91C_EMAC_CLK_HCLK_16              (0x1 << 10) // (EMAC) HCLK divided by 16

+#define 	AT91C_EMAC_CLK_HCLK_32              (0x2 << 10) // (EMAC) HCLK divided by 32

+#define 	AT91C_EMAC_CLK_HCLK_64              (0x3 << 10) // (EMAC) HCLK divided by 64

+#define AT91C_EMAC_RTY            (0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PAE            (0x1 << 13) // (EMAC) 

+#define AT91C_EMAC_RBOF           (0x3 << 14) // (EMAC) 

+#define 	AT91C_EMAC_RBOF_OFFSET_0             (0x0 << 14) // (EMAC) no offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_1             (0x1 << 14) // (EMAC) one byte offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_2             (0x2 << 14) // (EMAC) two bytes offset from start of receive buffer

+#define 	AT91C_EMAC_RBOF_OFFSET_3             (0x3 << 14) // (EMAC) three bytes offset from start of receive buffer

+#define AT91C_EMAC_RLCE           (0x1 << 16) // (EMAC) Receive Length field Checking Enable

+#define AT91C_EMAC_DRFCS          (0x1 << 17) // (EMAC) Discard Receive FCS

+#define AT91C_EMAC_EFRHD          (0x1 << 18) // (EMAC) 

+#define AT91C_EMAC_IRXFCS         (0x1 << 19) // (EMAC) Ignore RX FCS

+// -------- EMAC_NSR : (EMAC Offset: 0x8) Network Status Register -------- 

+#define AT91C_EMAC_LINKR          (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_MDIO           (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_IDLE           (0x1 <<  2) // (EMAC) 

+// -------- EMAC_TSR : (EMAC Offset: 0x14) Transmit Status Register -------- 

+#define AT91C_EMAC_UBR            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_COL            (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RLES           (0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TGO            (0x1 <<  3) // (EMAC) Transmit Go

+#define AT91C_EMAC_BEX            (0x1 <<  4) // (EMAC) Buffers exhausted mid frame

+#define AT91C_EMAC_COMP           (0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_UND            (0x1 <<  6) // (EMAC) 

+// -------- EMAC_RSR : (EMAC Offset: 0x20) Receive Status Register -------- 

+#define AT91C_EMAC_BNA            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_REC            (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_OVR            (0x1 <<  2) // (EMAC) 

+// -------- EMAC_ISR : (EMAC Offset: 0x24) Interrupt Status Register -------- 

+#define AT91C_EMAC_MFD            (0x1 <<  0) // (EMAC) 

+#define AT91C_EMAC_RCOMP          (0x1 <<  1) // (EMAC) 

+#define AT91C_EMAC_RXUBR          (0x1 <<  2) // (EMAC) 

+#define AT91C_EMAC_TXUBR          (0x1 <<  3) // (EMAC) 

+#define AT91C_EMAC_TUNDR          (0x1 <<  4) // (EMAC) 

+#define AT91C_EMAC_RLEX           (0x1 <<  5) // (EMAC) 

+#define AT91C_EMAC_TXERR          (0x1 <<  6) // (EMAC) 

+#define AT91C_EMAC_TCOMP          (0x1 <<  7) // (EMAC) 

+#define AT91C_EMAC_LINK           (0x1 <<  9) // (EMAC) 

+#define AT91C_EMAC_ROVR           (0x1 << 10) // (EMAC) 

+#define AT91C_EMAC_HRESP          (0x1 << 11) // (EMAC) 

+#define AT91C_EMAC_PFRE           (0x1 << 12) // (EMAC) 

+#define AT91C_EMAC_PTZ            (0x1 << 13) // (EMAC) 

+// -------- EMAC_IER : (EMAC Offset: 0x28) Interrupt Enable Register -------- 

+// -------- EMAC_IDR : (EMAC Offset: 0x2c) Interrupt Disable Register -------- 

+// -------- EMAC_IMR : (EMAC Offset: 0x30) Interrupt Mask Register -------- 

+// -------- EMAC_MAN : (EMAC Offset: 0x34) PHY Maintenance Register -------- 

+#define AT91C_EMAC_DATA           (0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_CODE           (0x3 << 16) // (EMAC) 

+#define AT91C_EMAC_REGA           (0x1F << 18) // (EMAC) 

+#define AT91C_EMAC_PHYA           (0x1F << 23) // (EMAC) 

+#define AT91C_EMAC_RW             (0x3 << 28) // (EMAC) 

+#define AT91C_EMAC_SOF            (0x3 << 30) // (EMAC) 

+// -------- EMAC_USRIO : (EMAC Offset: 0xc0) USER Input Output Register -------- 

+#define AT91C_EMAC_RMII           (0x1 <<  0) // (EMAC) Reduce MII

+// -------- EMAC_WOL : (EMAC Offset: 0xc4) Wake On LAN Register -------- 

+#define AT91C_EMAC_IP             (0xFFFF <<  0) // (EMAC) ARP request IP address

+#define AT91C_EMAC_MAG            (0x1 << 16) // (EMAC) Magic packet event enable

+#define AT91C_EMAC_ARP            (0x1 << 17) // (EMAC) ARP request event enable

+#define AT91C_EMAC_SA1            (0x1 << 18) // (EMAC) Specific address register 1 event enable

+// -------- EMAC_REV : (EMAC Offset: 0xfc) Revision Register -------- 

+#define AT91C_EMAC_REVREF         (0xFFFF <<  0) // (EMAC) 

+#define AT91C_EMAC_PARTREF        (0xFFFF << 16) // (EMAC) 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Analog to Digital Convertor

+// *****************************************************************************

+// *** Register offset in AT91S_ADC structure ***

+#define ADC_CR          ( 0) // ADC Control Register

+#define ADC_MR          ( 4) // ADC Mode Register

+#define ADC_CHER        (16) // ADC Channel Enable Register

+#define ADC_CHDR        (20) // ADC Channel Disable Register

+#define ADC_CHSR        (24) // ADC Channel Status Register

+#define ADC_SR          (28) // ADC Status Register

+#define ADC_LCDR        (32) // ADC Last Converted Data Register

+#define ADC_IER         (36) // ADC Interrupt Enable Register

+#define ADC_IDR         (40) // ADC Interrupt Disable Register

+#define ADC_IMR         (44) // ADC Interrupt Mask Register

+#define ADC_CDR0        (48) // ADC Channel Data Register 0

+#define ADC_CDR1        (52) // ADC Channel Data Register 1

+#define ADC_CDR2        (56) // ADC Channel Data Register 2

+#define ADC_CDR3        (60) // ADC Channel Data Register 3

+#define ADC_CDR4        (64) // ADC Channel Data Register 4

+#define ADC_CDR5        (68) // ADC Channel Data Register 5

+#define ADC_CDR6        (72) // ADC Channel Data Register 6

+#define ADC_CDR7        (76) // ADC Channel Data Register 7

+#define ADC_RPR         (256) // Receive Pointer Register

+#define ADC_RCR         (260) // Receive Counter Register

+#define ADC_TPR         (264) // Transmit Pointer Register

+#define ADC_TCR         (268) // Transmit Counter Register

+#define ADC_RNPR        (272) // Receive Next Pointer Register

+#define ADC_RNCR        (276) // Receive Next Counter Register

+#define ADC_TNPR        (280) // Transmit Next Pointer Register

+#define ADC_TNCR        (284) // Transmit Next Counter Register

+#define ADC_PTCR        (288) // PDC Transfer Control Register

+#define ADC_PTSR        (292) // PDC Transfer Status Register

+// -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register -------- 

+#define AT91C_ADC_SWRST           (0x1 <<  0) // (ADC) Software Reset

+#define AT91C_ADC_START           (0x1 <<  1) // (ADC) Start Conversion

+// -------- ADC_MR : (ADC Offset: 0x4) ADC Mode Register -------- 

+#define AT91C_ADC_TRGEN           (0x1 <<  0) // (ADC) Trigger Enable

+#define 	AT91C_ADC_TRGEN_DIS                  (0x0) // (ADC) Hradware triggers are disabled. Starting a conversion is only possible by software

+#define 	AT91C_ADC_TRGEN_EN                   (0x1) // (ADC) Hardware trigger selected by TRGSEL field is enabled.

+#define AT91C_ADC_TRGSEL          (0x7 <<  1) // (ADC) Trigger Selection

+#define 	AT91C_ADC_TRGSEL_TIOA0                (0x0 <<  1) // (ADC) Selected TRGSEL = TIAO0

+#define 	AT91C_ADC_TRGSEL_TIOA1                (0x1 <<  1) // (ADC) Selected TRGSEL = TIAO1

+#define 	AT91C_ADC_TRGSEL_TIOA2                (0x2 <<  1) // (ADC) Selected TRGSEL = TIAO2

+#define 	AT91C_ADC_TRGSEL_TIOA3                (0x3 <<  1) // (ADC) Selected TRGSEL = TIAO3

+#define 	AT91C_ADC_TRGSEL_TIOA4                (0x4 <<  1) // (ADC) Selected TRGSEL = TIAO4

+#define 	AT91C_ADC_TRGSEL_TIOA5                (0x5 <<  1) // (ADC) Selected TRGSEL = TIAO5

+#define 	AT91C_ADC_TRGSEL_EXT                  (0x6 <<  1) // (ADC) Selected TRGSEL = External Trigger

+#define AT91C_ADC_LOWRES          (0x1 <<  4) // (ADC) Resolution.

+#define 	AT91C_ADC_LOWRES_10_BIT               (0x0 <<  4) // (ADC) 10-bit resolution

+#define 	AT91C_ADC_LOWRES_8_BIT                (0x1 <<  4) // (ADC) 8-bit resolution

+#define AT91C_ADC_SLEEP           (0x1 <<  5) // (ADC) Sleep Mode

+#define 	AT91C_ADC_SLEEP_NORMAL_MODE          (0x0 <<  5) // (ADC) Normal Mode

+#define 	AT91C_ADC_SLEEP_MODE                 (0x1 <<  5) // (ADC) Sleep Mode

+#define AT91C_ADC_PRESCAL         (0x3F <<  8) // (ADC) Prescaler rate selection

+#define AT91C_ADC_STARTUP         (0x1F << 16) // (ADC) Startup Time

+#define AT91C_ADC_SHTIM           (0xF << 24) // (ADC) Sample & Hold Time

+// -------- 	ADC_CHER : (ADC Offset: 0x10) ADC Channel Enable Register -------- 

+#define AT91C_ADC_CH0             (0x1 <<  0) // (ADC) Channel 0

+#define AT91C_ADC_CH1             (0x1 <<  1) // (ADC) Channel 1

+#define AT91C_ADC_CH2             (0x1 <<  2) // (ADC) Channel 2

+#define AT91C_ADC_CH3             (0x1 <<  3) // (ADC) Channel 3

+#define AT91C_ADC_CH4             (0x1 <<  4) // (ADC) Channel 4

+#define AT91C_ADC_CH5             (0x1 <<  5) // (ADC) Channel 5

+#define AT91C_ADC_CH6             (0x1 <<  6) // (ADC) Channel 6

+#define AT91C_ADC_CH7             (0x1 <<  7) // (ADC) Channel 7

+// -------- 	ADC_CHDR : (ADC Offset: 0x14) ADC Channel Disable Register -------- 

+// -------- 	ADC_CHSR : (ADC Offset: 0x18) ADC Channel Status Register -------- 

+// -------- ADC_SR : (ADC Offset: 0x1c) ADC Status Register -------- 

+#define AT91C_ADC_EOC0            (0x1 <<  0) // (ADC) End of Conversion

+#define AT91C_ADC_EOC1            (0x1 <<  1) // (ADC) End of Conversion

+#define AT91C_ADC_EOC2            (0x1 <<  2) // (ADC) End of Conversion

+#define AT91C_ADC_EOC3            (0x1 <<  3) // (ADC) End of Conversion

+#define AT91C_ADC_EOC4            (0x1 <<  4) // (ADC) End of Conversion

+#define AT91C_ADC_EOC5            (0x1 <<  5) // (ADC) End of Conversion

+#define AT91C_ADC_EOC6            (0x1 <<  6) // (ADC) End of Conversion

+#define AT91C_ADC_EOC7            (0x1 <<  7) // (ADC) End of Conversion

+#define AT91C_ADC_OVRE0           (0x1 <<  8) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE1           (0x1 <<  9) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE2           (0x1 << 10) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE3           (0x1 << 11) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE4           (0x1 << 12) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE5           (0x1 << 13) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE6           (0x1 << 14) // (ADC) Overrun Error

+#define AT91C_ADC_OVRE7           (0x1 << 15) // (ADC) Overrun Error

+#define AT91C_ADC_DRDY            (0x1 << 16) // (ADC) Data Ready

+#define AT91C_ADC_GOVRE           (0x1 << 17) // (ADC) General Overrun

+#define AT91C_ADC_ENDRX           (0x1 << 18) // (ADC) End of Receiver Transfer

+#define AT91C_ADC_RXBUFF          (0x1 << 19) // (ADC) RXBUFF Interrupt

+// -------- ADC_LCDR : (ADC Offset: 0x20) ADC Last Converted Data Register -------- 

+#define AT91C_ADC_LDATA           (0x3FF <<  0) // (ADC) Last Data Converted

+// -------- ADC_IER : (ADC Offset: 0x24) ADC Interrupt Enable Register -------- 

+// -------- ADC_IDR : (ADC Offset: 0x28) ADC Interrupt Disable Register -------- 

+// -------- ADC_IMR : (ADC Offset: 0x2c) ADC Interrupt Mask Register -------- 

+// -------- ADC_CDR0 : (ADC Offset: 0x30) ADC Channel Data Register 0 -------- 

+#define AT91C_ADC_DATA            (0x3FF <<  0) // (ADC) Converted Data

+// -------- ADC_CDR1 : (ADC Offset: 0x34) ADC Channel Data Register 1 -------- 

+// -------- ADC_CDR2 : (ADC Offset: 0x38) ADC Channel Data Register 2 -------- 

+// -------- ADC_CDR3 : (ADC Offset: 0x3c) ADC Channel Data Register 3 -------- 

+// -------- ADC_CDR4 : (ADC Offset: 0x40) ADC Channel Data Register 4 -------- 

+// -------- ADC_CDR5 : (ADC Offset: 0x44) ADC Channel Data Register 5 -------- 

+// -------- ADC_CDR6 : (ADC Offset: 0x48) ADC Channel Data Register 6 -------- 

+// -------- ADC_CDR7 : (ADC Offset: 0x4c) ADC Channel Data Register 7 -------- 

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Advanced  Encryption Standard

+// *****************************************************************************

+// *** Register offset in AT91S_AES structure ***

+#define AES_CR          ( 0) // Control Register

+#define AES_MR          ( 4) // Mode Register

+#define AES_IER         (16) // Interrupt Enable Register

+#define AES_IDR         (20) // Interrupt Disable Register

+#define AES_IMR         (24) // Interrupt Mask Register

+#define AES_ISR         (28) // Interrupt Status Register

+#define AES_KEYWxR      (32) // Key Word x Register

+#define AES_IDATAxR     (64) // Input Data x Register

+#define AES_ODATAxR     (80) // Output Data x Register

+#define AES_IVxR        (96) // Initialization Vector x Register

+#define AES_VR          (252) // AES Version Register

+#define AES_RPR         (256) // Receive Pointer Register

+#define AES_RCR         (260) // Receive Counter Register

+#define AES_TPR         (264) // Transmit Pointer Register

+#define AES_TCR         (268) // Transmit Counter Register

+#define AES_RNPR        (272) // Receive Next Pointer Register

+#define AES_RNCR        (276) // Receive Next Counter Register

+#define AES_TNPR        (280) // Transmit Next Pointer Register

+#define AES_TNCR        (284) // Transmit Next Counter Register

+#define AES_PTCR        (288) // PDC Transfer Control Register

+#define AES_PTSR        (292) // PDC Transfer Status Register

+// -------- AES_CR : (AES Offset: 0x0) Control Register -------- 

+#define AT91C_AES_START           (0x1 <<  0) // (AES) Starts Processing

+#define AT91C_AES_SWRST           (0x1 <<  8) // (AES) Software Reset

+#define AT91C_AES_LOADSEED        (0x1 << 16) // (AES) Random Number Generator Seed Loading

+// -------- AES_MR : (AES Offset: 0x4) Mode Register -------- 

+#define AT91C_AES_CIPHER          (0x1 <<  0) // (AES) Processing Mode

+#define AT91C_AES_PROCDLY         (0xF <<  4) // (AES) Processing Delay

+#define AT91C_AES_SMOD            (0x3 <<  8) // (AES) Start Mode

+#define 	AT91C_AES_SMOD_MANUAL               (0x0 <<  8) // (AES) Manual Mode: The START bit in register AES_CR must be set to begin encryption or decryption.

+#define 	AT91C_AES_SMOD_AUTO                 (0x1 <<  8) // (AES) Auto Mode: no action in AES_CR is necessary (cf datasheet).

+#define 	AT91C_AES_SMOD_PDC                  (0x2 <<  8) // (AES) PDC Mode (cf datasheet).

+#define AT91C_AES_OPMOD           (0x7 << 12) // (AES) Operation Mode

+#define 	AT91C_AES_OPMOD_ECB                  (0x0 << 12) // (AES) ECB Electronic CodeBook mode.

+#define 	AT91C_AES_OPMOD_CBC                  (0x1 << 12) // (AES) CBC Cipher Block Chaining mode.

+#define 	AT91C_AES_OPMOD_OFB                  (0x2 << 12) // (AES) OFB Output Feedback mode.

+#define 	AT91C_AES_OPMOD_CFB                  (0x3 << 12) // (AES) CFB Cipher Feedback mode.

+#define 	AT91C_AES_OPMOD_CTR                  (0x4 << 12) // (AES) CTR Counter mode.

+#define AT91C_AES_LOD             (0x1 << 15) // (AES) Last Output Data Mode

+#define AT91C_AES_CFBS            (0x7 << 16) // (AES) Cipher Feedback Data Size

+#define 	AT91C_AES_CFBS_128_BIT              (0x0 << 16) // (AES) 128-bit.

+#define 	AT91C_AES_CFBS_64_BIT               (0x1 << 16) // (AES) 64-bit.

+#define 	AT91C_AES_CFBS_32_BIT               (0x2 << 16) // (AES) 32-bit.

+#define 	AT91C_AES_CFBS_16_BIT               (0x3 << 16) // (AES) 16-bit.

+#define 	AT91C_AES_CFBS_8_BIT                (0x4 << 16) // (AES) 8-bit.

+#define AT91C_AES_CKEY            (0xF << 20) // (AES) Countermeasure Key

+#define AT91C_AES_CTYPE           (0x1F << 24) // (AES) Countermeasure Type

+#define 	AT91C_AES_CTYPE_TYPE1_EN             (0x1 << 24) // (AES) Countermeasure type 1 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE2_EN             (0x2 << 24) // (AES) Countermeasure type 2 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE3_EN             (0x4 << 24) // (AES) Countermeasure type 3 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE4_EN             (0x8 << 24) // (AES) Countermeasure type 4 is enabled.

+#define 	AT91C_AES_CTYPE_TYPE5_EN             (0x10 << 24) // (AES) Countermeasure type 5 is enabled.

+// -------- AES_IER : (AES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_AES_DATRDY          (0x1 <<  0) // (AES) DATRDY

+#define AT91C_AES_ENDRX           (0x1 <<  1) // (AES) PDC Read Buffer End

+#define AT91C_AES_ENDTX           (0x1 <<  2) // (AES) PDC Write Buffer End

+#define AT91C_AES_RXBUFF          (0x1 <<  3) // (AES) PDC Read Buffer Full

+#define AT91C_AES_TXBUFE          (0x1 <<  4) // (AES) PDC Write Buffer Empty

+#define AT91C_AES_URAD            (0x1 <<  8) // (AES) Unspecified Register Access Detection

+// -------- AES_IDR : (AES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- AES_IMR : (AES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- AES_ISR : (AES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_AES_URAT            (0x7 << 12) // (AES) Unspecified Register Access Type Status

+#define 	AT91C_AES_URAT_IN_DAT_WRITE_DATPROC (0x0 << 12) // (AES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_DATPROC (0x1 << 12) // (AES) Output data register read during the data processing.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_DATPROC (0x2 << 12) // (AES) Mode register written during the data processing.

+#define 	AT91C_AES_URAT_OUT_DAT_READ_SUBKEY  (0x3 << 12) // (AES) Output data register read during the sub-keys generation.

+#define 	AT91C_AES_URAT_MODEREG_WRITE_SUBKEY (0x4 << 12) // (AES) Mode register written during the sub-keys generation.

+#define 	AT91C_AES_URAT_WO_REG_READ          (0x5 << 12) // (AES) Write-only register read access.

+

+// *****************************************************************************

+//              SOFTWARE API DEFINITION  FOR Triple Data Encryption Standard

+// *****************************************************************************

+// *** Register offset in AT91S_TDES structure ***

+#define TDES_CR         ( 0) // Control Register

+#define TDES_MR         ( 4) // Mode Register

+#define TDES_IER        (16) // Interrupt Enable Register

+#define TDES_IDR        (20) // Interrupt Disable Register

+#define TDES_IMR        (24) // Interrupt Mask Register

+#define TDES_ISR        (28) // Interrupt Status Register

+#define TDES_KEY1WxR    (32) // Key 1 Word x Register

+#define TDES_KEY2WxR    (40) // Key 2 Word x Register

+#define TDES_KEY3WxR    (48) // Key 3 Word x Register

+#define TDES_IDATAxR    (64) // Input Data x Register

+#define TDES_ODATAxR    (80) // Output Data x Register

+#define TDES_IVxR       (96) // Initialization Vector x Register

+#define TDES_VR         (252) // TDES Version Register

+#define TDES_RPR        (256) // Receive Pointer Register

+#define TDES_RCR        (260) // Receive Counter Register

+#define TDES_TPR        (264) // Transmit Pointer Register

+#define TDES_TCR        (268) // Transmit Counter Register

+#define TDES_RNPR       (272) // Receive Next Pointer Register

+#define TDES_RNCR       (276) // Receive Next Counter Register

+#define TDES_TNPR       (280) // Transmit Next Pointer Register

+#define TDES_TNCR       (284) // Transmit Next Counter Register

+#define TDES_PTCR       (288) // PDC Transfer Control Register

+#define TDES_PTSR       (292) // PDC Transfer Status Register

+// -------- TDES_CR : (TDES Offset: 0x0) Control Register -------- 

+#define AT91C_TDES_START          (0x1 <<  0) // (TDES) Starts Processing

+#define AT91C_TDES_SWRST          (0x1 <<  8) // (TDES) Software Reset

+// -------- TDES_MR : (TDES Offset: 0x4) Mode Register -------- 

+#define AT91C_TDES_CIPHER         (0x1 <<  0) // (TDES) Processing Mode

+#define AT91C_TDES_TDESMOD        (0x1 <<  1) // (TDES) Single or Triple DES Mode

+#define AT91C_TDES_KEYMOD         (0x1 <<  4) // (TDES) Key Mode

+#define AT91C_TDES_SMOD           (0x3 <<  8) // (TDES) Start Mode

+#define 	AT91C_TDES_SMOD_MANUAL               (0x0 <<  8) // (TDES) Manual Mode: The START bit in register TDES_CR must be set to begin encryption or decryption.

+#define 	AT91C_TDES_SMOD_AUTO                 (0x1 <<  8) // (TDES) Auto Mode: no action in TDES_CR is necessary (cf datasheet).

+#define 	AT91C_TDES_SMOD_PDC                  (0x2 <<  8) // (TDES) PDC Mode (cf datasheet).

+#define AT91C_TDES_OPMOD          (0x3 << 12) // (TDES) Operation Mode

+#define 	AT91C_TDES_OPMOD_ECB                  (0x0 << 12) // (TDES) ECB Electronic CodeBook mode.

+#define 	AT91C_TDES_OPMOD_CBC                  (0x1 << 12) // (TDES) CBC Cipher Block Chaining mode.

+#define 	AT91C_TDES_OPMOD_OFB                  (0x2 << 12) // (TDES) OFB Output Feedback mode.

+#define 	AT91C_TDES_OPMOD_CFB                  (0x3 << 12) // (TDES) CFB Cipher Feedback mode.

+#define AT91C_TDES_LOD            (0x1 << 15) // (TDES) Last Output Data Mode

+#define AT91C_TDES_CFBS           (0x3 << 16) // (TDES) Cipher Feedback Data Size

+#define 	AT91C_TDES_CFBS_64_BIT               (0x0 << 16) // (TDES) 64-bit.

+#define 	AT91C_TDES_CFBS_32_BIT               (0x1 << 16) // (TDES) 32-bit.

+#define 	AT91C_TDES_CFBS_16_BIT               (0x2 << 16) // (TDES) 16-bit.

+#define 	AT91C_TDES_CFBS_8_BIT                (0x3 << 16) // (TDES) 8-bit.

+// -------- TDES_IER : (TDES Offset: 0x10) Interrupt Enable Register -------- 

+#define AT91C_TDES_DATRDY         (0x1 <<  0) // (TDES) DATRDY

+#define AT91C_TDES_ENDRX          (0x1 <<  1) // (TDES) PDC Read Buffer End

+#define AT91C_TDES_ENDTX          (0x1 <<  2) // (TDES) PDC Write Buffer End

+#define AT91C_TDES_RXBUFF         (0x1 <<  3) // (TDES) PDC Read Buffer Full

+#define AT91C_TDES_TXBUFE         (0x1 <<  4) // (TDES) PDC Write Buffer Empty

+#define AT91C_TDES_URAD           (0x1 <<  8) // (TDES) Unspecified Register Access Detection

+// -------- TDES_IDR : (TDES Offset: 0x14) Interrupt Disable Register -------- 

+// -------- TDES_IMR : (TDES Offset: 0x18) Interrupt Mask Register -------- 

+// -------- TDES_ISR : (TDES Offset: 0x1c) Interrupt Status Register -------- 

+#define AT91C_TDES_URAT           (0x3 << 12) // (TDES) Unspecified Register Access Type Status

+#define 	AT91C_TDES_URAT_IN_DAT_WRITE_DATPROC (0x0 << 12) // (TDES) Input data register written during the data processing in PDC mode.

+#define 	AT91C_TDES_URAT_OUT_DAT_READ_DATPROC (0x1 << 12) // (TDES) Output data register read during the data processing.

+#define 	AT91C_TDES_URAT_MODEREG_WRITE_DATPROC (0x2 << 12) // (TDES) Mode register written during the data processing.

+#define 	AT91C_TDES_URAT_WO_REG_READ          (0x3 << 12) // (TDES) Write-only register read access.

+

+// *****************************************************************************

+//               REGISTER ADDRESS DEFINITION FOR AT91SAM7X256

+// *****************************************************************************

+// ========== Register definition for SYS peripheral ========== 

+// ========== Register definition for AIC peripheral ========== 

+#define AT91C_AIC_IVR             (0xFFFFF100) // (AIC) IRQ Vector Register

+#define AT91C_AIC_SMR             (0xFFFFF000) // (AIC) Source Mode Register

+#define AT91C_AIC_FVR             (0xFFFFF104) // (AIC) FIQ Vector Register

+#define AT91C_AIC_DCR             (0xFFFFF138) // (AIC) Debug Control Register (Protect)

+#define AT91C_AIC_EOICR           (0xFFFFF130) // (AIC) End of Interrupt Command Register

+#define AT91C_AIC_SVR             (0xFFFFF080) // (AIC) Source Vector Register

+#define AT91C_AIC_FFSR            (0xFFFFF148) // (AIC) Fast Forcing Status Register

+#define AT91C_AIC_ICCR            (0xFFFFF128) // (AIC) Interrupt Clear Command Register

+#define AT91C_AIC_ISR             (0xFFFFF108) // (AIC) Interrupt Status Register

+#define AT91C_AIC_IMR             (0xFFFFF110) // (AIC) Interrupt Mask Register

+#define AT91C_AIC_IPR             (0xFFFFF10C) // (AIC) Interrupt Pending Register

+#define AT91C_AIC_FFER            (0xFFFFF140) // (AIC) Fast Forcing Enable Register

+#define AT91C_AIC_IECR            (0xFFFFF120) // (AIC) Interrupt Enable Command Register

+#define AT91C_AIC_ISCR            (0xFFFFF12C) // (AIC) Interrupt Set Command Register

+#define AT91C_AIC_FFDR            (0xFFFFF144) // (AIC) Fast Forcing Disable Register

+#define AT91C_AIC_CISR            (0xFFFFF114) // (AIC) Core Interrupt Status Register

+#define AT91C_AIC_IDCR            (0xFFFFF124) // (AIC) Interrupt Disable Command Register

+#define AT91C_AIC_SPU             (0xFFFFF134) // (AIC) Spurious Vector Register

+// ========== Register definition for PDC_DBGU peripheral ========== 

+#define AT91C_DBGU_TCR            (0xFFFFF30C) // (PDC_DBGU) Transmit Counter Register

+#define AT91C_DBGU_RNPR           (0xFFFFF310) // (PDC_DBGU) Receive Next Pointer Register

+#define AT91C_DBGU_TNPR           (0xFFFFF318) // (PDC_DBGU) Transmit Next Pointer Register

+#define AT91C_DBGU_TPR            (0xFFFFF308) // (PDC_DBGU) Transmit Pointer Register

+#define AT91C_DBGU_RPR            (0xFFFFF300) // (PDC_DBGU) Receive Pointer Register

+#define AT91C_DBGU_RCR            (0xFFFFF304) // (PDC_DBGU) Receive Counter Register

+#define AT91C_DBGU_RNCR           (0xFFFFF314) // (PDC_DBGU) Receive Next Counter Register

+#define AT91C_DBGU_PTCR           (0xFFFFF320) // (PDC_DBGU) PDC Transfer Control Register

+#define AT91C_DBGU_PTSR           (0xFFFFF324) // (PDC_DBGU) PDC Transfer Status Register

+#define AT91C_DBGU_TNCR           (0xFFFFF31C) // (PDC_DBGU) Transmit Next Counter Register

+// ========== Register definition for DBGU peripheral ========== 

+#define AT91C_DBGU_EXID           (0xFFFFF244) // (DBGU) Chip ID Extension Register

+#define AT91C_DBGU_BRGR           (0xFFFFF220) // (DBGU) Baud Rate Generator Register

+#define AT91C_DBGU_IDR            (0xFFFFF20C) // (DBGU) Interrupt Disable Register

+#define AT91C_DBGU_CSR            (0xFFFFF214) // (DBGU) Channel Status Register

+#define AT91C_DBGU_CIDR           (0xFFFFF240) // (DBGU) Chip ID Register

+#define AT91C_DBGU_MR             (0xFFFFF204) // (DBGU) Mode Register

+#define AT91C_DBGU_IMR            (0xFFFFF210) // (DBGU) Interrupt Mask Register

+#define AT91C_DBGU_CR             (0xFFFFF200) // (DBGU) Control Register

+#define AT91C_DBGU_FNTR           (0xFFFFF248) // (DBGU) Force NTRST Register

+#define AT91C_DBGU_THR            (0xFFFFF21C) // (DBGU) Transmitter Holding Register

+#define AT91C_DBGU_RHR            (0xFFFFF218) // (DBGU) Receiver Holding Register

+#define AT91C_DBGU_IER            (0xFFFFF208) // (DBGU) Interrupt Enable Register

+// ========== Register definition for PIOA peripheral ========== 

+#define AT91C_PIOA_ODR            (0xFFFFF414) // (PIOA) Output Disable Registerr

+#define AT91C_PIOA_SODR           (0xFFFFF430) // (PIOA) Set Output Data Register

+#define AT91C_PIOA_ISR            (0xFFFFF44C) // (PIOA) Interrupt Status Register

+#define AT91C_PIOA_ABSR           (0xFFFFF478) // (PIOA) AB Select Status Register

+#define AT91C_PIOA_IER            (0xFFFFF440) // (PIOA) Interrupt Enable Register

+#define AT91C_PIOA_PPUDR          (0xFFFFF460) // (PIOA) Pull-up Disable Register

+#define AT91C_PIOA_IMR            (0xFFFFF448) // (PIOA) Interrupt Mask Register

+#define AT91C_PIOA_PER            (0xFFFFF400) // (PIOA) PIO Enable Register

+#define AT91C_PIOA_IFDR           (0xFFFFF424) // (PIOA) Input Filter Disable Register

+#define AT91C_PIOA_OWDR           (0xFFFFF4A4) // (PIOA) Output Write Disable Register

+#define AT91C_PIOA_MDSR           (0xFFFFF458) // (PIOA) Multi-driver Status Register

+#define AT91C_PIOA_IDR            (0xFFFFF444) // (PIOA) Interrupt Disable Register

+#define AT91C_PIOA_ODSR           (0xFFFFF438) // (PIOA) Output Data Status Register

+#define AT91C_PIOA_PPUSR          (0xFFFFF468) // (PIOA) Pull-up Status Register

+#define AT91C_PIOA_OWSR           (0xFFFFF4A8) // (PIOA) Output Write Status Register

+#define AT91C_PIOA_BSR            (0xFFFFF474) // (PIOA) Select B Register

+#define AT91C_PIOA_OWER           (0xFFFFF4A0) // (PIOA) Output Write Enable Register

+#define AT91C_PIOA_IFER           (0xFFFFF420) // (PIOA) Input Filter Enable Register

+#define AT91C_PIOA_PDSR           (0xFFFFF43C) // (PIOA) Pin Data Status Register

+#define AT91C_PIOA_PPUER          (0xFFFFF464) // (PIOA) Pull-up Enable Register

+#define AT91C_PIOA_OSR            (0xFFFFF418) // (PIOA) Output Status Register

+#define AT91C_PIOA_ASR            (0xFFFFF470) // (PIOA) Select A Register

+#define AT91C_PIOA_MDDR           (0xFFFFF454) // (PIOA) Multi-driver Disable Register

+#define AT91C_PIOA_CODR           (0xFFFFF434) // (PIOA) Clear Output Data Register

+#define AT91C_PIOA_MDER           (0xFFFFF450) // (PIOA) Multi-driver Enable Register

+#define AT91C_PIOA_PDR            (0xFFFFF404) // (PIOA) PIO Disable Register

+#define AT91C_PIOA_IFSR           (0xFFFFF428) // (PIOA) Input Filter Status Register

+#define AT91C_PIOA_OER            (0xFFFFF410) // (PIOA) Output Enable Register

+#define AT91C_PIOA_PSR            (0xFFFFF408) // (PIOA) PIO Status Register

+// ========== Register definition for PIOB peripheral ========== 

+#define AT91C_PIOB_OWDR           (0xFFFFF6A4) // (PIOB) Output Write Disable Register

+#define AT91C_PIOB_MDER           (0xFFFFF650) // (PIOB) Multi-driver Enable Register

+#define AT91C_PIOB_PPUSR          (0xFFFFF668) // (PIOB) Pull-up Status Register

+#define AT91C_PIOB_IMR            (0xFFFFF648) // (PIOB) Interrupt Mask Register

+#define AT91C_PIOB_ASR            (0xFFFFF670) // (PIOB) Select A Register

+#define AT91C_PIOB_PPUDR          (0xFFFFF660) // (PIOB) Pull-up Disable Register

+#define AT91C_PIOB_PSR            (0xFFFFF608) // (PIOB) PIO Status Register

+#define AT91C_PIOB_IER            (0xFFFFF640) // (PIOB) Interrupt Enable Register

+#define AT91C_PIOB_CODR           (0xFFFFF634) // (PIOB) Clear Output Data Register

+#define AT91C_PIOB_OWER           (0xFFFFF6A0) // (PIOB) Output Write Enable Register

+#define AT91C_PIOB_ABSR           (0xFFFFF678) // (PIOB) AB Select Status Register

+#define AT91C_PIOB_IFDR           (0xFFFFF624) // (PIOB) Input Filter Disable Register

+#define AT91C_PIOB_PDSR           (0xFFFFF63C) // (PIOB) Pin Data Status Register

+#define AT91C_PIOB_IDR            (0xFFFFF644) // (PIOB) Interrupt Disable Register

+#define AT91C_PIOB_OWSR           (0xFFFFF6A8) // (PIOB) Output Write Status Register

+#define AT91C_PIOB_PDR            (0xFFFFF604) // (PIOB) PIO Disable Register

+#define AT91C_PIOB_ODR            (0xFFFFF614) // (PIOB) Output Disable Registerr

+#define AT91C_PIOB_IFSR           (0xFFFFF628) // (PIOB) Input Filter Status Register

+#define AT91C_PIOB_PPUER          (0xFFFFF664) // (PIOB) Pull-up Enable Register

+#define AT91C_PIOB_SODR           (0xFFFFF630) // (PIOB) Set Output Data Register

+#define AT91C_PIOB_ISR            (0xFFFFF64C) // (PIOB) Interrupt Status Register

+#define AT91C_PIOB_ODSR           (0xFFFFF638) // (PIOB) Output Data Status Register

+#define AT91C_PIOB_OSR            (0xFFFFF618) // (PIOB) Output Status Register

+#define AT91C_PIOB_MDSR           (0xFFFFF658) // (PIOB) Multi-driver Status Register

+#define AT91C_PIOB_IFER           (0xFFFFF620) // (PIOB) Input Filter Enable Register

+#define AT91C_PIOB_BSR            (0xFFFFF674) // (PIOB) Select B Register

+#define AT91C_PIOB_MDDR           (0xFFFFF654) // (PIOB) Multi-driver Disable Register

+#define AT91C_PIOB_OER            (0xFFFFF610) // (PIOB) Output Enable Register

+#define AT91C_PIOB_PER            (0xFFFFF600) // (PIOB) PIO Enable Register

+// ========== Register definition for CKGR peripheral ========== 

+#define AT91C_CKGR_MOR            (0xFFFFFC20) // (CKGR) Main Oscillator Register

+#define AT91C_CKGR_PLLR           (0xFFFFFC2C) // (CKGR) PLL Register

+#define AT91C_CKGR_MCFR           (0xFFFFFC24) // (CKGR) Main Clock  Frequency Register

+// ========== Register definition for PMC peripheral ========== 

+#define AT91C_PMC_IDR             (0xFFFFFC64) // (PMC) Interrupt Disable Register

+#define AT91C_PMC_MOR             (0xFFFFFC20) // (PMC) Main Oscillator Register

+#define AT91C_PMC_PLLR            (0xFFFFFC2C) // (PMC) PLL Register

+#define AT91C_PMC_PCER            (0xFFFFFC10) // (PMC) Peripheral Clock Enable Register

+#define AT91C_PMC_PCKR            (0xFFFFFC40) // (PMC) Programmable Clock Register

+#define AT91C_PMC_MCKR            (0xFFFFFC30) // (PMC) Master Clock Register

+#define AT91C_PMC_SCDR            (0xFFFFFC04) // (PMC) System Clock Disable Register

+#define AT91C_PMC_PCDR            (0xFFFFFC14) // (PMC) Peripheral Clock Disable Register

+#define AT91C_PMC_SCSR            (0xFFFFFC08) // (PMC) System Clock Status Register

+#define AT91C_PMC_PCSR            (0xFFFFFC18) // (PMC) Peripheral Clock Status Register

+#define AT91C_PMC_MCFR            (0xFFFFFC24) // (PMC) Main Clock  Frequency Register

+#define AT91C_PMC_SCER            (0xFFFFFC00) // (PMC) System Clock Enable Register

+#define AT91C_PMC_IMR             (0xFFFFFC6C) // (PMC) Interrupt Mask Register

+#define AT91C_PMC_IER             (0xFFFFFC60) // (PMC) Interrupt Enable Register

+#define AT91C_PMC_SR              (0xFFFFFC68) // (PMC) Status Register

+// ========== Register definition for RSTC peripheral ========== 

+#define AT91C_RSTC_RCR            (0xFFFFFD00) // (RSTC) Reset Control Register

+#define AT91C_RSTC_RMR            (0xFFFFFD08) // (RSTC) Reset Mode Register

+#define AT91C_RSTC_RSR            (0xFFFFFD04) // (RSTC) Reset Status Register

+// ========== Register definition for RTTC peripheral ========== 

+#define AT91C_RTTC_RTSR           (0xFFFFFD2C) // (RTTC) Real-time Status Register

+#define AT91C_RTTC_RTMR           (0xFFFFFD20) // (RTTC) Real-time Mode Register

+#define AT91C_RTTC_RTVR           (0xFFFFFD28) // (RTTC) Real-time Value Register

+#define AT91C_RTTC_RTAR           (0xFFFFFD24) // (RTTC) Real-time Alarm Register

+// ========== Register definition for PITC peripheral ========== 

+#define AT91C_PITC_PIVR           (0xFFFFFD38) // (PITC) Period Interval Value Register

+#define AT91C_PITC_PISR           (0xFFFFFD34) // (PITC) Period Interval Status Register

+#define AT91C_PITC_PIIR           (0xFFFFFD3C) // (PITC) Period Interval Image Register

+#define AT91C_PITC_PIMR           (0xFFFFFD30) // (PITC) Period Interval Mode Register

+// ========== Register definition for WDTC peripheral ========== 

+#define AT91C_WDTC_WDCR           (0xFFFFFD40) // (WDTC) Watchdog Control Register

+#define AT91C_WDTC_WDSR           (0xFFFFFD48) // (WDTC) Watchdog Status Register

+#define AT91C_WDTC_WDMR           (0xFFFFFD44) // (WDTC) Watchdog Mode Register

+// ========== Register definition for VREG peripheral ========== 

+#define AT91C_VREG_MR             (0xFFFFFD60) // (VREG) Voltage Regulator Mode Register

+// ========== Register definition for MC peripheral ========== 

+#define AT91C_MC_ASR              (0xFFFFFF04) // (MC) MC Abort Status Register

+#define AT91C_MC_RCR              (0xFFFFFF00) // (MC) MC Remap Control Register

+#define AT91C_MC_FCR              (0xFFFFFF64) // (MC) MC Flash Command Register

+#define AT91C_MC_AASR             (0xFFFFFF08) // (MC) MC Abort Address Status Register

+#define AT91C_MC_FSR              (0xFFFFFF68) // (MC) MC Flash Status Register

+#define AT91C_MC_FMR              (0xFFFFFF60) // (MC) MC Flash Mode Register

+// ========== Register definition for PDC_SPI1 peripheral ========== 

+#define AT91C_SPI1_PTCR           (0xFFFE4120) // (PDC_SPI1) PDC Transfer Control Register

+#define AT91C_SPI1_RPR            (0xFFFE4100) // (PDC_SPI1) Receive Pointer Register

+#define AT91C_SPI1_TNCR           (0xFFFE411C) // (PDC_SPI1) Transmit Next Counter Register

+#define AT91C_SPI1_TPR            (0xFFFE4108) // (PDC_SPI1) Transmit Pointer Register

+#define AT91C_SPI1_TNPR           (0xFFFE4118) // (PDC_SPI1) Transmit Next Pointer Register

+#define AT91C_SPI1_TCR            (0xFFFE410C) // (PDC_SPI1) Transmit Counter Register

+#define AT91C_SPI1_RCR            (0xFFFE4104) // (PDC_SPI1) Receive Counter Register

+#define AT91C_SPI1_RNPR           (0xFFFE4110) // (PDC_SPI1) Receive Next Pointer Register

+#define AT91C_SPI1_RNCR           (0xFFFE4114) // (PDC_SPI1) Receive Next Counter Register

+#define AT91C_SPI1_PTSR           (0xFFFE4124) // (PDC_SPI1) PDC Transfer Status Register

+// ========== Register definition for SPI1 peripheral ========== 

+#define AT91C_SPI1_IMR            (0xFFFE401C) // (SPI1) Interrupt Mask Register

+#define AT91C_SPI1_IER            (0xFFFE4014) // (SPI1) Interrupt Enable Register

+#define AT91C_SPI1_MR             (0xFFFE4004) // (SPI1) Mode Register

+#define AT91C_SPI1_RDR            (0xFFFE4008) // (SPI1) Receive Data Register

+#define AT91C_SPI1_IDR            (0xFFFE4018) // (SPI1) Interrupt Disable Register

+#define AT91C_SPI1_SR             (0xFFFE4010) // (SPI1) Status Register

+#define AT91C_SPI1_TDR            (0xFFFE400C) // (SPI1) Transmit Data Register

+#define AT91C_SPI1_CR             (0xFFFE4000) // (SPI1) Control Register

+#define AT91C_SPI1_CSR            (0xFFFE4030) // (SPI1) Chip Select Register

+// ========== Register definition for PDC_SPI0 peripheral ========== 

+#define AT91C_SPI0_PTCR           (0xFFFE0120) // (PDC_SPI0) PDC Transfer Control Register

+#define AT91C_SPI0_TPR            (0xFFFE0108) // (PDC_SPI0) Transmit Pointer Register

+#define AT91C_SPI0_TCR            (0xFFFE010C) // (PDC_SPI0) Transmit Counter Register

+#define AT91C_SPI0_RCR            (0xFFFE0104) // (PDC_SPI0) Receive Counter Register

+#define AT91C_SPI0_PTSR           (0xFFFE0124) // (PDC_SPI0) PDC Transfer Status Register

+#define AT91C_SPI0_RNPR           (0xFFFE0110) // (PDC_SPI0) Receive Next Pointer Register

+#define AT91C_SPI0_RPR            (0xFFFE0100) // (PDC_SPI0) Receive Pointer Register

+#define AT91C_SPI0_TNCR           (0xFFFE011C) // (PDC_SPI0) Transmit Next Counter Register

+#define AT91C_SPI0_RNCR           (0xFFFE0114) // (PDC_SPI0) Receive Next Counter Register

+#define AT91C_SPI0_TNPR           (0xFFFE0118) // (PDC_SPI0) Transmit Next Pointer Register

+// ========== Register definition for SPI0 peripheral ========== 

+#define AT91C_SPI0_IER            (0xFFFE0014) // (SPI0) Interrupt Enable Register

+#define AT91C_SPI0_SR             (0xFFFE0010) // (SPI0) Status Register

+#define AT91C_SPI0_IDR            (0xFFFE0018) // (SPI0) Interrupt Disable Register

+#define AT91C_SPI0_CR             (0xFFFE0000) // (SPI0) Control Register

+#define AT91C_SPI0_MR             (0xFFFE0004) // (SPI0) Mode Register

+#define AT91C_SPI0_IMR            (0xFFFE001C) // (SPI0) Interrupt Mask Register

+#define AT91C_SPI0_TDR            (0xFFFE000C) // (SPI0) Transmit Data Register

+#define AT91C_SPI0_RDR            (0xFFFE0008) // (SPI0) Receive Data Register

+#define AT91C_SPI0_CSR            (0xFFFE0030) // (SPI0) Chip Select Register

+// ========== Register definition for PDC_US1 peripheral ========== 

+#define AT91C_US1_RNCR            (0xFFFC4114) // (PDC_US1) Receive Next Counter Register

+#define AT91C_US1_PTCR            (0xFFFC4120) // (PDC_US1) PDC Transfer Control Register

+#define AT91C_US1_TCR             (0xFFFC410C) // (PDC_US1) Transmit Counter Register

+#define AT91C_US1_PTSR            (0xFFFC4124) // (PDC_US1) PDC Transfer Status Register

+#define AT91C_US1_TNPR            (0xFFFC4118) // (PDC_US1) Transmit Next Pointer Register

+#define AT91C_US1_RCR             (0xFFFC4104) // (PDC_US1) Receive Counter Register

+#define AT91C_US1_RNPR            (0xFFFC4110) // (PDC_US1) Receive Next Pointer Register

+#define AT91C_US1_RPR             (0xFFFC4100) // (PDC_US1) Receive Pointer Register

+#define AT91C_US1_TNCR            (0xFFFC411C) // (PDC_US1) Transmit Next Counter Register

+#define AT91C_US1_TPR             (0xFFFC4108) // (PDC_US1) Transmit Pointer Register

+// ========== Register definition for US1 peripheral ========== 

+#define AT91C_US1_IF              (0xFFFC404C) // (US1) IRDA_FILTER Register

+#define AT91C_US1_NER             (0xFFFC4044) // (US1) Nb Errors Register

+#define AT91C_US1_RTOR            (0xFFFC4024) // (US1) Receiver Time-out Register

+#define AT91C_US1_CSR             (0xFFFC4014) // (US1) Channel Status Register

+#define AT91C_US1_IDR             (0xFFFC400C) // (US1) Interrupt Disable Register

+#define AT91C_US1_IER             (0xFFFC4008) // (US1) Interrupt Enable Register

+#define AT91C_US1_THR             (0xFFFC401C) // (US1) Transmitter Holding Register

+#define AT91C_US1_TTGR            (0xFFFC4028) // (US1) Transmitter Time-guard Register

+#define AT91C_US1_RHR             (0xFFFC4018) // (US1) Receiver Holding Register

+#define AT91C_US1_BRGR            (0xFFFC4020) // (US1) Baud Rate Generator Register

+#define AT91C_US1_IMR             (0xFFFC4010) // (US1) Interrupt Mask Register

+#define AT91C_US1_FIDI            (0xFFFC4040) // (US1) FI_DI_Ratio Register

+#define AT91C_US1_CR              (0xFFFC4000) // (US1) Control Register

+#define AT91C_US1_MR              (0xFFFC4004) // (US1) Mode Register

+// ========== Register definition for PDC_US0 peripheral ========== 

+#define AT91C_US0_TNPR            (0xFFFC0118) // (PDC_US0) Transmit Next Pointer Register

+#define AT91C_US0_RNPR            (0xFFFC0110) // (PDC_US0) Receive Next Pointer Register

+#define AT91C_US0_TCR             (0xFFFC010C) // (PDC_US0) Transmit Counter Register

+#define AT91C_US0_PTCR            (0xFFFC0120) // (PDC_US0) PDC Transfer Control Register

+#define AT91C_US0_PTSR            (0xFFFC0124) // (PDC_US0) PDC Transfer Status Register

+#define AT91C_US0_TNCR            (0xFFFC011C) // (PDC_US0) Transmit Next Counter Register

+#define AT91C_US0_TPR             (0xFFFC0108) // (PDC_US0) Transmit Pointer Register

+#define AT91C_US0_RCR             (0xFFFC0104) // (PDC_US0) Receive Counter Register

+#define AT91C_US0_RPR             (0xFFFC0100) // (PDC_US0) Receive Pointer Register

+#define AT91C_US0_RNCR            (0xFFFC0114) // (PDC_US0) Receive Next Counter Register

+// ========== Register definition for US0 peripheral ========== 

+#define AT91C_US0_BRGR            (0xFFFC0020) // (US0) Baud Rate Generator Register

+#define AT91C_US0_NER             (0xFFFC0044) // (US0) Nb Errors Register

+#define AT91C_US0_CR              (0xFFFC0000) // (US0) Control Register

+#define AT91C_US0_IMR             (0xFFFC0010) // (US0) Interrupt Mask Register

+#define AT91C_US0_FIDI            (0xFFFC0040) // (US0) FI_DI_Ratio Register

+#define AT91C_US0_TTGR            (0xFFFC0028) // (US0) Transmitter Time-guard Register

+#define AT91C_US0_MR              (0xFFFC0004) // (US0) Mode Register

+#define AT91C_US0_RTOR            (0xFFFC0024) // (US0) Receiver Time-out Register

+#define AT91C_US0_CSR             (0xFFFC0014) // (US0) Channel Status Register

+#define AT91C_US0_RHR             (0xFFFC0018) // (US0) Receiver Holding Register

+#define AT91C_US0_IDR             (0xFFFC000C) // (US0) Interrupt Disable Register

+#define AT91C_US0_THR             (0xFFFC001C) // (US0) Transmitter Holding Register

+#define AT91C_US0_IF              (0xFFFC004C) // (US0) IRDA_FILTER Register

+#define AT91C_US0_IER             (0xFFFC0008) // (US0) Interrupt Enable Register

+// ========== Register definition for PDC_SSC peripheral ========== 

+#define AT91C_SSC_TNCR            (0xFFFD411C) // (PDC_SSC) Transmit Next Counter Register

+#define AT91C_SSC_RPR             (0xFFFD4100) // (PDC_SSC) Receive Pointer Register

+#define AT91C_SSC_RNCR            (0xFFFD4114) // (PDC_SSC) Receive Next Counter Register

+#define AT91C_SSC_TPR             (0xFFFD4108) // (PDC_SSC) Transmit Pointer Register

+#define AT91C_SSC_PTCR            (0xFFFD4120) // (PDC_SSC) PDC Transfer Control Register

+#define AT91C_SSC_TCR             (0xFFFD410C) // (PDC_SSC) Transmit Counter Register

+#define AT91C_SSC_RCR             (0xFFFD4104) // (PDC_SSC) Receive Counter Register

+#define AT91C_SSC_RNPR            (0xFFFD4110) // (PDC_SSC) Receive Next Pointer Register

+#define AT91C_SSC_TNPR            (0xFFFD4118) // (PDC_SSC) Transmit Next Pointer Register

+#define AT91C_SSC_PTSR            (0xFFFD4124) // (PDC_SSC) PDC Transfer Status Register

+// ========== Register definition for SSC peripheral ========== 

+#define AT91C_SSC_RHR             (0xFFFD4020) // (SSC) Receive Holding Register

+#define AT91C_SSC_RSHR            (0xFFFD4030) // (SSC) Receive Sync Holding Register

+#define AT91C_SSC_TFMR            (0xFFFD401C) // (SSC) Transmit Frame Mode Register

+#define AT91C_SSC_IDR             (0xFFFD4048) // (SSC) Interrupt Disable Register

+#define AT91C_SSC_THR             (0xFFFD4024) // (SSC) Transmit Holding Register

+#define AT91C_SSC_RCMR            (0xFFFD4010) // (SSC) Receive Clock ModeRegister

+#define AT91C_SSC_IER             (0xFFFD4044) // (SSC) Interrupt Enable Register

+#define AT91C_SSC_TSHR            (0xFFFD4034) // (SSC) Transmit Sync Holding Register

+#define AT91C_SSC_SR              (0xFFFD4040) // (SSC) Status Register

+#define AT91C_SSC_CMR             (0xFFFD4004) // (SSC) Clock Mode Register

+#define AT91C_SSC_TCMR            (0xFFFD4018) // (SSC) Transmit Clock Mode Register

+#define AT91C_SSC_CR              (0xFFFD4000) // (SSC) Control Register

+#define AT91C_SSC_IMR             (0xFFFD404C) // (SSC) Interrupt Mask Register

+#define AT91C_SSC_RFMR            (0xFFFD4014) // (SSC) Receive Frame Mode Register

+// ========== Register definition for TWI peripheral ========== 

+#define AT91C_TWI_IER             (0xFFFB8024) // (TWI) Interrupt Enable Register

+#define AT91C_TWI_CR              (0xFFFB8000) // (TWI) Control Register

+#define AT91C_TWI_SR              (0xFFFB8020) // (TWI) Status Register

+#define AT91C_TWI_IMR             (0xFFFB802C) // (TWI) Interrupt Mask Register

+#define AT91C_TWI_THR             (0xFFFB8034) // (TWI) Transmit Holding Register

+#define AT91C_TWI_IDR             (0xFFFB8028) // (TWI) Interrupt Disable Register

+#define AT91C_TWI_IADR            (0xFFFB800C) // (TWI) Internal Address Register

+#define AT91C_TWI_MMR             (0xFFFB8004) // (TWI) Master Mode Register

+#define AT91C_TWI_CWGR            (0xFFFB8010) // (TWI) Clock Waveform Generator Register

+#define AT91C_TWI_RHR             (0xFFFB8030) // (TWI) Receive Holding Register

+// ========== Register definition for PWMC_CH3 peripheral ========== 

+#define AT91C_PWMC_CH3_CUPDR      (0xFFFCC270) // (PWMC_CH3) Channel Update Register

+#define AT91C_PWMC_CH3_Reserved   (0xFFFCC274) // (PWMC_CH3) Reserved

+#define AT91C_PWMC_CH3_CPRDR      (0xFFFCC268) // (PWMC_CH3) Channel Period Register

+#define AT91C_PWMC_CH3_CDTYR      (0xFFFCC264) // (PWMC_CH3) Channel Duty Cycle Register

+#define AT91C_PWMC_CH3_CCNTR      (0xFFFCC26C) // (PWMC_CH3) Channel Counter Register

+#define AT91C_PWMC_CH3_CMR        (0xFFFCC260) // (PWMC_CH3) Channel Mode Register

+// ========== Register definition for PWMC_CH2 peripheral ========== 

+#define AT91C_PWMC_CH2_Reserved   (0xFFFCC254) // (PWMC_CH2) Reserved

+#define AT91C_PWMC_CH2_CMR        (0xFFFCC240) // (PWMC_CH2) Channel Mode Register

+#define AT91C_PWMC_CH2_CCNTR      (0xFFFCC24C) // (PWMC_CH2) Channel Counter Register

+#define AT91C_PWMC_CH2_CPRDR      (0xFFFCC248) // (PWMC_CH2) Channel Period Register

+#define AT91C_PWMC_CH2_CUPDR      (0xFFFCC250) // (PWMC_CH2) Channel Update Register

+#define AT91C_PWMC_CH2_CDTYR      (0xFFFCC244) // (PWMC_CH2) Channel Duty Cycle Register

+// ========== Register definition for PWMC_CH1 peripheral ========== 

+#define AT91C_PWMC_CH1_Reserved   (0xFFFCC234) // (PWMC_CH1) Reserved

+#define AT91C_PWMC_CH1_CUPDR      (0xFFFCC230) // (PWMC_CH1) Channel Update Register

+#define AT91C_PWMC_CH1_CPRDR      (0xFFFCC228) // (PWMC_CH1) Channel Period Register

+#define AT91C_PWMC_CH1_CCNTR      (0xFFFCC22C) // (PWMC_CH1) Channel Counter Register

+#define AT91C_PWMC_CH1_CDTYR      (0xFFFCC224) // (PWMC_CH1) Channel Duty Cycle Register

+#define AT91C_PWMC_CH1_CMR        (0xFFFCC220) // (PWMC_CH1) Channel Mode Register

+// ========== Register definition for PWMC_CH0 peripheral ========== 

+#define AT91C_PWMC_CH0_Reserved   (0xFFFCC214) // (PWMC_CH0) Reserved

+#define AT91C_PWMC_CH0_CPRDR      (0xFFFCC208) // (PWMC_CH0) Channel Period Register

+#define AT91C_PWMC_CH0_CDTYR      (0xFFFCC204) // (PWMC_CH0) Channel Duty Cycle Register

+#define AT91C_PWMC_CH0_CMR        (0xFFFCC200) // (PWMC_CH0) Channel Mode Register

+#define AT91C_PWMC_CH0_CUPDR      (0xFFFCC210) // (PWMC_CH0) Channel Update Register

+#define AT91C_PWMC_CH0_CCNTR      (0xFFFCC20C) // (PWMC_CH0) Channel Counter Register

+// ========== Register definition for PWMC peripheral ========== 

+#define AT91C_PWMC_IDR            (0xFFFCC014) // (PWMC) PWMC Interrupt Disable Register

+#define AT91C_PWMC_DIS            (0xFFFCC008) // (PWMC) PWMC Disable Register

+#define AT91C_PWMC_IER            (0xFFFCC010) // (PWMC) PWMC Interrupt Enable Register

+#define AT91C_PWMC_VR             (0xFFFCC0FC) // (PWMC) PWMC Version Register

+#define AT91C_PWMC_ISR            (0xFFFCC01C) // (PWMC) PWMC Interrupt Status Register

+#define AT91C_PWMC_SR             (0xFFFCC00C) // (PWMC) PWMC Status Register

+#define AT91C_PWMC_IMR            (0xFFFCC018) // (PWMC) PWMC Interrupt Mask Register

+#define AT91C_PWMC_MR             (0xFFFCC000) // (PWMC) PWMC Mode Register

+#define AT91C_PWMC_ENA            (0xFFFCC004) // (PWMC) PWMC Enable Register

+// ========== Register definition for UDP peripheral ========== 

+#define AT91C_UDP_IMR             (0xFFFB0018) // (UDP) Interrupt Mask Register

+#define AT91C_UDP_FADDR           (0xFFFB0008) // (UDP) Function Address Register

+#define AT91C_UDP_NUM             (0xFFFB0000) // (UDP) Frame Number Register

+#define AT91C_UDP_FDR             (0xFFFB0050) // (UDP) Endpoint FIFO Data Register

+#define AT91C_UDP_ISR             (0xFFFB001C) // (UDP) Interrupt Status Register

+#define AT91C_UDP_CSR             (0xFFFB0030) // (UDP) Endpoint Control and Status Register

+#define AT91C_UDP_IDR             (0xFFFB0014) // (UDP) Interrupt Disable Register

+#define AT91C_UDP_ICR             (0xFFFB0020) // (UDP) Interrupt Clear Register

+#define AT91C_UDP_RSTEP           (0xFFFB0028) // (UDP) Reset Endpoint Register

+#define AT91C_UDP_TXVC            (0xFFFB0074) // (UDP) Transceiver Control Register

+#define AT91C_UDP_GLBSTATE        (0xFFFB0004) // (UDP) Global State Register

+#define AT91C_UDP_IER             (0xFFFB0010) // (UDP) Interrupt Enable Register

+// ========== Register definition for TC0 peripheral ========== 

+#define AT91C_TC0_SR              (0xFFFA0020) // (TC0) Status Register

+#define AT91C_TC0_RC              (0xFFFA001C) // (TC0) Register C

+#define AT91C_TC0_RB              (0xFFFA0018) // (TC0) Register B

+#define AT91C_TC0_CCR             (0xFFFA0000) // (TC0) Channel Control Register

+#define AT91C_TC0_CMR             (0xFFFA0004) // (TC0) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC0_IER             (0xFFFA0024) // (TC0) Interrupt Enable Register

+#define AT91C_TC0_RA              (0xFFFA0014) // (TC0) Register A

+#define AT91C_TC0_IDR             (0xFFFA0028) // (TC0) Interrupt Disable Register

+#define AT91C_TC0_CV              (0xFFFA0010) // (TC0) Counter Value

+#define AT91C_TC0_IMR             (0xFFFA002C) // (TC0) Interrupt Mask Register

+// ========== Register definition for TC1 peripheral ========== 

+#define AT91C_TC1_RB              (0xFFFA0058) // (TC1) Register B

+#define AT91C_TC1_CCR             (0xFFFA0040) // (TC1) Channel Control Register

+#define AT91C_TC1_IER             (0xFFFA0064) // (TC1) Interrupt Enable Register

+#define AT91C_TC1_IDR             (0xFFFA0068) // (TC1) Interrupt Disable Register

+#define AT91C_TC1_SR              (0xFFFA0060) // (TC1) Status Register

+#define AT91C_TC1_CMR             (0xFFFA0044) // (TC1) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC1_RA              (0xFFFA0054) // (TC1) Register A

+#define AT91C_TC1_RC              (0xFFFA005C) // (TC1) Register C

+#define AT91C_TC1_IMR             (0xFFFA006C) // (TC1) Interrupt Mask Register

+#define AT91C_TC1_CV              (0xFFFA0050) // (TC1) Counter Value

+// ========== Register definition for TC2 peripheral ========== 

+#define AT91C_TC2_CMR             (0xFFFA0084) // (TC2) Channel Mode Register (Capture Mode / Waveform Mode)

+#define AT91C_TC2_CCR             (0xFFFA0080) // (TC2) Channel Control Register

+#define AT91C_TC2_CV              (0xFFFA0090) // (TC2) Counter Value

+#define AT91C_TC2_RA              (0xFFFA0094) // (TC2) Register A

+#define AT91C_TC2_RB              (0xFFFA0098) // (TC2) Register B

+#define AT91C_TC2_IDR             (0xFFFA00A8) // (TC2) Interrupt Disable Register

+#define AT91C_TC2_IMR             (0xFFFA00AC) // (TC2) Interrupt Mask Register

+#define AT91C_TC2_RC              (0xFFFA009C) // (TC2) Register C

+#define AT91C_TC2_IER             (0xFFFA00A4) // (TC2) Interrupt Enable Register

+#define AT91C_TC2_SR              (0xFFFA00A0) // (TC2) Status Register

+// ========== Register definition for TCB peripheral ========== 

+#define AT91C_TCB_BMR             (0xFFFA00C4) // (TCB) TC Block Mode Register

+#define AT91C_TCB_BCR             (0xFFFA00C0) // (TCB) TC Block Control Register

+// ========== Register definition for CAN_MB0 peripheral ========== 

+#define AT91C_CAN_MB0_MDL         (0xFFFD0214) // (CAN_MB0) MailBox Data Low Register

+#define AT91C_CAN_MB0_MAM         (0xFFFD0204) // (CAN_MB0) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB0_MCR         (0xFFFD021C) // (CAN_MB0) MailBox Control Register

+#define AT91C_CAN_MB0_MID         (0xFFFD0208) // (CAN_MB0) MailBox ID Register

+#define AT91C_CAN_MB0_MSR         (0xFFFD0210) // (CAN_MB0) MailBox Status Register

+#define AT91C_CAN_MB0_MFID        (0xFFFD020C) // (CAN_MB0) MailBox Family ID Register

+#define AT91C_CAN_MB0_MDH         (0xFFFD0218) // (CAN_MB0) MailBox Data High Register

+#define AT91C_CAN_MB0_MMR         (0xFFFD0200) // (CAN_MB0) MailBox Mode Register

+// ========== Register definition for CAN_MB1 peripheral ========== 

+#define AT91C_CAN_MB1_MDL         (0xFFFD0234) // (CAN_MB1) MailBox Data Low Register

+#define AT91C_CAN_MB1_MID         (0xFFFD0228) // (CAN_MB1) MailBox ID Register

+#define AT91C_CAN_MB1_MMR         (0xFFFD0220) // (CAN_MB1) MailBox Mode Register

+#define AT91C_CAN_MB1_MSR         (0xFFFD0230) // (CAN_MB1) MailBox Status Register

+#define AT91C_CAN_MB1_MAM         (0xFFFD0224) // (CAN_MB1) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB1_MDH         (0xFFFD0238) // (CAN_MB1) MailBox Data High Register

+#define AT91C_CAN_MB1_MCR         (0xFFFD023C) // (CAN_MB1) MailBox Control Register

+#define AT91C_CAN_MB1_MFID        (0xFFFD022C) // (CAN_MB1) MailBox Family ID Register

+// ========== Register definition for CAN_MB2 peripheral ========== 

+#define AT91C_CAN_MB2_MCR         (0xFFFD025C) // (CAN_MB2) MailBox Control Register

+#define AT91C_CAN_MB2_MDH         (0xFFFD0258) // (CAN_MB2) MailBox Data High Register

+#define AT91C_CAN_MB2_MID         (0xFFFD0248) // (CAN_MB2) MailBox ID Register

+#define AT91C_CAN_MB2_MDL         (0xFFFD0254) // (CAN_MB2) MailBox Data Low Register

+#define AT91C_CAN_MB2_MMR         (0xFFFD0240) // (CAN_MB2) MailBox Mode Register

+#define AT91C_CAN_MB2_MAM         (0xFFFD0244) // (CAN_MB2) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB2_MFID        (0xFFFD024C) // (CAN_MB2) MailBox Family ID Register

+#define AT91C_CAN_MB2_MSR         (0xFFFD0250) // (CAN_MB2) MailBox Status Register

+// ========== Register definition for CAN_MB3 peripheral ========== 

+#define AT91C_CAN_MB3_MFID        (0xFFFD026C) // (CAN_MB3) MailBox Family ID Register

+#define AT91C_CAN_MB3_MAM         (0xFFFD0264) // (CAN_MB3) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB3_MID         (0xFFFD0268) // (CAN_MB3) MailBox ID Register

+#define AT91C_CAN_MB3_MCR         (0xFFFD027C) // (CAN_MB3) MailBox Control Register

+#define AT91C_CAN_MB3_MMR         (0xFFFD0260) // (CAN_MB3) MailBox Mode Register

+#define AT91C_CAN_MB3_MSR         (0xFFFD0270) // (CAN_MB3) MailBox Status Register

+#define AT91C_CAN_MB3_MDL         (0xFFFD0274) // (CAN_MB3) MailBox Data Low Register

+#define AT91C_CAN_MB3_MDH         (0xFFFD0278) // (CAN_MB3) MailBox Data High Register

+// ========== Register definition for CAN_MB4 peripheral ========== 

+#define AT91C_CAN_MB4_MID         (0xFFFD0288) // (CAN_MB4) MailBox ID Register

+#define AT91C_CAN_MB4_MMR         (0xFFFD0280) // (CAN_MB4) MailBox Mode Register

+#define AT91C_CAN_MB4_MDH         (0xFFFD0298) // (CAN_MB4) MailBox Data High Register

+#define AT91C_CAN_MB4_MFID        (0xFFFD028C) // (CAN_MB4) MailBox Family ID Register

+#define AT91C_CAN_MB4_MSR         (0xFFFD0290) // (CAN_MB4) MailBox Status Register

+#define AT91C_CAN_MB4_MCR         (0xFFFD029C) // (CAN_MB4) MailBox Control Register

+#define AT91C_CAN_MB4_MDL         (0xFFFD0294) // (CAN_MB4) MailBox Data Low Register

+#define AT91C_CAN_MB4_MAM         (0xFFFD0284) // (CAN_MB4) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB5 peripheral ========== 

+#define AT91C_CAN_MB5_MSR         (0xFFFD02B0) // (CAN_MB5) MailBox Status Register

+#define AT91C_CAN_MB5_MCR         (0xFFFD02BC) // (CAN_MB5) MailBox Control Register

+#define AT91C_CAN_MB5_MFID        (0xFFFD02AC) // (CAN_MB5) MailBox Family ID Register

+#define AT91C_CAN_MB5_MDH         (0xFFFD02B8) // (CAN_MB5) MailBox Data High Register

+#define AT91C_CAN_MB5_MID         (0xFFFD02A8) // (CAN_MB5) MailBox ID Register

+#define AT91C_CAN_MB5_MMR         (0xFFFD02A0) // (CAN_MB5) MailBox Mode Register

+#define AT91C_CAN_MB5_MDL         (0xFFFD02B4) // (CAN_MB5) MailBox Data Low Register

+#define AT91C_CAN_MB5_MAM         (0xFFFD02A4) // (CAN_MB5) MailBox Acceptance Mask Register

+// ========== Register definition for CAN_MB6 peripheral ========== 

+#define AT91C_CAN_MB6_MFID        (0xFFFD02CC) // (CAN_MB6) MailBox Family ID Register

+#define AT91C_CAN_MB6_MID         (0xFFFD02C8) // (CAN_MB6) MailBox ID Register

+#define AT91C_CAN_MB6_MAM         (0xFFFD02C4) // (CAN_MB6) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB6_MSR         (0xFFFD02D0) // (CAN_MB6) MailBox Status Register

+#define AT91C_CAN_MB6_MDL         (0xFFFD02D4) // (CAN_MB6) MailBox Data Low Register

+#define AT91C_CAN_MB6_MCR         (0xFFFD02DC) // (CAN_MB6) MailBox Control Register

+#define AT91C_CAN_MB6_MDH         (0xFFFD02D8) // (CAN_MB6) MailBox Data High Register

+#define AT91C_CAN_MB6_MMR         (0xFFFD02C0) // (CAN_MB6) MailBox Mode Register

+// ========== Register definition for CAN_MB7 peripheral ========== 

+#define AT91C_CAN_MB7_MCR         (0xFFFD02FC) // (CAN_MB7) MailBox Control Register

+#define AT91C_CAN_MB7_MDH         (0xFFFD02F8) // (CAN_MB7) MailBox Data High Register

+#define AT91C_CAN_MB7_MFID        (0xFFFD02EC) // (CAN_MB7) MailBox Family ID Register

+#define AT91C_CAN_MB7_MDL         (0xFFFD02F4) // (CAN_MB7) MailBox Data Low Register

+#define AT91C_CAN_MB7_MID         (0xFFFD02E8) // (CAN_MB7) MailBox ID Register

+#define AT91C_CAN_MB7_MMR         (0xFFFD02E0) // (CAN_MB7) MailBox Mode Register

+#define AT91C_CAN_MB7_MAM         (0xFFFD02E4) // (CAN_MB7) MailBox Acceptance Mask Register

+#define AT91C_CAN_MB7_MSR         (0xFFFD02F0) // (CAN_MB7) MailBox Status Register

+// ========== Register definition for CAN peripheral ========== 

+#define AT91C_CAN_TCR             (0xFFFD0024) // (CAN) Transfer Command Register

+#define AT91C_CAN_IMR             (0xFFFD000C) // (CAN) Interrupt Mask Register

+#define AT91C_CAN_IER             (0xFFFD0004) // (CAN) Interrupt Enable Register

+#define AT91C_CAN_ECR             (0xFFFD0020) // (CAN) Error Counter Register

+#define AT91C_CAN_TIMESTP         (0xFFFD001C) // (CAN) Time Stamp Register

+#define AT91C_CAN_MR              (0xFFFD0000) // (CAN) Mode Register

+#define AT91C_CAN_IDR             (0xFFFD0008) // (CAN) Interrupt Disable Register

+#define AT91C_CAN_ACR             (0xFFFD0028) // (CAN) Abort Command Register

+#define AT91C_CAN_TIM             (0xFFFD0018) // (CAN) Timer Register

+#define AT91C_CAN_SR              (0xFFFD0010) // (CAN) Status Register

+#define AT91C_CAN_BR              (0xFFFD0014) // (CAN) Baudrate Register

+#define AT91C_CAN_VR              (0xFFFD00FC) // (CAN) Version Register

+// ========== Register definition for EMAC peripheral ========== 

+#define AT91C_EMAC_ISR            (0xFFFDC024) // (EMAC) Interrupt Status Register

+#define AT91C_EMAC_SA4H           (0xFFFDC0B4) // (EMAC) Specific Address 4 Top, Last 2 bytes

+#define AT91C_EMAC_SA1L           (0xFFFDC098) // (EMAC) Specific Address 1 Bottom, First 4 bytes

+#define AT91C_EMAC_ELE            (0xFFFDC078) // (EMAC) Excessive Length Errors Register

+#define AT91C_EMAC_LCOL           (0xFFFDC05C) // (EMAC) Late Collision Register

+#define AT91C_EMAC_RLE            (0xFFFDC088) // (EMAC) Receive Length Field Mismatch Register

+#define AT91C_EMAC_WOL            (0xFFFDC0C4) // (EMAC) Wake On LAN Register

+#define AT91C_EMAC_DTF            (0xFFFDC058) // (EMAC) Deferred Transmission Frame Register

+#define AT91C_EMAC_TUND           (0xFFFDC064) // (EMAC) Transmit Underrun Error Register

+#define AT91C_EMAC_NCR            (0xFFFDC000) // (EMAC) Network Control Register

+#define AT91C_EMAC_SA4L           (0xFFFDC0B0) // (EMAC) Specific Address 4 Bottom, First 4 bytes

+#define AT91C_EMAC_RSR            (0xFFFDC020) // (EMAC) Receive Status Register

+#define AT91C_EMAC_SA3L           (0xFFFDC0A8) // (EMAC) Specific Address 3 Bottom, First 4 bytes

+#define AT91C_EMAC_TSR            (0xFFFDC014) // (EMAC) Transmit Status Register

+#define AT91C_EMAC_IDR            (0xFFFDC02C) // (EMAC) Interrupt Disable Register

+#define AT91C_EMAC_RSE            (0xFFFDC074) // (EMAC) Receive Symbol Errors Register

+#define AT91C_EMAC_ECOL           (0xFFFDC060) // (EMAC) Excessive Collision Register

+#define AT91C_EMAC_TID            (0xFFFDC0B8) // (EMAC) Type ID Checking Register

+#define AT91C_EMAC_HRB            (0xFFFDC090) // (EMAC) Hash Address Bottom[31:0]

+#define AT91C_EMAC_TBQP           (0xFFFDC01C) // (EMAC) Transmit Buffer Queue Pointer

+#define AT91C_EMAC_USRIO          (0xFFFDC0C0) // (EMAC) USER Input/Output Register

+#define AT91C_EMAC_PTR            (0xFFFDC038) // (EMAC) Pause Time Register

+#define AT91C_EMAC_SA2H           (0xFFFDC0A4) // (EMAC) Specific Address 2 Top, Last 2 bytes

+#define AT91C_EMAC_ROV            (0xFFFDC070) // (EMAC) Receive Overrun Errors Register

+#define AT91C_EMAC_ALE            (0xFFFDC054) // (EMAC) Alignment Error Register

+#define AT91C_EMAC_RJA            (0xFFFDC07C) // (EMAC) Receive Jabbers Register

+#define AT91C_EMAC_RBQP           (0xFFFDC018) // (EMAC) Receive Buffer Queue Pointer

+#define AT91C_EMAC_TPF            (0xFFFDC08C) // (EMAC) Transmitted Pause Frames Register

+#define AT91C_EMAC_NCFGR          (0xFFFDC004) // (EMAC) Network Configuration Register

+#define AT91C_EMAC_HRT            (0xFFFDC094) // (EMAC) Hash Address Top[63:32]

+#define AT91C_EMAC_USF            (0xFFFDC080) // (EMAC) Undersize Frames Register

+#define AT91C_EMAC_FCSE           (0xFFFDC050) // (EMAC) Frame Check Sequence Error Register

+#define AT91C_EMAC_TPQ            (0xFFFDC0BC) // (EMAC) Transmit Pause Quantum Register

+#define AT91C_EMAC_MAN            (0xFFFDC034) // (EMAC) PHY Maintenance Register

+#define AT91C_EMAC_FTO            (0xFFFDC040) // (EMAC) Frames Transmitted OK Register

+#define AT91C_EMAC_REV            (0xFFFDC0FC) // (EMAC) Revision Register

+#define AT91C_EMAC_IMR            (0xFFFDC030) // (EMAC) Interrupt Mask Register

+#define AT91C_EMAC_SCF            (0xFFFDC044) // (EMAC) Single Collision Frame Register

+#define AT91C_EMAC_PFR            (0xFFFDC03C) // (EMAC) Pause Frames received Register

+#define AT91C_EMAC_MCF            (0xFFFDC048) // (EMAC) Multiple Collision Frame Register

+#define AT91C_EMAC_NSR            (0xFFFDC008) // (EMAC) Network Status Register

+#define AT91C_EMAC_SA2L           (0xFFFDC0A0) // (EMAC) Specific Address 2 Bottom, First 4 bytes

+#define AT91C_EMAC_FRO            (0xFFFDC04C) // (EMAC) Frames Received OK Register

+#define AT91C_EMAC_IER            (0xFFFDC028) // (EMAC) Interrupt Enable Register

+#define AT91C_EMAC_SA1H           (0xFFFDC09C) // (EMAC) Specific Address 1 Top, Last 2 bytes

+#define AT91C_EMAC_CSE            (0xFFFDC068) // (EMAC) Carrier Sense Error Register

+#define AT91C_EMAC_SA3H           (0xFFFDC0AC) // (EMAC) Specific Address 3 Top, Last 2 bytes

+#define AT91C_EMAC_RRE            (0xFFFDC06C) // (EMAC) Receive Ressource Error Register

+#define AT91C_EMAC_STE            (0xFFFDC084) // (EMAC) SQE Test Error Register

+// ========== Register definition for PDC_ADC peripheral ========== 

+#define AT91C_ADC_PTSR            (0xFFFD8124) // (PDC_ADC) PDC Transfer Status Register

+#define AT91C_ADC_PTCR            (0xFFFD8120) // (PDC_ADC) PDC Transfer Control Register

+#define AT91C_ADC_TNPR            (0xFFFD8118) // (PDC_ADC) Transmit Next Pointer Register

+#define AT91C_ADC_TNCR            (0xFFFD811C) // (PDC_ADC) Transmit Next Counter Register

+#define AT91C_ADC_RNPR            (0xFFFD8110) // (PDC_ADC) Receive Next Pointer Register

+#define AT91C_ADC_RNCR            (0xFFFD8114) // (PDC_ADC) Receive Next Counter Register

+#define AT91C_ADC_RPR             (0xFFFD8100) // (PDC_ADC) Receive Pointer Register

+#define AT91C_ADC_TCR             (0xFFFD810C) // (PDC_ADC) Transmit Counter Register

+#define AT91C_ADC_TPR             (0xFFFD8108) // (PDC_ADC) Transmit Pointer Register

+#define AT91C_ADC_RCR             (0xFFFD8104) // (PDC_ADC) Receive Counter Register

+// ========== Register definition for ADC peripheral ========== 

+#define AT91C_ADC_CDR2            (0xFFFD8038) // (ADC) ADC Channel Data Register 2

+#define AT91C_ADC_CDR3            (0xFFFD803C) // (ADC) ADC Channel Data Register 3

+#define AT91C_ADC_CDR0            (0xFFFD8030) // (ADC) ADC Channel Data Register 0

+#define AT91C_ADC_CDR5            (0xFFFD8044) // (ADC) ADC Channel Data Register 5

+#define AT91C_ADC_CHDR            (0xFFFD8014) // (ADC) ADC Channel Disable Register

+#define AT91C_ADC_SR              (0xFFFD801C) // (ADC) ADC Status Register

+#define AT91C_ADC_CDR4            (0xFFFD8040) // (ADC) ADC Channel Data Register 4

+#define AT91C_ADC_CDR1            (0xFFFD8034) // (ADC) ADC Channel Data Register 1

+#define AT91C_ADC_LCDR            (0xFFFD8020) // (ADC) ADC Last Converted Data Register

+#define AT91C_ADC_IDR             (0xFFFD8028) // (ADC) ADC Interrupt Disable Register

+#define AT91C_ADC_CR              (0xFFFD8000) // (ADC) ADC Control Register

+#define AT91C_ADC_CDR7            (0xFFFD804C) // (ADC) ADC Channel Data Register 7

+#define AT91C_ADC_CDR6            (0xFFFD8048) // (ADC) ADC Channel Data Register 6

+#define AT91C_ADC_IER             (0xFFFD8024) // (ADC) ADC Interrupt Enable Register

+#define AT91C_ADC_CHER            (0xFFFD8010) // (ADC) ADC Channel Enable Register

+#define AT91C_ADC_CHSR            (0xFFFD8018) // (ADC) ADC Channel Status Register

+#define AT91C_ADC_MR              (0xFFFD8004) // (ADC) ADC Mode Register

+#define AT91C_ADC_IMR             (0xFFFD802C) // (ADC) ADC Interrupt Mask Register

+// ========== Register definition for PDC_AES peripheral ========== 

+#define AT91C_AES_TPR             (0xFFFA4108) // (PDC_AES) Transmit Pointer Register

+#define AT91C_AES_PTCR            (0xFFFA4120) // (PDC_AES) PDC Transfer Control Register

+#define AT91C_AES_RNPR            (0xFFFA4110) // (PDC_AES) Receive Next Pointer Register

+#define AT91C_AES_TNCR            (0xFFFA411C) // (PDC_AES) Transmit Next Counter Register

+#define AT91C_AES_TCR             (0xFFFA410C) // (PDC_AES) Transmit Counter Register

+#define AT91C_AES_RCR             (0xFFFA4104) // (PDC_AES) Receive Counter Register

+#define AT91C_AES_RNCR            (0xFFFA4114) // (PDC_AES) Receive Next Counter Register

+#define AT91C_AES_TNPR            (0xFFFA4118) // (PDC_AES) Transmit Next Pointer Register

+#define AT91C_AES_RPR             (0xFFFA4100) // (PDC_AES) Receive Pointer Register

+#define AT91C_AES_PTSR            (0xFFFA4124) // (PDC_AES) PDC Transfer Status Register

+// ========== Register definition for AES peripheral ========== 

+#define AT91C_AES_IVxR            (0xFFFA4060) // (AES) Initialization Vector x Register

+#define AT91C_AES_MR              (0xFFFA4004) // (AES) Mode Register

+#define AT91C_AES_VR              (0xFFFA40FC) // (AES) AES Version Register

+#define AT91C_AES_ODATAxR         (0xFFFA4050) // (AES) Output Data x Register

+#define AT91C_AES_IDATAxR         (0xFFFA4040) // (AES) Input Data x Register

+#define AT91C_AES_CR              (0xFFFA4000) // (AES) Control Register

+#define AT91C_AES_IDR             (0xFFFA4014) // (AES) Interrupt Disable Register

+#define AT91C_AES_IMR             (0xFFFA4018) // (AES) Interrupt Mask Register

+#define AT91C_AES_IER             (0xFFFA4010) // (AES) Interrupt Enable Register

+#define AT91C_AES_KEYWxR          (0xFFFA4020) // (AES) Key Word x Register

+#define AT91C_AES_ISR             (0xFFFA401C) // (AES) Interrupt Status Register

+// ========== Register definition for PDC_TDES peripheral ========== 

+#define AT91C_TDES_RNCR           (0xFFFA8114) // (PDC_TDES) Receive Next Counter Register

+#define AT91C_TDES_TCR            (0xFFFA810C) // (PDC_TDES) Transmit Counter Register

+#define AT91C_TDES_RCR            (0xFFFA8104) // (PDC_TDES) Receive Counter Register

+#define AT91C_TDES_TNPR           (0xFFFA8118) // (PDC_TDES) Transmit Next Pointer Register

+#define AT91C_TDES_RNPR           (0xFFFA8110) // (PDC_TDES) Receive Next Pointer Register

+#define AT91C_TDES_RPR            (0xFFFA8100) // (PDC_TDES) Receive Pointer Register

+#define AT91C_TDES_TNCR           (0xFFFA811C) // (PDC_TDES) Transmit Next Counter Register

+#define AT91C_TDES_TPR            (0xFFFA8108) // (PDC_TDES) Transmit Pointer Register

+#define AT91C_TDES_PTSR           (0xFFFA8124) // (PDC_TDES) PDC Transfer Status Register

+#define AT91C_TDES_PTCR           (0xFFFA8120) // (PDC_TDES) PDC Transfer Control Register

+// ========== Register definition for TDES peripheral ========== 

+#define AT91C_TDES_KEY2WxR        (0xFFFA8028) // (TDES) Key 2 Word x Register

+#define AT91C_TDES_KEY3WxR        (0xFFFA8030) // (TDES) Key 3 Word x Register

+#define AT91C_TDES_IDR            (0xFFFA8014) // (TDES) Interrupt Disable Register

+#define AT91C_TDES_VR             (0xFFFA80FC) // (TDES) TDES Version Register

+#define AT91C_TDES_IVxR           (0xFFFA8060) // (TDES) Initialization Vector x Register

+#define AT91C_TDES_ODATAxR        (0xFFFA8050) // (TDES) Output Data x Register

+#define AT91C_TDES_IMR            (0xFFFA8018) // (TDES) Interrupt Mask Register

+#define AT91C_TDES_MR             (0xFFFA8004) // (TDES) Mode Register

+#define AT91C_TDES_CR             (0xFFFA8000) // (TDES) Control Register

+#define AT91C_TDES_IER            (0xFFFA8010) // (TDES) Interrupt Enable Register

+#define AT91C_TDES_ISR            (0xFFFA801C) // (TDES) Interrupt Status Register

+#define AT91C_TDES_IDATAxR        (0xFFFA8040) // (TDES) Input Data x Register

+#define AT91C_TDES_KEY1WxR        (0xFFFA8020) // (TDES) Key 1 Word x Register

+

+// *****************************************************************************

+//               PIO DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_PIO_PA0             (1 <<  0) // Pin Controlled by PA0

+#define AT91C_PA0_RXD0            (AT91C_PIO_PA0) //  USART 0 Receive Data

+#define AT91C_PIO_PA1             (1 <<  1) // Pin Controlled by PA1

+#define AT91C_PA1_TXD0            (AT91C_PIO_PA1) //  USART 0 Transmit Data

+#define AT91C_PIO_PA10            (1 << 10) // Pin Controlled by PA10

+#define AT91C_PA10_TWD            (AT91C_PIO_PA10) //  TWI Two-wire Serial Data

+#define AT91C_PIO_PA11            (1 << 11) // Pin Controlled by PA11

+#define AT91C_PA11_TWCK           (AT91C_PIO_PA11) //  TWI Two-wire Serial Clock

+#define AT91C_PIO_PA12            (1 << 12) // Pin Controlled by PA12

+#define AT91C_PA12_NPCS00         (AT91C_PIO_PA12) //  SPI 0 Peripheral Chip Select 0

+#define AT91C_PIO_PA13            (1 << 13) // Pin Controlled by PA13

+#define AT91C_PA13_NPCS01         (AT91C_PIO_PA13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PA13_PCK1           (AT91C_PIO_PA13) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PA14            (1 << 14) // Pin Controlled by PA14

+#define AT91C_PA14_NPCS02         (AT91C_PIO_PA14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PA14_IRQ1           (AT91C_PIO_PA14) //  External Interrupt 1

+#define AT91C_PIO_PA15            (1 << 15) // Pin Controlled by PA15

+#define AT91C_PA15_NPCS03         (AT91C_PIO_PA15) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PA15_TCLK2          (AT91C_PIO_PA15) //  Timer Counter 2 external clock input

+#define AT91C_PIO_PA16            (1 << 16) // Pin Controlled by PA16

+#define AT91C_PA16_MISO0          (AT91C_PIO_PA16) //  SPI 0 Master In Slave

+#define AT91C_PIO_PA17            (1 << 17) // Pin Controlled by PA17

+#define AT91C_PA17_MOSI0          (AT91C_PIO_PA17) //  SPI 0 Master Out Slave

+#define AT91C_PIO_PA18            (1 << 18) // Pin Controlled by PA18

+#define AT91C_PA18_SPCK0          (AT91C_PIO_PA18) //  SPI 0 Serial Clock

+#define AT91C_PIO_PA19            (1 << 19) // Pin Controlled by PA19

+#define AT91C_PA19_CANRX          (AT91C_PIO_PA19) //  CAN Receive

+#define AT91C_PIO_PA2             (1 <<  2) // Pin Controlled by PA2

+#define AT91C_PA2_SCK0            (AT91C_PIO_PA2) //  USART 0 Serial Clock

+#define AT91C_PA2_NPCS11          (AT91C_PIO_PA2) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA20            (1 << 20) // Pin Controlled by PA20

+#define AT91C_PA20_CANTX          (AT91C_PIO_PA20) //  CAN Transmit

+#define AT91C_PIO_PA21            (1 << 21) // Pin Controlled by PA21

+#define AT91C_PA21_TF             (AT91C_PIO_PA21) //  SSC Transmit Frame Sync

+#define AT91C_PA21_NPCS10         (AT91C_PIO_PA21) //  SPI 1 Peripheral Chip Select 0

+#define AT91C_PIO_PA22            (1 << 22) // Pin Controlled by PA22

+#define AT91C_PA22_TK             (AT91C_PIO_PA22) //  SSC Transmit Clock

+#define AT91C_PA22_SPCK1          (AT91C_PIO_PA22) //  SPI 1 Serial Clock

+#define AT91C_PIO_PA23            (1 << 23) // Pin Controlled by PA23

+#define AT91C_PA23_TD             (AT91C_PIO_PA23) //  SSC Transmit data

+#define AT91C_PA23_MOSI1          (AT91C_PIO_PA23) //  SPI 1 Master Out Slave

+#define AT91C_PIO_PA24            (1 << 24) // Pin Controlled by PA24

+#define AT91C_PA24_RD             (AT91C_PIO_PA24) //  SSC Receive Data

+#define AT91C_PA24_MISO1          (AT91C_PIO_PA24) //  SPI 1 Master In Slave

+#define AT91C_PIO_PA25            (1 << 25) // Pin Controlled by PA25

+#define AT91C_PA25_RK             (AT91C_PIO_PA25) //  SSC Receive Clock

+#define AT91C_PA25_NPCS11         (AT91C_PIO_PA25) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PA26            (1 << 26) // Pin Controlled by PA26

+#define AT91C_PA26_RF             (AT91C_PIO_PA26) //  SSC Receive Frame Sync

+#define AT91C_PA26_NPCS12         (AT91C_PIO_PA26) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA27            (1 << 27) // Pin Controlled by PA27

+#define AT91C_PA27_DRXD           (AT91C_PIO_PA27) //  DBGU Debug Receive Data

+#define AT91C_PA27_PCK3           (AT91C_PIO_PA27) //  PMC Programmable Clock Output 3

+#define AT91C_PIO_PA28            (1 << 28) // Pin Controlled by PA28

+#define AT91C_PA28_DTXD           (AT91C_PIO_PA28) //  DBGU Debug Transmit Data

+#define AT91C_PIO_PA29            (1 << 29) // Pin Controlled by PA29

+#define AT91C_PA29_FIQ            (AT91C_PIO_PA29) //  AIC Fast Interrupt Input

+#define AT91C_PA29_NPCS13         (AT91C_PIO_PA29) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA3             (1 <<  3) // Pin Controlled by PA3

+#define AT91C_PA3_RTS0            (AT91C_PIO_PA3) //  USART 0 Ready To Send

+#define AT91C_PA3_NPCS12          (AT91C_PIO_PA3) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PA30            (1 << 30) // Pin Controlled by PA30

+#define AT91C_PA30_IRQ0           (AT91C_PIO_PA30) //  External Interrupt 0

+#define AT91C_PA30_PCK2           (AT91C_PIO_PA30) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PA4             (1 <<  4) // Pin Controlled by PA4

+#define AT91C_PA4_CTS0            (AT91C_PIO_PA4) //  USART 0 Clear To Send

+#define AT91C_PA4_NPCS13          (AT91C_PIO_PA4) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PA5             (1 <<  5) // Pin Controlled by PA5

+#define AT91C_PA5_RXD1            (AT91C_PIO_PA5) //  USART 1 Receive Data

+#define AT91C_PIO_PA6             (1 <<  6) // Pin Controlled by PA6

+#define AT91C_PA6_TXD1            (AT91C_PIO_PA6) //  USART 1 Transmit Data

+#define AT91C_PIO_PA7             (1 <<  7) // Pin Controlled by PA7

+#define AT91C_PA7_SCK1            (AT91C_PIO_PA7) //  USART 1 Serial Clock

+#define AT91C_PA7_NPCS01          (AT91C_PIO_PA7) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PA8             (1 <<  8) // Pin Controlled by PA8

+#define AT91C_PA8_RTS1            (AT91C_PIO_PA8) //  USART 1 Ready To Send

+#define AT91C_PA8_NPCS02          (AT91C_PIO_PA8) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PA9             (1 <<  9) // Pin Controlled by PA9

+#define AT91C_PA9_CTS1            (AT91C_PIO_PA9) //  USART 1 Clear To Send

+#define AT91C_PA9_NPCS03          (AT91C_PIO_PA9) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB0             (1 <<  0) // Pin Controlled by PB0

+#define AT91C_PB0_ETXCK_EREFCK    (AT91C_PIO_PB0) //  Ethernet MAC Transmit Clock/Reference Clock

+#define AT91C_PB0_PCK0            (AT91C_PIO_PB0) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB1             (1 <<  1) // Pin Controlled by PB1

+#define AT91C_PB1_ETXEN           (AT91C_PIO_PB1) //  Ethernet MAC Transmit Enable

+#define AT91C_PIO_PB10            (1 << 10) // Pin Controlled by PB10

+#define AT91C_PB10_ETX2           (AT91C_PIO_PB10) //  Ethernet MAC Transmit Data 2

+#define AT91C_PB10_NPCS11         (AT91C_PIO_PB10) //  SPI 1 Peripheral Chip Select 1

+#define AT91C_PIO_PB11            (1 << 11) // Pin Controlled by PB11

+#define AT91C_PB11_ETX3           (AT91C_PIO_PB11) //  Ethernet MAC Transmit Data 3

+#define AT91C_PB11_NPCS12         (AT91C_PIO_PB11) //  SPI 1 Peripheral Chip Select 2

+#define AT91C_PIO_PB12            (1 << 12) // Pin Controlled by PB12

+#define AT91C_PB12_ETXER          (AT91C_PIO_PB12) //  Ethernet MAC Transmikt Coding Error

+#define AT91C_PB12_TCLK0          (AT91C_PIO_PB12) //  Timer Counter 0 external clock input

+#define AT91C_PIO_PB13            (1 << 13) // Pin Controlled by PB13

+#define AT91C_PB13_ERX2           (AT91C_PIO_PB13) //  Ethernet MAC Receive Data 2

+#define AT91C_PB13_NPCS01         (AT91C_PIO_PB13) //  SPI 0 Peripheral Chip Select 1

+#define AT91C_PIO_PB14            (1 << 14) // Pin Controlled by PB14

+#define AT91C_PB14_ERX3           (AT91C_PIO_PB14) //  Ethernet MAC Receive Data 3

+#define AT91C_PB14_NPCS02         (AT91C_PIO_PB14) //  SPI 0 Peripheral Chip Select 2

+#define AT91C_PIO_PB15            (1 << 15) // Pin Controlled by PB15

+#define AT91C_PB15_ERXDV          (AT91C_PIO_PB15) //  Ethernet MAC Receive Data Valid

+#define AT91C_PIO_PB16            (1 << 16) // Pin Controlled by PB16

+#define AT91C_PB16_ECOL           (AT91C_PIO_PB16) //  Ethernet MAC Collision Detected

+#define AT91C_PB16_NPCS13         (AT91C_PIO_PB16) //  SPI 1 Peripheral Chip Select 3

+#define AT91C_PIO_PB17            (1 << 17) // Pin Controlled by PB17

+#define AT91C_PB17_ERXCK          (AT91C_PIO_PB17) //  Ethernet MAC Receive Clock

+#define AT91C_PB17_NPCS03         (AT91C_PIO_PB17) //  SPI 0 Peripheral Chip Select 3

+#define AT91C_PIO_PB18            (1 << 18) // Pin Controlled by PB18

+#define AT91C_PB18_EF100          (AT91C_PIO_PB18) //  Ethernet MAC Force 100 Mbits/sec

+#define AT91C_PB18_ADTRG          (AT91C_PIO_PB18) //  ADC External Trigger

+#define AT91C_PIO_PB19            (1 << 19) // Pin Controlled by PB19

+#define AT91C_PB19_PWM0           (AT91C_PIO_PB19) //  PWM Channel 0

+#define AT91C_PB19_TCLK1          (AT91C_PIO_PB19) //  Timer Counter 1 external clock input

+#define AT91C_PIO_PB2             (1 <<  2) // Pin Controlled by PB2

+#define AT91C_PB2_ETX0            (AT91C_PIO_PB2) //  Ethernet MAC Transmit Data 0

+#define AT91C_PIO_PB20            (1 << 20) // Pin Controlled by PB20

+#define AT91C_PB20_PWM1           (AT91C_PIO_PB20) //  PWM Channel 1

+#define AT91C_PB20_PCK0           (AT91C_PIO_PB20) //  PMC Programmable Clock Output 0

+#define AT91C_PIO_PB21            (1 << 21) // Pin Controlled by PB21

+#define AT91C_PB21_PWM2           (AT91C_PIO_PB21) //  PWM Channel 2

+#define AT91C_PB21_PCK1           (AT91C_PIO_PB21) //  PMC Programmable Clock Output 1

+#define AT91C_PIO_PB22            (1 << 22) // Pin Controlled by PB22

+#define AT91C_PB22_PWM3           (AT91C_PIO_PB22) //  PWM Channel 3

+#define AT91C_PB22_PCK2           (AT91C_PIO_PB22) //  PMC Programmable Clock Output 2

+#define AT91C_PIO_PB23            (1 << 23) // Pin Controlled by PB23

+#define AT91C_PB23_TIOA0          (AT91C_PIO_PB23) //  Timer Counter 0 Multipurpose Timer I/O Pin A

+#define AT91C_PB23_DCD1           (AT91C_PIO_PB23) //  USART 1 Data Carrier Detect

+#define AT91C_PIO_PB24            (1 << 24) // Pin Controlled by PB24

+#define AT91C_PB24_TIOB0          (AT91C_PIO_PB24) //  Timer Counter 0 Multipurpose Timer I/O Pin B

+#define AT91C_PB24_DSR1           (AT91C_PIO_PB24) //  USART 1 Data Set ready

+#define AT91C_PIO_PB25            (1 << 25) // Pin Controlled by PB25

+#define AT91C_PB25_TIOA1          (AT91C_PIO_PB25) //  Timer Counter 1 Multipurpose Timer I/O Pin A

+#define AT91C_PB25_DTR1           (AT91C_PIO_PB25) //  USART 1 Data Terminal ready

+#define AT91C_PIO_PB26            (1 << 26) // Pin Controlled by PB26

+#define AT91C_PB26_TIOB1          (AT91C_PIO_PB26) //  Timer Counter 1 Multipurpose Timer I/O Pin B

+#define AT91C_PB26_RI1            (AT91C_PIO_PB26) //  USART 1 Ring Indicator

+#define AT91C_PIO_PB27            (1 << 27) // Pin Controlled by PB27

+#define AT91C_PB27_TIOA2          (AT91C_PIO_PB27) //  Timer Counter 2 Multipurpose Timer I/O Pin A

+#define AT91C_PB27_PWM0           (AT91C_PIO_PB27) //  PWM Channel 0

+#define AT91C_PIO_PB28            (1 << 28) // Pin Controlled by PB28

+#define AT91C_PB28_TIOB2          (AT91C_PIO_PB28) //  Timer Counter 2 Multipurpose Timer I/O Pin B

+#define AT91C_PB28_PWM1           (AT91C_PIO_PB28) //  PWM Channel 1

+#define AT91C_PIO_PB29            (1 << 29) // Pin Controlled by PB29

+#define AT91C_PB29_PCK1           (AT91C_PIO_PB29) //  PMC Programmable Clock Output 1

+#define AT91C_PB29_PWM2           (AT91C_PIO_PB29) //  PWM Channel 2

+#define AT91C_PIO_PB3             (1 <<  3) // Pin Controlled by PB3

+#define AT91C_PB3_ETX1            (AT91C_PIO_PB3) //  Ethernet MAC Transmit Data 1

+#define AT91C_PIO_PB30            (1 << 30) // Pin Controlled by PB30

+#define AT91C_PB30_PCK2           (AT91C_PIO_PB30) //  PMC Programmable Clock Output 2

+#define AT91C_PB30_PWM3           (AT91C_PIO_PB30) //  PWM Channel 3

+#define AT91C_PIO_PB4             (1 <<  4) // Pin Controlled by PB4

+#define AT91C_PB4_ECRS_ECRSDV     (AT91C_PIO_PB4) //  Ethernet MAC Carrier Sense/Carrier Sense and Data Valid

+#define AT91C_PIO_PB5             (1 <<  5) // Pin Controlled by PB5

+#define AT91C_PB5_ERX0            (AT91C_PIO_PB5) //  Ethernet MAC Receive Data 0

+#define AT91C_PIO_PB6             (1 <<  6) // Pin Controlled by PB6

+#define AT91C_PB6_ERX1            (AT91C_PIO_PB6) //  Ethernet MAC Receive Data 1

+#define AT91C_PIO_PB7             (1 <<  7) // Pin Controlled by PB7

+#define AT91C_PB7_ERXER           (AT91C_PIO_PB7) //  Ethernet MAC Receive Error

+#define AT91C_PIO_PB8             (1 <<  8) // Pin Controlled by PB8

+#define AT91C_PB8_EMDC            (AT91C_PIO_PB8) //  Ethernet MAC Management Data Clock

+#define AT91C_PIO_PB9             (1 <<  9) // Pin Controlled by PB9

+#define AT91C_PB9_EMDIO           (AT91C_PIO_PB9) //  Ethernet MAC Management Data Input/Output

+

+// *****************************************************************************

+//               PERIPHERAL ID DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ID_FIQ              ( 0) // Advanced Interrupt Controller (FIQ)

+#define AT91C_ID_SYS              ( 1) // System Peripheral

+#define AT91C_ID_PIOA             ( 2) // Parallel IO Controller A

+#define AT91C_ID_PIOB             ( 3) // Parallel IO Controller B

+#define AT91C_ID_SPI0             ( 4) // Serial Peripheral Interface 0

+#define AT91C_ID_SPI1             ( 5) // Serial Peripheral Interface 1

+#define AT91C_ID_US0              ( 6) // USART 0

+#define AT91C_ID_US1              ( 7) // USART 1

+#define AT91C_ID_SSC              ( 8) // Serial Synchronous Controller

+#define AT91C_ID_TWI              ( 9) // Two-Wire Interface

+#define AT91C_ID_PWMC             (10) // PWM Controller

+#define AT91C_ID_UDP              (11) // USB Device Port

+#define AT91C_ID_TC0              (12) // Timer Counter 0

+#define AT91C_ID_TC1              (13) // Timer Counter 1

+#define AT91C_ID_TC2              (14) // Timer Counter 2

+#define AT91C_ID_CAN              (15) // Control Area Network Controller

+#define AT91C_ID_EMAC             (16) // Ethernet MAC

+#define AT91C_ID_ADC              (17) // Analog-to-Digital Converter

+#define AT91C_ID_AES              (18) // Advanced Encryption Standard 128-bit

+#define AT91C_ID_TDES             (19) // Triple Data Encryption Standard

+#define AT91C_ID_20_Reserved      (20) // Reserved

+#define AT91C_ID_21_Reserved      (21) // Reserved

+#define AT91C_ID_22_Reserved      (22) // Reserved

+#define AT91C_ID_23_Reserved      (23) // Reserved

+#define AT91C_ID_24_Reserved      (24) // Reserved

+#define AT91C_ID_25_Reserved      (25) // Reserved

+#define AT91C_ID_26_Reserved      (26) // Reserved

+#define AT91C_ID_27_Reserved      (27) // Reserved

+#define AT91C_ID_28_Reserved      (28) // Reserved

+#define AT91C_ID_29_Reserved      (29) // Reserved

+#define AT91C_ID_IRQ0             (30) // Advanced Interrupt Controller (IRQ0)

+#define AT91C_ID_IRQ1             (31) // Advanced Interrupt Controller (IRQ1)

+

+// *****************************************************************************

+//               BASE ADDRESS DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_BASE_SYS            (0xFFFFF000) // (SYS) Base Address

+#define AT91C_BASE_AIC            (0xFFFFF000) // (AIC) Base Address

+#define AT91C_BASE_PDC_DBGU       (0xFFFFF300) // (PDC_DBGU) Base Address

+#define AT91C_BASE_DBGU           (0xFFFFF200) // (DBGU) Base Address

+#define AT91C_BASE_PIOA           (0xFFFFF400) // (PIOA) Base Address

+#define AT91C_BASE_PIOB           (0xFFFFF600) // (PIOB) Base Address

+#define AT91C_BASE_CKGR           (0xFFFFFC20) // (CKGR) Base Address

+#define AT91C_BASE_PMC            (0xFFFFFC00) // (PMC) Base Address

+#define AT91C_BASE_RSTC           (0xFFFFFD00) // (RSTC) Base Address

+#define AT91C_BASE_RTTC           (0xFFFFFD20) // (RTTC) Base Address

+#define AT91C_BASE_PITC           (0xFFFFFD30) // (PITC) Base Address

+#define AT91C_BASE_WDTC           (0xFFFFFD40) // (WDTC) Base Address

+#define AT91C_BASE_VREG           (0xFFFFFD60) // (VREG) Base Address

+#define AT91C_BASE_MC             (0xFFFFFF00) // (MC) Base Address

+#define AT91C_BASE_PDC_SPI1       (0xFFFE4100) // (PDC_SPI1) Base Address

+#define AT91C_BASE_SPI1           (0xFFFE4000) // (SPI1) Base Address

+#define AT91C_BASE_PDC_SPI0       (0xFFFE0100) // (PDC_SPI0) Base Address

+#define AT91C_BASE_SPI0           (0xFFFE0000) // (SPI0) Base Address

+#define AT91C_BASE_PDC_US1        (0xFFFC4100) // (PDC_US1) Base Address

+#define AT91C_BASE_US1            (0xFFFC4000) // (US1) Base Address

+#define AT91C_BASE_PDC_US0        (0xFFFC0100) // (PDC_US0) Base Address

+#define AT91C_BASE_US0            (0xFFFC0000) // (US0) Base Address

+#define AT91C_BASE_PDC_SSC        (0xFFFD4100) // (PDC_SSC) Base Address

+#define AT91C_BASE_SSC            (0xFFFD4000) // (SSC) Base Address

+#define AT91C_BASE_TWI            (0xFFFB8000) // (TWI) Base Address

+#define AT91C_BASE_PWMC_CH3       (0xFFFCC260) // (PWMC_CH3) Base Address

+#define AT91C_BASE_PWMC_CH2       (0xFFFCC240) // (PWMC_CH2) Base Address

+#define AT91C_BASE_PWMC_CH1       (0xFFFCC220) // (PWMC_CH1) Base Address

+#define AT91C_BASE_PWMC_CH0       (0xFFFCC200) // (PWMC_CH0) Base Address

+#define AT91C_BASE_PWMC           (0xFFFCC000) // (PWMC) Base Address

+#define AT91C_BASE_UDP            (0xFFFB0000) // (UDP) Base Address

+#define AT91C_BASE_TC0            (0xFFFA0000) // (TC0) Base Address

+#define AT91C_BASE_TC1            (0xFFFA0040) // (TC1) Base Address

+#define AT91C_BASE_TC2            (0xFFFA0080) // (TC2) Base Address

+#define AT91C_BASE_TCB            (0xFFFA0000) // (TCB) Base Address

+#define AT91C_BASE_CAN_MB0        (0xFFFD0200) // (CAN_MB0) Base Address

+#define AT91C_BASE_CAN_MB1        (0xFFFD0220) // (CAN_MB1) Base Address

+#define AT91C_BASE_CAN_MB2        (0xFFFD0240) // (CAN_MB2) Base Address

+#define AT91C_BASE_CAN_MB3        (0xFFFD0260) // (CAN_MB3) Base Address

+#define AT91C_BASE_CAN_MB4        (0xFFFD0280) // (CAN_MB4) Base Address

+#define AT91C_BASE_CAN_MB5        (0xFFFD02A0) // (CAN_MB5) Base Address

+#define AT91C_BASE_CAN_MB6        (0xFFFD02C0) // (CAN_MB6) Base Address

+#define AT91C_BASE_CAN_MB7        (0xFFFD02E0) // (CAN_MB7) Base Address

+#define AT91C_BASE_CAN            (0xFFFD0000) // (CAN) Base Address

+#define AT91C_BASE_EMAC           (0xFFFDC000) // (EMAC) Base Address

+#define AT91C_BASE_PDC_ADC        (0xFFFD8100) // (PDC_ADC) Base Address

+#define AT91C_BASE_ADC            (0xFFFD8000) // (ADC) Base Address

+#define AT91C_BASE_PDC_AES        (0xFFFA4100) // (PDC_AES) Base Address

+#define AT91C_BASE_AES            (0xFFFA4000) // (AES) Base Address

+#define AT91C_BASE_PDC_TDES       (0xFFFA8100) // (PDC_TDES) Base Address

+#define AT91C_BASE_TDES           (0xFFFA8000) // (TDES) Base Address

+

+// *****************************************************************************

+//               MEMORY MAPPING DEFINITIONS FOR AT91SAM7X256

+// *****************************************************************************

+#define AT91C_ISRAM	              (0x00200000) // Internal SRAM base address

+#define AT91C_ISRAM_SIZE	         (0x00010000) // Internal SRAM size in byte (64 Kbyte)

+#define AT91C_IFLASH	             (0x00100000) // Internal ROM base address

+#define AT91C_IFLASH_SIZE	        (0x00040000) // Internal ROM size in byte (256 Kbyte)

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/ISR_Support.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/ISR_Support.h
new file mode 100644
index 0000000..8e1cb83
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/ISR_Support.h
@@ -0,0 +1,130 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7S64.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7S64.h
new file mode 100644
index 0000000..9d012c4
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7S64.h
@@ -0,0 +1,3265 @@
+//*----------------------------------------------------------------------------

+//*         ATMEL Microcontroller Software Support  -  ROUSSET  -

+//*----------------------------------------------------------------------------

+//* The software is delivered "AS IS" without warranty or condition of any

+//* kind, either express, implied or statutory. This includes without

+//* limitation any warranty or condition with respect to merchantability or

+//* fitness for any particular purpose, or against the infringements of

+//* intellectual property rights of others.

+//*----------------------------------------------------------------------------

+//* File Name           : lib_AT91SAM7S64.h

+//* Object              : AT91SAM7S64 inlined functions

+//* Generated           : AT91 SW Application Group  07/16/2004 (07:43:09)

+//*

+//* CVS Reference       : /lib_MC_SAM.h/1.3/Thu Mar 25 15:19:14 2004//

+//* CVS Reference       : /lib_pdc_1363d.h/1.2/Wed Feb 19 09:25:22 2003//

+//* CVS Reference       : /lib_dbgu.h/1.1/Fri Jan 31 12:18:40 2003//

+//* CVS Reference       : /lib_ssc.h/1.4/Fri Jan 31 12:19:20 2003//

+//* CVS Reference       : /lib_spi2.h/1.1/Mon Aug 25 13:23:52 2003//

+//* CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+//* CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+//* CVS Reference       : /lib_pmc_SAM.h/1.6/Tue Apr 27 13:53:52 2004//

+//* CVS Reference       : /lib_adc.h/1.6/Fri Oct 17 08:12:38 2003//

+//* CVS Reference       : /lib_pio.h/1.3/Fri Jan 31 12:18:56 2003//

+//* CVS Reference       : /lib_twi.h/1.2/Fri Jan 31 12:19:38 2003//

+//* CVS Reference       : /lib_usart.h/1.5/Thu Nov 21 16:01:54 2002//

+//* CVS Reference       : /lib_udp.h/1.3/Fri Jan 31 12:19:48 2003//

+//* CVS Reference       : /lib_aic.h/1.3/Fri Jul 12 07:46:12 2002//

+//*----------------------------------------------------------------------------

+

+#ifndef lib_AT91SAM7S64_H

+#define lib_AT91SAM7S64_H

+

+/* *****************************************************************************

+                SOFTWARE API FOR MC

+   ***************************************************************************** */

+

+#define AT91C_MC_CORRECT_KEY  ((unsigned int) 0x5A << 24) // (MC) Correct Protect Key

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_Remap

+//* \brief Make Remap

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_Remap (void)     //  

+{

+    AT91PS_MC pMC = (AT91PS_MC) AT91C_BASE_MC;

+    

+    pMC->MC_RCR = AT91C_MC_RCB;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_CfgModeReg

+//* \brief Configure the EFC Mode Register of the MC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_CfgModeReg (

+	AT91PS_MC pMC, // pointer to a MC controller

+	unsigned int mode)        // mode register 

+{

+	// Write to the FMR register

+	pMC->MC_FMR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetModeReg

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetModeReg(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_ComputeFMCN

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_ComputeFMCN(

+	int master_clock) // master clock in Hz

+{

+	return (master_clock/1000000 +2);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_PerformCmd

+//* \brief Perform EFC Command

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_PerformCmd (

+	AT91PS_MC pMC, // pointer to a MC controller

+    unsigned int transfer_cmd)

+{

+	pMC->MC_FCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetStatus

+//* \brief Return MC EFC Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetStatus(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptMasked

+//* \brief Test if EFC MC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptMasked(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetModeReg(pMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptSet

+//* \brief Test if EFC MC Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptSet(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetStatus(pMC) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PDC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextRx

+//* \brief Set the next receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextRx (

+	AT91PS_PDC pPDC,     // \arg pointer to a PDC controller

+	char *address,       // \arg address to the next bloc to be received

+	unsigned int bytes)  // \arg number of bytes to be received

+{

+	pPDC->PDC_RNPR = (unsigned int) address;

+	pPDC->PDC_RNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextTx

+//* \brief Set the next transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TNPR = (unsigned int) address;

+	pPDC->PDC_TNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetRx

+//* \brief Set the receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetRx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be received

+	unsigned int bytes)    // \arg number of bytes to be received

+{

+	pPDC->PDC_RPR = (unsigned int) address;

+	pPDC->PDC_RCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetTx

+//* \brief Set the transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TPR = (unsigned int) address;

+	pPDC->PDC_TCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableTx

+//* \brief Enable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableRx

+//* \brief Enable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableTx

+//* \brief Disable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableRx

+//* \brief Disable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsTxEmpty

+//* \brief Test if the current transfer descriptor has been sent

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextTxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsRxEmpty

+//* \brief Test if the current transfer descriptor has been filled

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextRxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Open

+//* \brief Open PDC: disable TX and RX reset transfer descriptors, re-enable RX and TX

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Open (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+    //* Enable the RX and TX PDC transfer requests

+	AT91F_PDC_EnableRx(pPDC);

+	AT91F_PDC_EnableTx(pPDC);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Close

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Close (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SendFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_SendFrame(

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsTxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetTx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextTx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextTxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextTx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_ReceiveFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_ReceiveFrame (

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsRxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetRx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextRx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextRxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextRx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+/* *****************************************************************************

+                SOFTWARE API FOR DBGU

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptEnable

+//* \brief Enable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptEnable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be enabled

+{

+        pDbgu->DBGU_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptDisable

+//* \brief Disable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptDisable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be disabled

+{

+        pDbgu->DBGU_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_GetInterruptMaskStatus

+//* \brief Return DBGU Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_DBGU_GetInterruptMaskStatus( // \return DBGU Interrupt Mask Status

+        AT91PS_DBGU pDbgu) // \arg  pointer to a DBGU controller

+{

+        return pDbgu->DBGU_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_IsInterruptMasked

+//* \brief Test if DBGU Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_DBGU_IsInterruptMasked(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_DBGU_GetInterruptMaskStatus(pDbgu) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SSC

+   ***************************************************************************** */

+//* Define the standard I2S mode configuration

+

+//* Configuration to set in the SSC Transmit Clock Mode Register

+//* Parameters :  nb_bit_by_slot : 8, 16 or 32 bits

+//* 			  nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_MASTER_TX_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									   AT91C_SSC_CKS_DIV   +\

+                            		   AT91C_SSC_CKO_CONTINOUS      +\

+                            		   AT91C_SSC_CKG_NONE    +\

+                                       AT91C_SSC_START_FALL_RF +\

+                           			   AT91C_SSC_STTOUT  +\

+                            		   ((1<<16) & AT91C_SSC_STTDLY) +\

+                            		   ((((nb_bit_by_slot*nb_slot_by_frame)/2)-1) <<24))

+

+

+//* Configuration to set in the SSC Transmit Frame Mode Register

+//* Parameters : nb_bit_by_slot : 8, 16 or 32 bits

+//* 			 nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_TX_FRAME_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									(nb_bit_by_slot-1)  +\

+                            		AT91C_SSC_MSBF   +\

+                            		(((nb_slot_by_frame-1)<<8) & AT91C_SSC_DATNB)  +\

+                            		(((nb_bit_by_slot-1)<<16) & AT91C_SSC_FSLEN) +\

+                            		AT91C_SSC_FSOS_NEGATIVE)

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_SetBaudrate (

+        AT91PS_SSC pSSC,        // \arg pointer to a SSC controller

+        unsigned int mainClock, // \arg peripheral clock

+        unsigned int speed)     // \arg SSC baudrate

+{

+        unsigned int baud_value;

+        //* Define the baud rate divisor register

+        if (speed == 0)

+           baud_value = 0;

+        else

+        {

+           baud_value = (unsigned int) (mainClock * 10)/(2*speed);

+           if ((baud_value % 10) >= 5)

+                  baud_value = (baud_value / 10) + 1;

+           else

+                  baud_value /= 10;

+        }

+

+        pSSC->SSC_CMR = baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_Configure

+//* \brief Configure SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_Configure (

+             AT91PS_SSC pSSC,          // \arg pointer to a SSC controller

+             unsigned int syst_clock,  // \arg System Clock Frequency

+             unsigned int baud_rate,   // \arg Expected Baud Rate Frequency

+             unsigned int clock_rx,    // \arg Receiver Clock Parameters

+             unsigned int mode_rx,     // \arg mode Register to be programmed

+             unsigned int clock_tx,    // \arg Transmitter Clock Parameters

+             unsigned int mode_tx)     // \arg mode Register to be programmed

+{

+    //* Disable interrupts

+	pSSC->SSC_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+	pSSC->SSC_CR = AT91C_SSC_SWRST | AT91C_SSC_RXDIS | AT91C_SSC_TXDIS ;

+

+    //* Define the Clock Mode Register

+	AT91F_SSC_SetBaudrate(pSSC, syst_clock, baud_rate);

+

+     //* Write the Receive Clock Mode Register

+	pSSC->SSC_RCMR =  clock_rx;

+

+     //* Write the Transmit Clock Mode Register

+	pSSC->SSC_TCMR =  clock_tx;

+

+     //* Write the Receive Frame Mode Register

+	pSSC->SSC_RFMR =  mode_rx;

+

+     //* Write the Transmit Frame Mode Register

+	pSSC->SSC_TFMR =  mode_tx;

+

+    //* Clear Transmit and Receive Counters

+	AT91F_PDC_Open((AT91PS_PDC) &(pSSC->SSC_RPR));

+

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableRx

+//* \brief Enable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableRx

+//* \brief Disable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableTx

+//* \brief Enable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableTx

+//* \brief Disable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableIt

+//* \brief Enable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pSSC->SSC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableIt

+//* \brief Disable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pSSC->SSC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_ReceiveFrame (

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_SendFrame(

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_GetInterruptMaskStatus

+//* \brief Return SSC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_GetInterruptMaskStatus( // \return SSC Interrupt Mask Status

+        AT91PS_SSC pSsc) // \arg  pointer to a SSC controller

+{

+        return pSsc->SSC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_IsInterruptMasked

+//* \brief Test if SSC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SSC_IsInterruptMasked(

+        AT91PS_SSC pSsc,   // \arg  pointer to a SSC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SSC_GetInterruptMaskStatus(pSsc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SPI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Open

+//* \brief Open a SPI Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgCs

+//* \brief Configure SPI chip select register

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgCs (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	int cs,     // SPI cs number (0 to 3)

+ 	int val)   //  chip select register

+{

+	//* Write to the CSR register

+	*(pSPI->SPI_CSR + cs) = val;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_EnableIt

+//* \brief Enable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_EnableIt (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pSPI->SPI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_DisableIt

+//* \brief Disable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_DisableIt (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pSPI->SPI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Reset

+//* \brief Reset the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Reset (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SWRST;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Enable

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Enable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Disable

+//* \brief Disable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Disable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgMode

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgMode (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	int mode)        // mode register 

+{

+	//* Write to the MR register

+	pSPI->SPI_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPCS

+//* \brief Switch to the correct PCS of SPI Mode Register : Fixed Peripheral Selected

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPCS (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	char PCS_Device) // PCS of the Device

+{	

+ 	//* Write to the MR register

+	pSPI->SPI_MR &= 0xFFF0FFFF;

+	pSPI->SPI_MR |= ( (PCS_Device<<16) & AT91C_SPI_PCS );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_ReceiveFrame (

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is bSPIy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_SendFrame(

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Close

+//* \brief Close SPI: disable IT disable transfert, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Close (

+	AT91PS_SPI pSPI)     // \arg pointer to a SPI controller

+{

+    //* Reset all the Chip Select register

+    pSPI->SPI_CSR[0] = 0 ;

+    pSPI->SPI_CSR[1] = 0 ;

+    pSPI->SPI_CSR[2] = 0 ;

+    pSPI->SPI_CSR[3] = 0 ;

+

+    //* Reset the SPI mode

+    pSPI->SPI_MR = 0  ;

+

+    //* Disable all interrupts

+    pSPI->SPI_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pSPI->SPI_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_PutChar (

+	AT91PS_SPI pSPI,

+	unsigned int character,

+             unsigned int cs_number )

+{

+    unsigned int value_for_cs;

+    value_for_cs = (~(1 << cs_number)) & 0xF;  //Place a zero among a 4 ONEs number

+    pSPI->SPI_TDR = (character & 0xFFFF) | (value_for_cs << 16);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_GetChar (

+	const AT91PS_SPI pSPI)

+{

+    return((pSPI->SPI_RDR) & 0xFFFF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetInterruptMaskStatus

+//* \brief Return SPI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_GetInterruptMaskStatus( // \return SPI Interrupt Mask Status

+        AT91PS_SPI pSpi) // \arg  pointer to a SPI controller

+{

+        return pSpi->SPI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_IsInterruptMasked

+//* \brief Test if SPI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_IsInterruptMasked(

+        AT91PS_SPI pSpi,   // \arg  pointer to a SPI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SPI_GetInterruptMaskStatus(pSpi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PWMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetStatus

+//* \brief Return PWM Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetStatus( // \return PWM Interrupt Status

+	AT91PS_PWMC pPWM) // pointer to a PWM controller

+{

+	return pPWM->PWMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptEnable

+//* \brief Enable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptEnable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be enabled

+{

+        pPwm->PWMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptDisable

+//* \brief Disable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptDisable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be disabled

+{

+        pPwm->PWMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetInterruptMaskStatus

+//* \brief Return PWM Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetInterruptMaskStatus( // \return PWM Interrupt Mask Status

+        AT91PS_PWMC pPwm) // \arg  pointer to a PWM controller

+{

+        return pPwm->PWMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsInterruptMasked

+//* \brief Test if PWM Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsInterruptMasked(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetInterruptMaskStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsStatusSet

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsStatusSet(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_CfgChannel

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int mode, // \arg  PWM mode

+        unsigned int period, // \arg PWM period

+        unsigned int duty) // \arg PWM duty cycle

+{

+	pPWM->PWMC_CH[channelId].PWMC_CMR = mode;

+	pPWM->PWMC_CH[channelId].PWMC_CDTYR = duty;

+	pPWM->PWMC_CH[channelId].PWMC_CPRDR = period;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StartChannel

+//* \brief Enable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StartChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_ENA = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StopChannel

+//* \brief Disable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StopChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_DIS = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_UpdateChannel

+//* \brief Update Period or Duty Cycle

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_UpdateChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int update) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_CH[channelId].PWMC_CUPDR = update;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptEnable

+//* \brief Enable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptEnable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be enabled

+{

+        pTc->TC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptDisable

+//* \brief Disable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptDisable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be disabled

+{

+        pTc->TC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_GetInterruptMaskStatus

+//* \brief Return TC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TC_GetInterruptMaskStatus( // \return TC Interrupt Mask Status

+        AT91PS_TC pTc) // \arg  pointer to a TC controller

+{

+        return pTc->TC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_IsInterruptMasked

+//* \brief Test if TC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TC_IsInterruptMasked(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TC_GetInterruptMaskStatus(pTc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkEnableReg

+//* \brief Configure the System Clock Enable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkEnableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCER register

+	pPMC->PMC_SCER = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkDisableReg

+//* \brief Configure the System Clock Disable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkDisableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCDR register

+	pPMC->PMC_SCDR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetSysClkStatusReg

+//* \brief Return the System Clock Status Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetSysClkStatusReg (

+	AT91PS_PMC pPMC // pointer to a CAN controller

+	)

+{

+	return pPMC->PMC_SCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePeriphClock

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCER = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePeriphClock

+//* \brief Disable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCDR = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetPeriphClock

+//* \brief Get peripheral clock status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetPeriphClock (

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_PCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscillatorReg (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int mode)

+{

+	pCKGR->CKGR_MOR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainOscillatorReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MOR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_EnableMainOscillator

+//* \brief Enable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_EnableMainOscillator(

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR |= AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_DisableMainOscillator

+//* \brief Disable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_DisableMainOscillator (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscStartUpTime

+//* \brief Cfg MOR Register according to the main osc startup time

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscStartUpTime (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int startup_time,  // \arg main osc startup time in microsecond (us)

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_OSCOUNT;

+	pCKGR->CKGR_MOR |= ((slowClock * startup_time)/(8*1000000)) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClockFreqReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClockFreqReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MCFR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClock

+//* \brief Return Main clock in Hz

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClock (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	return ((pCKGR->CKGR_MCFR  & AT91C_CKGR_MAINF) * slowClock) >> 4;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgMCKReg

+//* \brief Cfg Master Clock Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgMCKReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	pPMC->PMC_MCKR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMCKReg

+//* \brief Return Master Clock Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMCKReg(

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_MCKR;

+}

+

+//*------------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMasterClock

+//* \brief Return master clock in Hz which correponds to processor clock for ARM7

+//*------------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMasterClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	unsigned int reg = pPMC->PMC_MCKR;

+	unsigned int prescaler = (1 << ((reg & AT91C_PMC_PRES) >> 2));

+	unsigned int pllDivider, pllMultiplier;

+

+	switch (reg & AT91C_PMC_CSS) {

+		case AT91C_PMC_CSS_SLOW_CLK: // Slow clock selected

+			return slowClock / prescaler;

+		case AT91C_PMC_CSS_MAIN_CLK: // Main clock is selected

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / prescaler;

+		case AT91C_PMC_CSS_PLL_CLK: // PLLB clock is selected

+			reg = pCKGR->CKGR_PLLR;

+			pllDivider    = (reg  & AT91C_CKGR_DIV);

+			pllMultiplier = ((reg  & AT91C_CKGR_MUL) >> 16) + 1;

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;

+	}

+	return 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck,  // \arg Peripheral clock identifier 0 .. 7

+	unsigned int mode)

+{

+	pPMC->PMC_PCKR[pck] = mode;

+	pPMC->PMC_SCER = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck)  // \arg Peripheral clock identifier 0 .. 7

+{

+	pPMC->PMC_SCDR = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnableIt

+//* \brief Enable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnableIt (

+	AT91PS_PMC pPMC,     // pointer to a PMC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pPMC->PMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisableIt

+//* \brief Disable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisableIt (

+	AT91PS_PMC pPMC, // pointer to a PMC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pPMC->PMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetStatus

+//* \brief Return PMC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetStatus( // \return PMC Interrupt Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetInterruptMaskStatus

+//* \brief Return PMC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetInterruptMaskStatus( // \return PMC Interrupt Mask Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsInterruptMasked

+//* \brief Test if PMC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsInterruptMasked(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetInterruptMaskStatus(pPMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsStatusSet

+//* \brief Test if PMC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsStatusSet(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetStatus(pPMC) & flag);

+}/* *****************************************************************************

+                SOFTWARE API FOR ADC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableIt

+//* \brief Enable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableIt (

+	AT91PS_ADC pADC,     // pointer to a ADC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pADC->ADC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableIt

+//* \brief Disable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableIt (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pADC->ADC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetStatus

+//* \brief Return ADC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetStatus( // \return ADC Interrupt Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetInterruptMaskStatus

+//* \brief Return ADC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetInterruptMaskStatus( // \return ADC Interrupt Mask Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsInterruptMasked

+//* \brief Test if ADC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsInterruptMasked(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetInterruptMaskStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsStatusSet

+//* \brief Test if ADC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsStatusSet(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgModeReg

+//* \brief Configure the Mode Register of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgModeReg (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pADC->ADC_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetModeReg

+//* \brief Return the Mode Register of the ADC controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetModeReg (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgTimings

+//* \brief Configure the different necessary timings of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgTimings (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mck_clock, // in MHz 

+	unsigned int adc_clock, // in MHz 

+	unsigned int startup_time, // in us 

+	unsigned int sample_and_hold_time)	// in ns  

+{

+	unsigned int prescal,startup,shtim;

+	

+	prescal = mck_clock/(2*adc_clock) - 1;

+	startup = adc_clock*startup_time/8 - 1;

+	shtim = adc_clock*sample_and_hold_time/1000 - 1;

+	

+	//* Write to the MR register

+	pADC->ADC_MR = ( (prescal<<8) & AT91C_ADC_PRESCAL) | ( (startup<<16) & AT91C_ADC_STARTUP) | ( (shtim<<24) & AT91C_ADC_SHTIM);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHER register

+	pADC->ADC_CHER = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHDR register

+	pADC->ADC_CHDR = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetChannelStatus

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetChannelStatus (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CHSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_StartConversion

+//* \brief Software request for a analog to digital conversion 

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_StartConversion (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_SoftReset

+//* \brief Software reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_SoftReset (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetLastConvertedData

+//* \brief Return the Last Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetLastConvertedData (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_LCDR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH0

+//* \brief Return the Channel 0 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH0 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR0;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH1

+//* \brief Return the Channel 1 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH1 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR1;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH2

+//* \brief Return the Channel 2 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH2 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR2;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH3

+//* \brief Return the Channel 3 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH3 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR3;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH4

+//* \brief Return the Channel 4 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH4 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR4;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH5

+//* \brief Return the Channel 5 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH5 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR5;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH6

+//* \brief Return the Channel 6 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH6 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR6;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH7

+//* \brief Return the Channel 7 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH7 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR7;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PIO

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPeriph

+//* \brief Enable pins to be drived by peripheral

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPeriph(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int periphAEnable,  // \arg PERIPH A to enable

+	unsigned int periphBEnable)  // \arg PERIPH B to enable

+

+{

+	pPio->PIO_ASR = periphAEnable;

+	pPio->PIO_BSR = periphBEnable;

+	pPio->PIO_PDR = (periphAEnable | periphBEnable); // Set in Periph mode

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOutput

+//* \brief Enable PIO in output mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOutput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pioEnable)      // \arg PIO to be enabled

+{

+	pPio->PIO_PER = pioEnable; // Set in PIO mode

+	pPio->PIO_OER = pioEnable; // Configure in Output

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInput

+//* \brief Enable PIO in input mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputEnable)      // \arg PIO to be enabled

+{

+	// Disable output

+	pPio->PIO_ODR  = inputEnable;

+	pPio->PIO_PER  = inputEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOpendrain

+//* \brief Configure PIO in open drain

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOpendrain(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int multiDrvEnable) // \arg pio to be configured in open drain

+{

+	// Configure the multi-drive option

+	pPio->PIO_MDDR = ~multiDrvEnable;

+	pPio->PIO_MDER = multiDrvEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPullup

+//* \brief Enable pullup on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPullup(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pullupEnable)   // \arg enable pullup on PIO

+{

+		// Connect or not Pullup

+	pPio->PIO_PPUDR = ~pullupEnable;

+	pPio->PIO_PPUER = pullupEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgDirectDrive

+//* \brief Enable direct drive on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgDirectDrive(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int directDrive)    // \arg PIO to be configured with direct drive

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_OWDR  = ~directDrive;

+	pPio->PIO_OWER  = directDrive;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInputFilter

+//* \brief Enable input filter on input PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInputFilter(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputFilter)    // \arg PIO to be configured with input filter

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_IFDR  = ~inputFilter;

+	pPio->PIO_IFER  = inputFilter;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInput

+//* \brief Return PIO input value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInput( // \return PIO input

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+	return pPio->PIO_PDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputSet

+//* \brief Test if PIO is input flag is active

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputSet(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PIO_GetInput(pPio) & flag);

+}

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_SetOutput

+//* \brief Set to 1 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_SetOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be set

+{

+	pPio->PIO_SODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ClearOutput

+//* \brief Set to 0 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ClearOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be cleared

+{

+	pPio->PIO_CODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ForceOutput

+//* \brief Force output when Direct drive option is enabled

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ForceOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be forced

+{

+	pPio->PIO_ODSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Enable

+//* \brief Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Enable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled 

+{

+        pPio->PIO_PER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Disable

+//* \brief Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Disable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled 

+{

+        pPio->PIO_PDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetStatus

+//* \brief Return PIO Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetStatus( // \return PIO Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsSet

+//* \brief Test if PIO is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputEnable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be enabled

+{

+        pPio->PIO_OER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputDisable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be disabled

+{

+        pPio->PIO_ODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputStatus

+//* \brief Return PIO Output Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputStatus( // \return PIO Output Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOuputSet

+//* \brief Test if PIO Output is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterEnable

+//* \brief Input Filter Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be enabled

+{

+        pPio->PIO_IFER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterDisable

+//* \brief Input Filter Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be disabled

+{

+        pPio->PIO_IFDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInputFilterStatus

+//* \brief Return PIO Input Filter Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInputFilterStatus( // \return PIO Input Filter Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IFSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputFilterSet

+//* \brief Test if PIO Input filter is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputFilterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInputFilterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputDataStatus

+//* \brief Return PIO Output Data Status 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputDataStatus( // \return PIO Output Data Status 

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ODSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptEnable

+//* \brief Enable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be enabled

+{

+        pPio->PIO_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptDisable

+//* \brief Disable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be disabled

+{

+        pPio->PIO_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptMaskStatus

+//* \brief Return PIO Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptMaskStatus( // \return PIO Interrupt Mask Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptStatus( // \return PIO Interrupt Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptMasked

+//* \brief Test if PIO Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptMasked(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptMaskStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptSet

+//* \brief Test if PIO Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverEnable

+//* \brief Multi Driver Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled

+{

+        pPio->PIO_MDER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverDisable

+//* \brief Multi Driver Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled

+{

+        pPio->PIO_MDDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetMultiDriverStatus

+//* \brief Return PIO Multi Driver Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetMultiDriverStatus( // \return PIO Multi Driver Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_MDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsMultiDriverSet

+//* \brief Test if PIO MultiDriver is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsMultiDriverSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetMultiDriverStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_A_RegisterSelection

+//* \brief PIO A Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_A_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio A register selection

+{

+        pPio->PIO_ASR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_B_RegisterSelection

+//* \brief PIO B Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_B_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio B register selection 

+{

+        pPio->PIO_BSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Get_AB_RegisterStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_Get_AB_RegisterStatus( // \return PIO AB Register Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ABSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsAB_RegisterSet

+//* \brief Test if PIO AB Register is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsAB_RegisterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_Get_AB_RegisterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteEnable

+//* \brief Output Write Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be enabled

+{

+        pPio->PIO_OWER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteDisable

+//* \brief Output Write Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be disabled

+{

+        pPio->PIO_OWDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputWriteStatus

+//* \brief Return PIO Output Write Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputWriteStatus( // \return PIO Output Write Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OWSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputWriteSet

+//* \brief Test if PIO OutputWrite is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputWriteSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputWriteStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetCfgPullup

+//* \brief Return PIO Configuration Pullup

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetCfgPullup( // \return PIO Configuration Pullup 

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PPUSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputDataStatusSet

+//* \brief Test if PIO Output Data Status is Set 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputDataStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputDataStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsCfgPullupStatusSet

+//* \brief Test if PIO Configuration Pullup Status is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsCfgPullupStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (~AT91F_PIO_GetCfgPullup(pPio) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TWI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_EnableIt

+//* \brief Enable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_EnableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pTWI->TWI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_DisableIt

+//* \brief Disable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_DisableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pTWI->TWI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_Configure

+//* \brief Configure TWI in master mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_Configure ( AT91PS_TWI pTWI )          // \arg pointer to a TWI controller

+{

+    //* Disable interrupts

+	pTWI->TWI_IDR = (unsigned int) -1;

+

+    //* Reset peripheral

+	pTWI->TWI_CR = AT91C_TWI_SWRST;

+

+	//* Set Master mode

+	pTWI->TWI_CR = AT91C_TWI_MSEN | AT91C_TWI_SVDIS;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_GetInterruptMaskStatus

+//* \brief Return TWI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TWI_GetInterruptMaskStatus( // \return TWI Interrupt Mask Status

+        AT91PS_TWI pTwi) // \arg  pointer to a TWI controller

+{

+        return pTwi->TWI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_IsInterruptMasked

+//* \brief Test if TWI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TWI_IsInterruptMasked(

+        AT91PS_TWI pTwi,   // \arg  pointer to a TWI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TWI_GetInterruptMaskStatus(pTwi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR USART

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Calculate the baudrate

+//* Standard Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_MODE ( AT91C_US_USMODE_NORMAL + \

+                        AT91C_US_NBSTOP_1_BIT + \

+                        AT91C_US_PAR_NONE + \

+                        AT91C_US_CHRL_8_BITS + \

+                        AT91C_US_CLKS_CLOCK )

+

+//* Standard External Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_SCK_MODE ( AT91C_US_USMODE_NORMAL + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_EXT )

+

+//* Standard Synchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_SYNC_MODE ( AT91C_US_SYNC + \

+                       AT91C_US_USMODE_NORMAL + \

+                       AT91C_US_NBSTOP_1_BIT + \

+                       AT91C_US_PAR_NONE + \

+                       AT91C_US_CHRL_8_BITS + \

+                       AT91C_US_CLKS_CLOCK )

+

+//* SCK used Label

+#define AT91C_US_SCK_USED (AT91C_US_CKLO | AT91C_US_CLKS_EXT)

+

+//* Standard ISO T=0 Mode : 8 bits , 1 stop , parity

+#define AT91C_US_ISO_READER_MODE ( AT91C_US_USMODE_ISO7816_0 + \

+					   		 AT91C_US_CLKS_CLOCK +\

+                       		 AT91C_US_NBSTOP_1_BIT + \

+                       		 AT91C_US_PAR_EVEN + \

+                       		 AT91C_US_CHRL_8_BITS + \

+                       		 AT91C_US_CKLO +\

+                       		 AT91C_US_OVER)

+

+//* Standard IRDA mode

+#define AT91C_US_ASYNC_IRDA_MODE (  AT91C_US_USMODE_IRDA + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_CLOCK )

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Caluculate baud_value according to the main clock and the baud rate

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Baudrate (

+	const unsigned int main_clock, // \arg peripheral clock

+	const unsigned int baud_rate)  // \arg UART baudrate

+{

+	unsigned int baud_value = ((main_clock*10)/(baud_rate * 16));

+	if ((baud_value % 10) >= 5)

+		baud_value = (baud_value / 10) + 1;

+	else

+		baud_value /= 10;

+	return baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetBaudrate (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int mainClock, // \arg peripheral clock

+	unsigned int speed)     // \arg UART baudrate

+{

+	//* Define the baud rate divisor register

+	pUSART->US_BRGR = AT91F_US_Baudrate(mainClock, speed);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetTimeguard

+//* \brief Set USART timeguard

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetTimeguard (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int timeguard) // \arg timeguard value

+{

+	//* Write the Timeguard Register

+	pUSART->US_TTGR = timeguard ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableIt

+//* \brief Enable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUSART->US_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableIt

+//* \brief Disable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IER register

+	pUSART->US_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Configure

+//* \brief Configure USART

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Configure (

+	AT91PS_USART pUSART,     // \arg pointer to a USART controller

+	unsigned int mainClock,  // \arg peripheral clock

+	unsigned int mode ,      // \arg mode Register to be programmed

+	unsigned int baudRate ,  // \arg baudrate to be programmed

+	unsigned int timeguard ) // \arg timeguard to be programmed

+{

+    //* Disable interrupts

+    pUSART->US_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+    pUSART->US_CR = AT91C_US_RSTRX | AT91C_US_RSTTX | AT91C_US_RXDIS | AT91C_US_TXDIS ;

+

+	//* Define the baud rate divisor register

+	AT91F_US_SetBaudrate(pUSART, mainClock, baudRate);

+

+	//* Write the Timeguard Register

+	AT91F_US_SetTimeguard(pUSART, timeguard);

+

+    //* Clear Transmit and Receive Counters

+    AT91F_PDC_Open((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Define the USART mode

+    pUSART->US_MR = mode  ;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableRx

+//* \brief Enable receiving characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableTx

+//* \brief Enable sending characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable  transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetRx

+//* \brief Reset Receiver and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset receiver

+	pUSART->US_CR = AT91C_US_RSTRX;

+    //* Re-Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetTx

+//* \brief Reset Transmitter and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset transmitter

+	pUSART->US_CR = AT91C_US_RSTTX;

+    //* Enable transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableRx

+//* \brief Disable Receiver

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable receiver

+    pUSART->US_CR = AT91C_US_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableTx

+//* \brief Disable Transmitter

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable transmitter

+    pUSART->US_CR = AT91C_US_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Close

+//* \brief Close USART: disable IT disable receiver and transmitter, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Close (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Reset the baud rate divisor register

+    pUSART->US_BRGR = 0 ;

+

+    //* Reset the USART mode

+    pUSART->US_MR = 0  ;

+

+    //* Reset the Timeguard Register

+    pUSART->US_TTGR = 0;

+

+    //* Disable all interrupts

+    pUSART->US_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pUSART->US_CR = AT91C_US_TXDIS | AT91C_US_RXDIS | AT91C_US_RSTTX | AT91C_US_RSTRX ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_TxReady

+//* \brief Return 1 if a character can be written in US_THR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_TxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_TXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_RxReady

+//* \brief Return 1 if a character can be read in US_RHR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_RxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_RXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Error

+//* \brief Return the error flag

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Error (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR &

+    	(AT91C_US_OVRE |  // Overrun error

+    	 AT91C_US_FRAME | // Framing error

+    	 AT91C_US_PARE));  // Parity error

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_PutChar (

+	AT91PS_USART pUSART,

+	int character )

+{

+    pUSART->US_THR = (character & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_US_GetChar (

+	const AT91PS_USART pUSART)

+{

+    return((pUSART->US_RHR) & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_SendFrame(

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_ReceiveFrame (

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetIrdaFilter

+//* \brief Set the value of IrDa filter tregister

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetIrdaFilter (

+	AT91PS_USART pUSART,

+	unsigned char value

+)

+{

+	pUSART->US_IF = value;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR UDP

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableIt

+//* \brief Enable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUDP->UDP_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableIt

+//* \brief Disable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pUDP->UDP_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetAddress

+//* \brief Set UDP functional address

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetAddress (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char address)   // \arg new UDP address

+{

+	pUDP->UDP_FADDR = (AT91C_UDP_FEN | address);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg endpoints to be enabled

+{

+	pUDP->UDP_GLBSTATE  |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg endpoints to be enabled

+{

+	pUDP->UDP_GLBSTATE  &= ~(flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetState

+//* \brief Set UDP Device state

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetState (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg new UDP address

+{

+	pUDP->UDP_GLBSTATE  &= ~(AT91C_UDP_FADDEN | AT91C_UDP_CONFG);

+	pUDP->UDP_GLBSTATE  |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetState

+//* \brief return UDP Device state

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetState ( // \return the UDP device state

+	AT91PS_UDP pUDP)     // \arg pointer to a UDP controller

+{

+	return (pUDP->UDP_GLBSTATE  & (AT91C_UDP_FADDEN | AT91C_UDP_CONFG));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_ResetEp

+//* \brief Reset UDP endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_ResetEp ( // \return the UDP device state

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg Endpoints to be reset

+{

+	pUDP->UDP_RSTEP = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStall

+//* \brief Endpoint will STALL requests

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpStall(

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_FORCESTALL;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpWrite

+//* \brief Write value in the DPR

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpWrite(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned char value)     // \arg value to be written in the DPR

+{

+	pUDP->UDP_FDR[endpoint] = value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpRead

+//* \brief Return value from the DPR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpRead(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_FDR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpEndOfWr

+//* \brief Notify the UDP that values in DPR are ready to be sent

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpEndOfWr(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_TXPKTRDY;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpClear

+//* \brief Clear flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpClear(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] &= ~(flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpSet

+//* \brief Set flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpSet(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStatus

+//* \brief Return the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpStatus(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_CSR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetInterruptMaskStatus

+//* \brief Return UDP Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetInterruptMaskStatus( // \return UDP Interrupt Mask Status

+        AT91PS_UDP pUdp) // \arg  pointer to a UDP controller

+{

+        return pUdp->UDP_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_IsInterruptMasked

+//* \brief Test if UDP Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_UDP_IsInterruptMasked(

+        AT91PS_UDP pUdp,   // \arg  pointer to a UDP controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_UDP_GetInterruptMaskStatus(pUdp) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR AIC

+   ***************************************************************************** */

+#define AT91C_AIC_BRANCH_OPCODE ((void (*) ()) 0xE51FFF20) // ldr, pc, [pc, #-&F20]

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ConfigureIt

+//* \brief Interrupt Handler Initialization

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AIC_ConfigureIt (

+	AT91PS_AIC pAic,  // \arg pointer to the AIC registers

+	unsigned int irq_id,     // \arg interrupt number to initialize

+	unsigned int priority,   // \arg priority to give to the interrupt

+	unsigned int src_type,   // \arg activation and sense of activation

+	void (*newHandler) (void) ) // \arg address of the interrupt handler

+{

+	unsigned int oldHandler;

+    unsigned int mask ;

+

+    oldHandler = pAic->AIC_SVR[irq_id];

+

+    mask = 0x1 << irq_id ;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Save the interrupt handler routine pointer and the interrupt priority

+    pAic->AIC_SVR[irq_id] = (unsigned int) newHandler ;

+    //* Store the Source Mode Register

+    pAic->AIC_SMR[irq_id] = src_type | priority  ;

+    //* Clear the interrupt on the interrupt controller

+    pAic->AIC_ICCR = mask ;

+

+	return oldHandler;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_EnableIt

+//* \brief Enable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_EnableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    //* Enable the interrupt on the interrupt controller

+    pAic->AIC_IECR = 0x1 << irq_id ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_DisableIt

+//* \brief Disable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_DisableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    unsigned int mask = 0x1 << irq_id;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = mask ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ClearIt

+//* \brief Clear corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_ClearIt (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number to initialize

+{

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = (0x1 << irq_id);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_AcknowledgeIt

+//* \brief Acknowledge corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_AcknowledgeIt (

+	AT91PS_AIC pAic)     // \arg pointer to the AIC registers

+{

+    pAic->AIC_EOICR = pAic->AIC_EOICR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_SetExceptionVector

+//* \brief Configure vector handler

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_SetExceptionVector (

+	unsigned int *pVector, // \arg pointer to the AIC registers

+	void (*Handler) () )   // \arg Interrupt Handler

+{

+	unsigned int oldVector = *pVector;

+

+	if ((unsigned int) Handler == (unsigned int) AT91C_AIC_BRANCH_OPCODE)

+		*pVector = (unsigned int) AT91C_AIC_BRANCH_OPCODE;

+	else

+		*pVector = (((((unsigned int) Handler) - ((unsigned int) pVector) - 0x8) >> 2) & 0x00FFFFFF) | 0xEA000000;

+

+	return oldVector;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Trig

+//* \brief Trig an IT

+//*----------------------------------------------------------------------------

+__inline void  AT91F_AIC_Trig (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number

+{

+	pAic->AIC_ISCR = (0x1 << irq_id) ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsActive

+//* \brief Test if an IT is active

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsActive (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_ISR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsPending

+//* \brief Test if an IT is pending

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsPending (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_IPR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Open

+//* \brief Set exception vectors and AIC registers to default values

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_Open(

+	AT91PS_AIC pAic,        // \arg pointer to the AIC registers

+	void (*IrqHandler) (),  // \arg Default IRQ vector exception

+	void (*FiqHandler) (),  // \arg Default FIQ vector exception

+	void (*DefaultHandler)  (), // \arg Default Handler set in ISR

+	void (*SpuriousHandler) (), // \arg Default Spurious Handler

+	unsigned int protectMode)   // \arg Debug Control Register

+{

+	int i;

+

+	// Disable all interrupts and set IVR to the default handler

+	for (i = 0; i < 32; ++i) {

+		AT91F_AIC_DisableIt(pAic, i);

+		AT91F_AIC_ConfigureIt(pAic, i, AT91C_AIC_PRIOR_LOWEST, AT91C_AIC_SRCTYPE_INT_LEVEL_SENSITIVE, DefaultHandler);

+	}

+

+	// Set the IRQ exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x18, IrqHandler);

+	// Set the Fast Interrupt exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x1C, FiqHandler);

+

+	pAic->AIC_SPU = (unsigned int) SpuriousHandler;

+	pAic->AIC_DCR = protectMode;

+}

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  MC

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  DBGU

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPIO

+//* \brief Configure PIO controllers to drive DBGU signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA10_DTXD    ) |

+		((unsigned int) AT91C_PA9_DRXD    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH3_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH3 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH3_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA14_PWM3    ) |

+		((unsigned int) AT91C_PA7_PWM3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH2_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA2_PWM2    ), // Peripheral A

+		((unsigned int) AT91C_PA25_PWM2    ) |

+		((unsigned int) AT91C_PA13_PWM2    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH1_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA1_PWM1    ), // Peripheral A

+		((unsigned int) AT91C_PA24_PWM1    ) |

+		((unsigned int) AT91C_PA12_PWM1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH0_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA0_PWM0    ), // Peripheral A

+		((unsigned int) AT91C_PA23_PWM0    ) |

+		((unsigned int) AT91C_PA11_PWM0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SSC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPIO

+//* \brief Configure PIO controllers to drive SSC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA17_TD      ) |

+		((unsigned int) AT91C_PA15_TF      ) |

+		((unsigned int) AT91C_PA19_RK      ) |

+		((unsigned int) AT91C_PA18_RD      ) |

+		((unsigned int) AT91C_PA20_RF      ) |

+		((unsigned int) AT91C_PA16_TK      ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPIO

+//* \brief Configure PIO controllers to drive SPI signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA11_NPCS0   ) |

+		((unsigned int) AT91C_PA13_MOSI    ) |

+		((unsigned int) AT91C_PA31_NPCS1   ) |

+		((unsigned int) AT91C_PA12_MISO    ) |

+		((unsigned int) AT91C_PA14_SPCK    ), // Peripheral A

+		((unsigned int) AT91C_PA9_NPCS1   ) |

+		((unsigned int) AT91C_PA30_NPCS2   ) |

+		((unsigned int) AT91C_PA10_NPCS2   ) |

+		((unsigned int) AT91C_PA22_NPCS3   ) |

+		((unsigned int) AT91C_PA3_NPCS3   ) |

+		((unsigned int) AT91C_PA5_NPCS3   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PWMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PWMC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC2

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC2));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPIO

+//* \brief Configure PIO controllers to drive TC2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA26_TIOA2   ) |

+		((unsigned int) AT91C_PA27_TIOB2   ) |

+		((unsigned int) AT91C_PA29_TCLK2   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC1

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPIO

+//* \brief Configure PIO controllers to drive TC1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA15_TIOA1   ) |

+		((unsigned int) AT91C_PA16_TIOB1   ) |

+		((unsigned int) AT91C_PA28_TCLK1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC0

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPIO

+//* \brief Configure PIO controllers to drive TC0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA0_TIOA0   ) |

+		((unsigned int) AT91C_PA1_TIOB0   ) |

+		((unsigned int) AT91C_PA4_TCLK0   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPIO

+//* \brief Configure PIO controllers to drive PMC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA17_PCK1    ) |

+		((unsigned int) AT91C_PA21_PCK1    ) |

+		((unsigned int) AT91C_PA31_PCK2    ) |

+		((unsigned int) AT91C_PA18_PCK2    ) |

+		((unsigned int) AT91C_PA6_PCK0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  ADC

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_ADC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPIO

+//* \brief Configure PIO controllers to drive ADC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA8_ADTRG   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOA_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOA

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOA_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOA));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TWI

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TWI));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPIO

+//* \brief Configure PIO controllers to drive TWI signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA3_TWD     ) |

+		((unsigned int) AT91C_PA4_TWCK    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US1

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPIO

+//* \brief Configure PIO controllers to drive US1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA21_RXD1    ) |

+		((unsigned int) AT91C_PA27_DTR1    ) |

+		((unsigned int) AT91C_PA26_DCD1    ) |

+		((unsigned int) AT91C_PA22_TXD1    ) |

+		((unsigned int) AT91C_PA24_RTS1    ) |

+		((unsigned int) AT91C_PA23_SCK1    ) |

+		((unsigned int) AT91C_PA28_DSR1    ) |

+		((unsigned int) AT91C_PA29_RI1     ) |

+		((unsigned int) AT91C_PA25_CTS1    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US0

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPIO

+//* \brief Configure PIO controllers to drive US0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA5_RXD0    ) |

+		((unsigned int) AT91C_PA6_TXD0    ) |

+		((unsigned int) AT91C_PA7_RTS0    ) |

+		((unsigned int) AT91C_PA8_CTS0    ), // Peripheral A

+		((unsigned int) AT91C_PA2_SCK0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  UDP

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_UDP));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AIC

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_IRQ0) |

+		((unsigned int) 1 << AT91C_ID_FIQ) |

+		((unsigned int) 1 << AT91C_ID_IRQ1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPIO

+//* \brief Configure PIO controllers to drive AIC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA30_IRQ1    ), // Peripheral A

+		((unsigned int) AT91C_PA20_IRQ0    ) |

+		((unsigned int) AT91C_PA19_FIQ     )); // Peripheral B

+}

+

+#endif // lib_AT91SAM7S64_H

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X128.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X128.h
new file mode 100644
index 0000000..805a2bc
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X128.h
@@ -0,0 +1,4558 @@
+//* ----------------------------------------------------------------------------

+//*         ATMEL Microcontroller Software Support  -  ROUSSET  -

+//* ----------------------------------------------------------------------------

+//* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//* ----------------------------------------------------------------------------

+//* File Name           : lib_AT91SAM7X128.h

+//* Object              : AT91SAM7X128 inlined functions

+//* Generated           : AT91 SW Application Group  05/20/2005 (16:22:23)

+//*

+//* CVS Reference       : /lib_dbgu.h/1.1/Fri Jan 31 12:18:40 2003//

+//* CVS Reference       : /lib_pmc_SAM7X.h/1.1/Tue Feb  1 08:32:10 2005//

+//* CVS Reference       : /lib_VREG_6085B.h/1.1/Tue Feb  1 16:20:47 2005//

+//* CVS Reference       : /lib_rstc_6098A.h/1.1/Wed Oct  6 10:39:20 2004//

+//* CVS Reference       : /lib_ssc.h/1.4/Fri Jan 31 12:19:20 2003//

+//* CVS Reference       : /lib_wdtc_6080A.h/1.1/Wed Oct  6 10:38:30 2004//

+//* CVS Reference       : /lib_usart.h/1.5/Thu Nov 21 16:01:54 2002//

+//* CVS Reference       : /lib_spi2.h/1.1/Mon Aug 25 14:23:52 2003//

+//* CVS Reference       : /lib_pitc_6079A.h/1.2/Tue Nov  9 14:43:56 2004//

+//* CVS Reference       : /lib_aic_6075b.h/1.1/Fri May 20 14:01:19 2005//

+//* CVS Reference       : /lib_aes_6149a.h/1.1/Mon Jan 17 07:43:09 2005//

+//* CVS Reference       : /lib_twi.h/1.3/Mon Jul 19 14:27:58 2004//

+//* CVS Reference       : /lib_adc.h/1.6/Fri Oct 17 09:12:38 2003//

+//* CVS Reference       : /lib_rttc_6081A.h/1.1/Wed Oct  6 10:39:38 2004//

+//* CVS Reference       : /lib_udp.h/1.4/Wed Feb 16 08:39:34 2005//

+//* CVS Reference       : /lib_des3_6150a.h/1.1/Mon Jan 17 09:19:19 2005//

+//* CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+//* CVS Reference       : /lib_MC_SAM7X.h/1.1/Thu Mar 25 15:19:14 2004//

+//* CVS Reference       : /lib_pio.h/1.3/Fri Jan 31 12:18:56 2003//

+//* CVS Reference       : /lib_can_AT91.h/1.4/Fri Oct 17 09:12:50 2003//

+//* CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+//* CVS Reference       : /lib_pdc.h/1.2/Tue Jul  2 13:29:40 2002//

+//* ----------------------------------------------------------------------------

+

+#ifndef lib_AT91SAM7X128_H

+#define lib_AT91SAM7X128_H

+

+/* *****************************************************************************

+                SOFTWARE API FOR AIC

+   ***************************************************************************** */

+#define AT91C_AIC_BRANCH_OPCODE ((void (*) ()) 0xE51FFF20) // ldr, pc, [pc, #-&F20]

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ConfigureIt

+//* \brief Interrupt Handler Initialization

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AIC_ConfigureIt (

+	AT91PS_AIC pAic,  // \arg pointer to the AIC registers

+	unsigned int irq_id,     // \arg interrupt number to initialize

+	unsigned int priority,   // \arg priority to give to the interrupt

+	unsigned int src_type,   // \arg activation and sense of activation

+	void (*newHandler) (void) ) // \arg address of the interrupt handler

+{

+	unsigned int oldHandler;

+    unsigned int mask ;

+

+    oldHandler = pAic->AIC_SVR[irq_id];

+

+    mask = 0x1 << irq_id ;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Save the interrupt handler routine pointer and the interrupt priority

+    pAic->AIC_SVR[irq_id] = (unsigned int) newHandler ;

+    //* Store the Source Mode Register

+    pAic->AIC_SMR[irq_id] = src_type | priority  ;

+    //* Clear the interrupt on the interrupt controller

+    pAic->AIC_ICCR = mask ;

+

+	return oldHandler;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_EnableIt

+//* \brief Enable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_EnableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    //* Enable the interrupt on the interrupt controller

+    pAic->AIC_IECR = 0x1 << irq_id ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_DisableIt

+//* \brief Disable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_DisableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    unsigned int mask = 0x1 << irq_id;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = mask ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ClearIt

+//* \brief Clear corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_ClearIt (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number to initialize

+{

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = (0x1 << irq_id);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_AcknowledgeIt

+//* \brief Acknowledge corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_AcknowledgeIt (

+	AT91PS_AIC pAic)     // \arg pointer to the AIC registers

+{

+    pAic->AIC_EOICR = pAic->AIC_EOICR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_SetExceptionVector

+//* \brief Configure vector handler

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_SetExceptionVector (

+	unsigned int *pVector, // \arg pointer to the AIC registers

+	void (*Handler) () )   // \arg Interrupt Handler

+{

+	unsigned int oldVector = *pVector;

+

+	if ((unsigned int) Handler == (unsigned int) AT91C_AIC_BRANCH_OPCODE)

+		*pVector = (unsigned int) AT91C_AIC_BRANCH_OPCODE;

+	else

+		*pVector = (((((unsigned int) Handler) - ((unsigned int) pVector) - 0x8) >> 2) & 0x00FFFFFF) | 0xEA000000;

+

+	return oldVector;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Trig

+//* \brief Trig an IT

+//*----------------------------------------------------------------------------

+__inline void  AT91F_AIC_Trig (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number

+{

+	pAic->AIC_ISCR = (0x1 << irq_id) ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsActive

+//* \brief Test if an IT is active

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsActive (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_ISR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsPending

+//* \brief Test if an IT is pending

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsPending (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_IPR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Open

+//* \brief Set exception vectors and AIC registers to default values

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_Open(

+	AT91PS_AIC pAic,        // \arg pointer to the AIC registers

+	void (*IrqHandler) (),  // \arg Default IRQ vector exception

+	void (*FiqHandler) (),  // \arg Default FIQ vector exception

+	void (*DefaultHandler)  (), // \arg Default Handler set in ISR

+	void (*SpuriousHandler) (), // \arg Default Spurious Handler

+	unsigned int protectMode)   // \arg Debug Control Register

+{

+	int i;

+

+	// Disable all interrupts and set IVR to the default handler

+	for (i = 0; i < 32; ++i) {

+		AT91F_AIC_DisableIt(pAic, i);

+		AT91F_AIC_ConfigureIt(pAic, i, AT91C_AIC_PRIOR_LOWEST, AT91C_AIC_SRCTYPE_HIGH_LEVEL, DefaultHandler);

+	}

+

+	// Set the IRQ exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x18, IrqHandler);

+	// Set the Fast Interrupt exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x1C, FiqHandler);

+

+	pAic->AIC_SPU = (unsigned int) SpuriousHandler;

+	pAic->AIC_DCR = protectMode;

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PDC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextRx

+//* \brief Set the next receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextRx (

+	AT91PS_PDC pPDC,     // \arg pointer to a PDC controller

+	char *address,       // \arg address to the next bloc to be received

+	unsigned int bytes)  // \arg number of bytes to be received

+{

+	pPDC->PDC_RNPR = (unsigned int) address;

+	pPDC->PDC_RNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextTx

+//* \brief Set the next transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TNPR = (unsigned int) address;

+	pPDC->PDC_TNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetRx

+//* \brief Set the receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetRx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be received

+	unsigned int bytes)    // \arg number of bytes to be received

+{

+	pPDC->PDC_RPR = (unsigned int) address;

+	pPDC->PDC_RCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetTx

+//* \brief Set the transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TPR = (unsigned int) address;

+	pPDC->PDC_TCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableTx

+//* \brief Enable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableRx

+//* \brief Enable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableTx

+//* \brief Disable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableRx

+//* \brief Disable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsTxEmpty

+//* \brief Test if the current transfer descriptor has been sent

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextTxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsRxEmpty

+//* \brief Test if the current transfer descriptor has been filled

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextRxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Open

+//* \brief Open PDC: disable TX and RX reset transfer descriptors, re-enable RX and TX

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Open (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+    //* Enable the RX and TX PDC transfer requests

+	AT91F_PDC_EnableRx(pPDC);

+	AT91F_PDC_EnableTx(pPDC);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Close

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Close (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SendFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_SendFrame(

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsTxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetTx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextTx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextTxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextTx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_ReceiveFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_ReceiveFrame (

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsRxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetRx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextRx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextRxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextRx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+/* *****************************************************************************

+                SOFTWARE API FOR DBGU

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptEnable

+//* \brief Enable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptEnable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be enabled

+{

+        pDbgu->DBGU_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptDisable

+//* \brief Disable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptDisable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be disabled

+{

+        pDbgu->DBGU_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_GetInterruptMaskStatus

+//* \brief Return DBGU Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_DBGU_GetInterruptMaskStatus( // \return DBGU Interrupt Mask Status

+        AT91PS_DBGU pDbgu) // \arg  pointer to a DBGU controller

+{

+        return pDbgu->DBGU_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_IsInterruptMasked

+//* \brief Test if DBGU Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_DBGU_IsInterruptMasked(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_DBGU_GetInterruptMaskStatus(pDbgu) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PIO

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPeriph

+//* \brief Enable pins to be drived by peripheral

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPeriph(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int periphAEnable,  // \arg PERIPH A to enable

+	unsigned int periphBEnable)  // \arg PERIPH B to enable

+

+{

+	pPio->PIO_ASR = periphAEnable;

+	pPio->PIO_BSR = periphBEnable;

+	pPio->PIO_PDR = (periphAEnable | periphBEnable); // Set in Periph mode

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOutput

+//* \brief Enable PIO in output mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOutput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pioEnable)      // \arg PIO to be enabled

+{

+	pPio->PIO_PER = pioEnable; // Set in PIO mode

+	pPio->PIO_OER = pioEnable; // Configure in Output

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInput

+//* \brief Enable PIO in input mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputEnable)      // \arg PIO to be enabled

+{

+	// Disable output

+	pPio->PIO_ODR  = inputEnable;

+	pPio->PIO_PER  = inputEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOpendrain

+//* \brief Configure PIO in open drain

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOpendrain(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int multiDrvEnable) // \arg pio to be configured in open drain

+{

+	// Configure the multi-drive option

+	pPio->PIO_MDDR = ~multiDrvEnable;

+	pPio->PIO_MDER = multiDrvEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPullup

+//* \brief Enable pullup on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPullup(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pullupEnable)   // \arg enable pullup on PIO

+{

+		// Connect or not Pullup

+	pPio->PIO_PPUDR = ~pullupEnable;

+	pPio->PIO_PPUER = pullupEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgDirectDrive

+//* \brief Enable direct drive on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgDirectDrive(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int directDrive)    // \arg PIO to be configured with direct drive

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_OWDR  = ~directDrive;

+	pPio->PIO_OWER  = directDrive;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInputFilter

+//* \brief Enable input filter on input PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInputFilter(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputFilter)    // \arg PIO to be configured with input filter

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_IFDR  = ~inputFilter;

+	pPio->PIO_IFER  = inputFilter;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInput

+//* \brief Return PIO input value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInput( // \return PIO input

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+	return pPio->PIO_PDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputSet

+//* \brief Test if PIO is input flag is active

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputSet(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PIO_GetInput(pPio) & flag);

+}

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_SetOutput

+//* \brief Set to 1 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_SetOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be set

+{

+	pPio->PIO_SODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ClearOutput

+//* \brief Set to 0 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ClearOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be cleared

+{

+	pPio->PIO_CODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ForceOutput

+//* \brief Force output when Direct drive option is enabled

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ForceOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be forced

+{

+	pPio->PIO_ODSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Enable

+//* \brief Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Enable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled 

+{

+        pPio->PIO_PER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Disable

+//* \brief Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Disable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled 

+{

+        pPio->PIO_PDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetStatus

+//* \brief Return PIO Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetStatus( // \return PIO Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsSet

+//* \brief Test if PIO is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputEnable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be enabled

+{

+        pPio->PIO_OER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputDisable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be disabled

+{

+        pPio->PIO_ODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputStatus

+//* \brief Return PIO Output Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputStatus( // \return PIO Output Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOuputSet

+//* \brief Test if PIO Output is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterEnable

+//* \brief Input Filter Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be enabled

+{

+        pPio->PIO_IFER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterDisable

+//* \brief Input Filter Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be disabled

+{

+        pPio->PIO_IFDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInputFilterStatus

+//* \brief Return PIO Input Filter Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInputFilterStatus( // \return PIO Input Filter Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IFSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputFilterSet

+//* \brief Test if PIO Input filter is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputFilterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInputFilterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputDataStatus

+//* \brief Return PIO Output Data Status 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputDataStatus( // \return PIO Output Data Status 

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ODSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptEnable

+//* \brief Enable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be enabled

+{

+        pPio->PIO_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptDisable

+//* \brief Disable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be disabled

+{

+        pPio->PIO_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptMaskStatus

+//* \brief Return PIO Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptMaskStatus( // \return PIO Interrupt Mask Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptStatus( // \return PIO Interrupt Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptMasked

+//* \brief Test if PIO Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptMasked(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptMaskStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptSet

+//* \brief Test if PIO Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverEnable

+//* \brief Multi Driver Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled

+{

+        pPio->PIO_MDER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverDisable

+//* \brief Multi Driver Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled

+{

+        pPio->PIO_MDDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetMultiDriverStatus

+//* \brief Return PIO Multi Driver Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetMultiDriverStatus( // \return PIO Multi Driver Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_MDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsMultiDriverSet

+//* \brief Test if PIO MultiDriver is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsMultiDriverSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetMultiDriverStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_A_RegisterSelection

+//* \brief PIO A Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_A_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio A register selection

+{

+        pPio->PIO_ASR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_B_RegisterSelection

+//* \brief PIO B Register Selection 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_B_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio B register selection 

+{

+        pPio->PIO_BSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Get_AB_RegisterStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_Get_AB_RegisterStatus( // \return PIO AB Register Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ABSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsAB_RegisterSet

+//* \brief Test if PIO AB Register is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsAB_RegisterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_Get_AB_RegisterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteEnable

+//* \brief Output Write Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be enabled

+{

+        pPio->PIO_OWER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteDisable

+//* \brief Output Write Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be disabled

+{

+        pPio->PIO_OWDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputWriteStatus

+//* \brief Return PIO Output Write Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputWriteStatus( // \return PIO Output Write Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OWSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputWriteSet

+//* \brief Test if PIO OutputWrite is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputWriteSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputWriteStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetCfgPullup

+//* \brief Return PIO Configuration Pullup

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetCfgPullup( // \return PIO Configuration Pullup 

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PPUSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputDataStatusSet

+//* \brief Test if PIO Output Data Status is Set 

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputDataStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputDataStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsCfgPullupStatusSet

+//* \brief Test if PIO Configuration Pullup Status is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsCfgPullupStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (~AT91F_PIO_GetCfgPullup(pPio) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkEnableReg

+//* \brief Configure the System Clock Enable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkEnableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCER register

+	pPMC->PMC_SCER = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkDisableReg

+//* \brief Configure the System Clock Disable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkDisableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCDR register

+	pPMC->PMC_SCDR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetSysClkStatusReg

+//* \brief Return the System Clock Status Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetSysClkStatusReg (

+	AT91PS_PMC pPMC // pointer to a CAN controller

+	)

+{

+	return pPMC->PMC_SCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePeriphClock

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCER = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePeriphClock

+//* \brief Disable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCDR = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetPeriphClock

+//* \brief Get peripheral clock status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetPeriphClock (

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_PCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscillatorReg (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int mode)

+{

+	pCKGR->CKGR_MOR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainOscillatorReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MOR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_EnableMainOscillator

+//* \brief Enable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_EnableMainOscillator(

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR |= AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_DisableMainOscillator

+//* \brief Disable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_DisableMainOscillator (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscStartUpTime

+//* \brief Cfg MOR Register according to the main osc startup time

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscStartUpTime (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int startup_time,  // \arg main osc startup time in microsecond (us)

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_OSCOUNT;

+	pCKGR->CKGR_MOR |= ((slowClock * startup_time)/(8*1000000)) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClockFreqReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClockFreqReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MCFR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClock

+//* \brief Return Main clock in Hz

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClock (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	return ((pCKGR->CKGR_MCFR  & AT91C_CKGR_MAINF) * slowClock) >> 4;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgMCKReg

+//* \brief Cfg Master Clock Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgMCKReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	pPMC->PMC_MCKR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMCKReg

+//* \brief Return Master Clock Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMCKReg(

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_MCKR;

+}

+

+//*------------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMasterClock

+//* \brief Return master clock in Hz which correponds to processor clock for ARM7

+//*------------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMasterClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	unsigned int reg = pPMC->PMC_MCKR;

+	unsigned int prescaler = (1 << ((reg & AT91C_PMC_PRES) >> 2));

+	unsigned int pllDivider, pllMultiplier;

+

+	switch (reg & AT91C_PMC_CSS) {

+		case AT91C_PMC_CSS_SLOW_CLK: // Slow clock selected

+			return slowClock / prescaler;

+		case AT91C_PMC_CSS_MAIN_CLK: // Main clock is selected

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / prescaler;

+		case AT91C_PMC_CSS_PLL_CLK: // PLLB clock is selected

+			reg = pCKGR->CKGR_PLLR;

+			pllDivider    = (reg  & AT91C_CKGR_DIV);

+			pllMultiplier = ((reg  & AT91C_CKGR_MUL) >> 16) + 1;

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;

+	}

+	return 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck,  // \arg Peripheral clock identifier 0 .. 7

+	unsigned int mode)

+{

+	pPMC->PMC_PCKR[pck] = mode;

+	pPMC->PMC_SCER = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck)  // \arg Peripheral clock identifier 0 .. 7

+{

+	pPMC->PMC_SCDR = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnableIt

+//* \brief Enable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnableIt (

+	AT91PS_PMC pPMC,     // pointer to a PMC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pPMC->PMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisableIt

+//* \brief Disable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisableIt (

+	AT91PS_PMC pPMC, // pointer to a PMC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pPMC->PMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetStatus

+//* \brief Return PMC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetStatus( // \return PMC Interrupt Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetInterruptMaskStatus

+//* \brief Return PMC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetInterruptMaskStatus( // \return PMC Interrupt Mask Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsInterruptMasked

+//* \brief Test if PMC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsInterruptMasked(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetInterruptMaskStatus(pPMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsStatusSet

+//* \brief Test if PMC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsStatusSet(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetStatus(pPMC) & flag);

+}/* *****************************************************************************

+                SOFTWARE API FOR RSTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSoftReset

+//* \brief Start Software Reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSoftReset(

+        AT91PS_RSTC pRSTC,

+        unsigned int reset)

+{

+	pRSTC->RSTC_RCR = (0xA5000000 | reset);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSetMode

+//* \brief Set Reset Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSetMode(

+        AT91PS_RSTC pRSTC,

+        unsigned int mode)

+{

+	pRSTC->RSTC_RMR = (0xA5000000 | mode);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetMode

+//* \brief Get Reset Mode

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetMode(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetStatus

+//* \brief Get Reset Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetStatus(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RSR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTIsSoftRstActive

+//* \brief Return !=0 if software reset is still not completed

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTIsSoftRstActive(

+        AT91PS_RSTC pRSTC)

+{

+	return ((pRSTC->RSTC_RSR) & AT91C_RSTC_SRCMP);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR RTTC

+   ***************************************************************************** */

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_SetRTT_TimeBase()

+//* \brief  Set the RTT prescaler according to the TimeBase in ms

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetTimeBase(

+        AT91PS_RTTC pRTTC, 

+        unsigned int ms)

+{

+	if (ms > 2000)

+		return 1;   // AT91C_TIME_OUT_OF_RANGE

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (((ms << 15) /1000) & 0xFFFF);	

+	return 0;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTSetPrescaler()

+//* \brief  Set the new prescaler value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetPrescaler(

+        AT91PS_RTTC pRTTC, 

+        unsigned int rtpres)

+{

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (rtpres & 0xFFFF);	

+	return (pRTTC->RTTC_RTMR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTRestart()

+//* \brief  Restart the RTT prescaler

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTRestart(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTRST;	

+}

+

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmINT()

+//* \brief  Enable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearAlarmINT()

+//* \brief  Disable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetRttIncINT()

+//* \brief  Enable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearRttIncINT()

+//* \brief  Disable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmValue()

+//* \brief  Set RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmValue(

+        AT91PS_RTTC pRTTC, unsigned int alarm)

+{

+	pRTTC->RTTC_RTAR = alarm;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_GetAlarmValue()

+//* \brief  Get RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetAlarmValue(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTAR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTGetStatus()

+//* \brief  Read the RTT status

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetStatus(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTSR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ReadValue()

+//* \brief  Read the RTT value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTReadValue(

+        AT91PS_RTTC pRTTC)

+{

+        register volatile unsigned int val1,val2;

+	do

+	{

+		val1 = pRTTC->RTTC_RTVR;

+		val2 = pRTTC->RTTC_RTVR;

+	}	

+	while(val1 != val2);

+	return(val1);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PITC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITInit

+//* \brief System timer init : period in µsecond, system clock freq in MHz

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITInit(

+        AT91PS_PITC pPITC,

+        unsigned int period,

+        unsigned int pit_frequency)

+{

+	pPITC->PITC_PIMR = period? (period * pit_frequency + 8) >> 4 : 0; // +8 to avoid %10 and /10

+	pPITC->PITC_PIMR |= AT91C_PITC_PITEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITSetPIV

+//* \brief Set the PIT Periodic Interval Value 

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITSetPIV(

+        AT91PS_PITC pPITC,

+        unsigned int piv)

+{

+	pPITC->PITC_PIMR = piv | (pPITC->PITC_PIMR & (AT91C_PITC_PITEN | AT91C_PITC_PITIEN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITEnableInt

+//* \brief Enable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITEnableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR |= AT91C_PITC_PITIEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITDisableInt

+//* \brief Disable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITDisableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR &= ~AT91C_PITC_PITIEN;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetMode

+//* \brief Read PIT mode register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetMode(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetStatus

+//* \brief Read PIT status register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetStatus(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PISR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIIR

+//* \brief Read PIT CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIIR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIIR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIVR

+//* \brief Read System timer CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIVR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIVR);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR WDTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSetMode

+//* \brief Set Watchdog Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTSetMode(

+        AT91PS_WDTC pWDTC,

+        unsigned int Mode)

+{

+	pWDTC->WDTC_WDMR = Mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTRestart

+//* \brief Restart Watchdog

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTRestart(

+        AT91PS_WDTC pWDTC)

+{

+	pWDTC->WDTC_WDCR = 0xA5000001;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSGettatus

+//* \brief Get Watchdog Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTSGettatus(

+        AT91PS_WDTC pWDTC)

+{

+	return(pWDTC->WDTC_WDSR & 0x3);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTGetPeriod

+//* \brief Translate ms into Watchdog Compatible value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTGetPeriod(unsigned int ms)

+{

+	if ((ms < 4) || (ms > 16000))

+		return 0;

+	return((ms << 8) / 1000);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR VREG

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Enable_LowPowerMode

+//* \brief Enable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Enable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR |= AT91C_VREG_PSTDBY;	 

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Disable_LowPowerMode

+//* \brief Disable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Disable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR &= ~AT91C_VREG_PSTDBY;	 

+}/* *****************************************************************************

+                SOFTWARE API FOR MC

+   ***************************************************************************** */

+

+#define AT91C_MC_CORRECT_KEY  ((unsigned int) 0x5A << 24) // (MC) Correct Protect Key

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_Remap

+//* \brief Make Remap

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_Remap (void)     //  

+{

+    AT91PS_MC pMC = (AT91PS_MC) AT91C_BASE_MC;

+    

+    pMC->MC_RCR = AT91C_MC_RCB;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_CfgModeReg

+//* \brief Configure the EFC Mode Register of the MC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_CfgModeReg (

+	AT91PS_MC pMC, // pointer to a MC controller

+	unsigned int mode)        // mode register 

+{

+	// Write to the FMR register

+	pMC->MC_FMR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetModeReg

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetModeReg(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_ComputeFMCN

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_ComputeFMCN(

+	int master_clock) // master clock in Hz

+{

+	return (master_clock/1000000 +2);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_PerformCmd

+//* \brief Perform EFC Command

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_PerformCmd (

+	AT91PS_MC pMC, // pointer to a MC controller

+    unsigned int transfer_cmd)

+{

+	pMC->MC_FCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetStatus

+//* \brief Return MC EFC Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetStatus(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptMasked

+//* \brief Test if EFC MC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptMasked(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetModeReg(pMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptSet

+//* \brief Test if EFC MC Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptSet(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetStatus(pMC) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SPI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Open

+//* \brief Open a SPI Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgCs

+//* \brief Configure SPI chip select register

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgCs (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	int cs,     // SPI cs number (0 to 3)

+ 	int val)   //  chip select register

+{

+	//* Write to the CSR register

+	*(pSPI->SPI_CSR + cs) = val;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_EnableIt

+//* \brief Enable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_EnableIt (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pSPI->SPI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_DisableIt

+//* \brief Disable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_DisableIt (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pSPI->SPI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Reset

+//* \brief Reset the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Reset (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SWRST;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Enable

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Enable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Disable

+//* \brief Disable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Disable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgMode

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgMode (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	int mode)        // mode register 

+{

+	//* Write to the MR register

+	pSPI->SPI_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPCS

+//* \brief Switch to the correct PCS of SPI Mode Register : Fixed Peripheral Selected

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPCS (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	char PCS_Device) // PCS of the Device

+{	

+ 	//* Write to the MR register

+	pSPI->SPI_MR &= 0xFFF0FFFF;

+	pSPI->SPI_MR |= ( (PCS_Device<<16) & AT91C_SPI_PCS );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_ReceiveFrame (

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is bSPIy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_SendFrame(

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Close

+//* \brief Close SPI: disable IT disable transfert, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Close (

+	AT91PS_SPI pSPI)     // \arg pointer to a SPI controller

+{

+    //* Reset all the Chip Select register

+    pSPI->SPI_CSR[0] = 0 ;

+    pSPI->SPI_CSR[1] = 0 ;

+    pSPI->SPI_CSR[2] = 0 ;

+    pSPI->SPI_CSR[3] = 0 ;

+

+    //* Reset the SPI mode

+    pSPI->SPI_MR = 0  ;

+

+    //* Disable all interrupts

+    pSPI->SPI_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pSPI->SPI_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_PutChar (

+	AT91PS_SPI pSPI,

+	unsigned int character,

+             unsigned int cs_number )

+{

+    unsigned int value_for_cs;

+    value_for_cs = (~(1 << cs_number)) & 0xF;  //Place a zero among a 4 ONEs number

+    pSPI->SPI_TDR = (character & 0xFFFF) | (value_for_cs << 16);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_GetChar (

+	const AT91PS_SPI pSPI)

+{

+    return((pSPI->SPI_RDR) & 0xFFFF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetInterruptMaskStatus

+//* \brief Return SPI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_GetInterruptMaskStatus( // \return SPI Interrupt Mask Status

+        AT91PS_SPI pSpi) // \arg  pointer to a SPI controller

+{

+        return pSpi->SPI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_IsInterruptMasked

+//* \brief Test if SPI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_IsInterruptMasked(

+        AT91PS_SPI pSpi,   // \arg  pointer to a SPI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SPI_GetInterruptMaskStatus(pSpi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR USART

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Calculate the baudrate

+//* Standard Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_MODE ( AT91C_US_USMODE_NORMAL + \

+                        AT91C_US_NBSTOP_1_BIT + \

+                        AT91C_US_PAR_NONE + \

+                        AT91C_US_CHRL_8_BITS + \

+                        AT91C_US_CLKS_CLOCK )

+

+//* Standard External Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_SCK_MODE ( AT91C_US_USMODE_NORMAL + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_EXT )

+

+//* Standard Synchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_SYNC_MODE ( AT91C_US_SYNC + \

+                       AT91C_US_USMODE_NORMAL + \

+                       AT91C_US_NBSTOP_1_BIT + \

+                       AT91C_US_PAR_NONE + \

+                       AT91C_US_CHRL_8_BITS + \

+                       AT91C_US_CLKS_CLOCK )

+

+//* SCK used Label

+#define AT91C_US_SCK_USED (AT91C_US_CKLO | AT91C_US_CLKS_EXT)

+

+//* Standard ISO T=0 Mode : 8 bits , 1 stop , parity

+#define AT91C_US_ISO_READER_MODE ( AT91C_US_USMODE_ISO7816_0 + \

+					   		 AT91C_US_CLKS_CLOCK +\

+                       		 AT91C_US_NBSTOP_1_BIT + \

+                       		 AT91C_US_PAR_EVEN + \

+                       		 AT91C_US_CHRL_8_BITS + \

+                       		 AT91C_US_CKLO +\

+                       		 AT91C_US_OVER)

+

+//* Standard IRDA mode

+#define AT91C_US_ASYNC_IRDA_MODE (  AT91C_US_USMODE_IRDA + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_CLOCK )

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Caluculate baud_value according to the main clock and the baud rate

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Baudrate (

+	const unsigned int main_clock, // \arg peripheral clock

+	const unsigned int baud_rate)  // \arg UART baudrate

+{

+	unsigned int baud_value = ((main_clock*10)/(baud_rate * 16));

+	if ((baud_value % 10) >= 5)

+		baud_value = (baud_value / 10) + 1;

+	else

+		baud_value /= 10;

+	return baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetBaudrate (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int mainClock, // \arg peripheral clock

+	unsigned int speed)     // \arg UART baudrate

+{

+	//* Define the baud rate divisor register

+	pUSART->US_BRGR = AT91F_US_Baudrate(mainClock, speed);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetTimeguard

+//* \brief Set USART timeguard

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetTimeguard (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int timeguard) // \arg timeguard value

+{

+	//* Write the Timeguard Register

+	pUSART->US_TTGR = timeguard ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableIt

+//* \brief Enable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUSART->US_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableIt

+//* \brief Disable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IER register

+	pUSART->US_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Configure

+//* \brief Configure USART

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Configure (

+	AT91PS_USART pUSART,     // \arg pointer to a USART controller

+	unsigned int mainClock,  // \arg peripheral clock

+	unsigned int mode ,      // \arg mode Register to be programmed

+	unsigned int baudRate ,  // \arg baudrate to be programmed

+	unsigned int timeguard ) // \arg timeguard to be programmed

+{

+    //* Disable interrupts

+    pUSART->US_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+    pUSART->US_CR = AT91C_US_RSTRX | AT91C_US_RSTTX | AT91C_US_RXDIS | AT91C_US_TXDIS ;

+

+	//* Define the baud rate divisor register

+	AT91F_US_SetBaudrate(pUSART, mainClock, baudRate);

+

+	//* Write the Timeguard Register

+	AT91F_US_SetTimeguard(pUSART, timeguard);

+

+    //* Clear Transmit and Receive Counters

+    AT91F_PDC_Open((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Define the USART mode

+    pUSART->US_MR = mode  ;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableRx

+//* \brief Enable receiving characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableTx

+//* \brief Enable sending characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable  transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetRx

+//* \brief Reset Receiver and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset receiver

+	pUSART->US_CR = AT91C_US_RSTRX;

+    //* Re-Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetTx

+//* \brief Reset Transmitter and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset transmitter

+	pUSART->US_CR = AT91C_US_RSTTX;

+    //* Enable transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableRx

+//* \brief Disable Receiver

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable receiver

+    pUSART->US_CR = AT91C_US_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableTx

+//* \brief Disable Transmitter

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable transmitter

+    pUSART->US_CR = AT91C_US_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Close

+//* \brief Close USART: disable IT disable receiver and transmitter, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Close (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Reset the baud rate divisor register

+    pUSART->US_BRGR = 0 ;

+

+    //* Reset the USART mode

+    pUSART->US_MR = 0  ;

+

+    //* Reset the Timeguard Register

+    pUSART->US_TTGR = 0;

+

+    //* Disable all interrupts

+    pUSART->US_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pUSART->US_CR = AT91C_US_TXDIS | AT91C_US_RXDIS | AT91C_US_RSTTX | AT91C_US_RSTRX ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_TxReady

+//* \brief Return 1 if a character can be written in US_THR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_TxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_TXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_RxReady

+//* \brief Return 1 if a character can be read in US_RHR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_RxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_RXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Error

+//* \brief Return the error flag

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Error (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR &

+    	(AT91C_US_OVRE |  // Overrun error

+    	 AT91C_US_FRAME | // Framing error

+    	 AT91C_US_PARE));  // Parity error

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_PutChar (

+	AT91PS_USART pUSART,

+	int character )

+{

+    pUSART->US_THR = (character & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_US_GetChar (

+	const AT91PS_USART pUSART)

+{

+    return((pUSART->US_RHR) & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_SendFrame(

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_ReceiveFrame (

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetIrdaFilter

+//* \brief Set the value of IrDa filter tregister

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetIrdaFilter (

+	AT91PS_USART pUSART,

+	unsigned char value

+)

+{

+	pUSART->US_IF = value;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SSC

+   ***************************************************************************** */

+//* Define the standard I2S mode configuration

+

+//* Configuration to set in the SSC Transmit Clock Mode Register

+//* Parameters :  nb_bit_by_slot : 8, 16 or 32 bits

+//* 			  nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_MASTER_TX_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									   AT91C_SSC_CKS_DIV   +\

+                            		   AT91C_SSC_CKO_CONTINOUS      +\

+                            		   AT91C_SSC_CKG_NONE    +\

+                                       AT91C_SSC_START_FALL_RF +\

+                           			   AT91C_SSC_STTOUT  +\

+                            		   ((1<<16) & AT91C_SSC_STTDLY) +\

+                            		   ((((nb_bit_by_slot*nb_slot_by_frame)/2)-1) <<24))

+

+

+//* Configuration to set in the SSC Transmit Frame Mode Register

+//* Parameters : nb_bit_by_slot : 8, 16 or 32 bits

+//* 			 nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_TX_FRAME_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									(nb_bit_by_slot-1)  +\

+                            		AT91C_SSC_MSBF   +\

+                            		(((nb_slot_by_frame-1)<<8) & AT91C_SSC_DATNB)  +\

+                            		(((nb_bit_by_slot-1)<<16) & AT91C_SSC_FSLEN) +\

+                            		AT91C_SSC_FSOS_NEGATIVE)

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_SetBaudrate (

+        AT91PS_SSC pSSC,        // \arg pointer to a SSC controller

+        unsigned int mainClock, // \arg peripheral clock

+        unsigned int speed)     // \arg SSC baudrate

+{

+        unsigned int baud_value;

+        //* Define the baud rate divisor register

+        if (speed == 0)

+           baud_value = 0;

+        else

+        {

+           baud_value = (unsigned int) (mainClock * 10)/(2*speed);

+           if ((baud_value % 10) >= 5)

+                  baud_value = (baud_value / 10) + 1;

+           else

+                  baud_value /= 10;

+        }

+

+        pSSC->SSC_CMR = baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_Configure

+//* \brief Configure SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_Configure (

+             AT91PS_SSC pSSC,          // \arg pointer to a SSC controller

+             unsigned int syst_clock,  // \arg System Clock Frequency

+             unsigned int baud_rate,   // \arg Expected Baud Rate Frequency

+             unsigned int clock_rx,    // \arg Receiver Clock Parameters

+             unsigned int mode_rx,     // \arg mode Register to be programmed

+             unsigned int clock_tx,    // \arg Transmitter Clock Parameters

+             unsigned int mode_tx)     // \arg mode Register to be programmed

+{

+    //* Disable interrupts

+	pSSC->SSC_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+	pSSC->SSC_CR = AT91C_SSC_SWRST | AT91C_SSC_RXDIS | AT91C_SSC_TXDIS ;

+

+    //* Define the Clock Mode Register

+	AT91F_SSC_SetBaudrate(pSSC, syst_clock, baud_rate);

+

+     //* Write the Receive Clock Mode Register

+	pSSC->SSC_RCMR =  clock_rx;

+

+     //* Write the Transmit Clock Mode Register

+	pSSC->SSC_TCMR =  clock_tx;

+

+     //* Write the Receive Frame Mode Register

+	pSSC->SSC_RFMR =  mode_rx;

+

+     //* Write the Transmit Frame Mode Register

+	pSSC->SSC_TFMR =  mode_tx;

+

+    //* Clear Transmit and Receive Counters

+	AT91F_PDC_Open((AT91PS_PDC) &(pSSC->SSC_RPR));

+

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableRx

+//* \brief Enable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableRx

+//* \brief Disable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableTx

+//* \brief Enable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableTx

+//* \brief Disable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableIt

+//* \brief Enable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pSSC->SSC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableIt

+//* \brief Disable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pSSC->SSC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_ReceiveFrame (

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_SendFrame(

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_GetInterruptMaskStatus

+//* \brief Return SSC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_GetInterruptMaskStatus( // \return SSC Interrupt Mask Status

+        AT91PS_SSC pSsc) // \arg  pointer to a SSC controller

+{

+        return pSsc->SSC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_IsInterruptMasked

+//* \brief Test if SSC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_SSC_IsInterruptMasked(

+        AT91PS_SSC pSsc,   // \arg  pointer to a SSC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SSC_GetInterruptMaskStatus(pSsc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TWI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_EnableIt

+//* \brief Enable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_EnableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pTWI->TWI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_DisableIt

+//* \brief Disable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_DisableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pTWI->TWI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_Configure

+//* \brief Configure TWI in master mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_Configure ( AT91PS_TWI pTWI )          // \arg pointer to a TWI controller

+{

+    //* Disable interrupts

+	pTWI->TWI_IDR = (unsigned int) -1;

+

+    //* Reset peripheral

+	pTWI->TWI_CR = AT91C_TWI_SWRST;

+

+	//* Set Master mode

+	pTWI->TWI_CR = AT91C_TWI_MSEN;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_GetInterruptMaskStatus

+//* \brief Return TWI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TWI_GetInterruptMaskStatus( // \return TWI Interrupt Mask Status

+        AT91PS_TWI pTwi) // \arg  pointer to a TWI controller

+{

+        return pTwi->TWI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_IsInterruptMasked

+//* \brief Test if TWI Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TWI_IsInterruptMasked(

+        AT91PS_TWI pTwi,   // \arg  pointer to a TWI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TWI_GetInterruptMaskStatus(pTwi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PWMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetStatus

+//* \brief Return PWM Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetStatus( // \return PWM Interrupt Status

+	AT91PS_PWMC pPWM) // pointer to a PWM controller

+{

+	return pPWM->PWMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptEnable

+//* \brief Enable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptEnable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be enabled

+{

+        pPwm->PWMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptDisable

+//* \brief Disable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptDisable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be disabled

+{

+        pPwm->PWMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetInterruptMaskStatus

+//* \brief Return PWM Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetInterruptMaskStatus( // \return PWM Interrupt Mask Status

+        AT91PS_PWMC pPwm) // \arg  pointer to a PWM controller

+{

+        return pPwm->PWMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsInterruptMasked

+//* \brief Test if PWM Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsInterruptMasked(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetInterruptMaskStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsStatusSet

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsStatusSet(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_CfgChannel

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int mode, // \arg  PWM mode

+        unsigned int period, // \arg PWM period

+        unsigned int duty) // \arg PWM duty cycle

+{

+	pPWM->PWMC_CH[channelId].PWMC_CMR = mode;

+	pPWM->PWMC_CH[channelId].PWMC_CDTYR = duty;

+	pPWM->PWMC_CH[channelId].PWMC_CPRDR = period;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StartChannel

+//* \brief Enable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StartChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_ENA = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StopChannel

+//* \brief Disable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StopChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_DIS = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_UpdateChannel

+//* \brief Update Period or Duty Cycle

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_UpdateChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int update) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_CH[channelId].PWMC_CUPDR = update;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR UDP

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableIt

+//* \brief Enable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUDP->UDP_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableIt

+//* \brief Disable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pUDP->UDP_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetAddress

+//* \brief Set UDP functional address

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetAddress (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char address)   // \arg new UDP address

+{

+	pUDP->UDP_FADDR = (AT91C_UDP_FEN | address);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] &= ~AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetState

+//* \brief Set UDP Device state

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetState (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg new UDP address

+{

+	pUDP->UDP_GLBSTATE  &= ~(AT91C_UDP_FADDEN | AT91C_UDP_CONFG);

+	pUDP->UDP_GLBSTATE  |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetState

+//* \brief return UDP Device state

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetState ( // \return the UDP device state

+	AT91PS_UDP pUDP)     // \arg pointer to a UDP controller

+{

+	return (pUDP->UDP_GLBSTATE  & (AT91C_UDP_FADDEN | AT91C_UDP_CONFG));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_ResetEp

+//* \brief Reset UDP endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_ResetEp ( // \return the UDP device state

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg Endpoints to be reset

+{

+	pUDP->UDP_RSTEP = flag;

+	pUDP->UDP_RSTEP = 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStall

+//* \brief Endpoint will STALL requests

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpStall(

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_FORCESTALL;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpWrite

+//* \brief Write value in the DPR

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpWrite(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned char value)     // \arg value to be written in the DPR

+{

+	pUDP->UDP_FDR[endpoint] = value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpRead

+//* \brief Return value from the DPR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpRead(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_FDR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpEndOfWr

+//* \brief Notify the UDP that values in DPR are ready to be sent

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpEndOfWr(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_TXPKTRDY;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpClear

+//* \brief Clear flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpClear(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] &= ~(flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpSet

+//* \brief Set flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpSet(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStatus

+//* \brief Return the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpStatus(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_CSR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetInterruptMaskStatus

+//* \brief Return UDP Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetInterruptMaskStatus( // \return UDP Interrupt Mask Status

+        AT91PS_UDP pUdp) // \arg  pointer to a UDP controller

+{

+        return pUdp->UDP_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_IsInterruptMasked

+//* \brief Test if UDP Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_UDP_IsInterruptMasked(

+        AT91PS_UDP pUdp,   // \arg  pointer to a UDP controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_UDP_GetInterruptMaskStatus(pUdp) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptEnable

+//* \brief Enable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptEnable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be enabled

+{

+        pTc->TC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptDisable

+//* \brief Disable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptDisable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be disabled

+{

+        pTc->TC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_GetInterruptMaskStatus

+//* \brief Return TC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TC_GetInterruptMaskStatus( // \return TC Interrupt Mask Status

+        AT91PS_TC pTc) // \arg  pointer to a TC controller

+{

+        return pTc->TC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_IsInterruptMasked

+//* \brief Test if TC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline int AT91F_TC_IsInterruptMasked(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TC_GetInterruptMaskStatus(pTc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR CAN

+   ***************************************************************************** */

+#define	STANDARD_FORMAT 0

+#define	EXTENDED_FORMAT 1

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_InitMailboxRegisters()

+//* \brief Configure the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_InitMailboxRegisters(AT91PS_CAN_MB	CAN_Mailbox,

+								int  			mode_reg,

+								int 			acceptance_mask_reg,

+								int  			id_reg,

+								int  			data_low_reg,

+								int  			data_high_reg,

+								int  			control_reg)

+{

+	CAN_Mailbox->CAN_MB_MCR 	= 0x0;

+	CAN_Mailbox->CAN_MB_MMR 	= mode_reg;

+	CAN_Mailbox->CAN_MB_MAM 	= acceptance_mask_reg;

+	CAN_Mailbox->CAN_MB_MID 	= id_reg;

+	CAN_Mailbox->CAN_MB_MDL 	= data_low_reg; 		

+	CAN_Mailbox->CAN_MB_MDH 	= data_high_reg;

+	CAN_Mailbox->CAN_MB_MCR 	= control_reg;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EnableCAN()

+//* \brief 

+//*----------------------------------------------------------------------------

+__inline void AT91F_EnableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR |= AT91C_CAN_CANEN;

+

+	// Wait for WAKEUP flag raising <=> 11-recessive-bit were scanned by the transceiver

+	while( (pCAN->CAN_SR & AT91C_CAN_WAKEUP) != AT91C_CAN_WAKEUP );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DisableCAN()

+//* \brief 

+//*----------------------------------------------------------------------------

+__inline void AT91F_DisableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR &= ~AT91C_CAN_CANEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_EnableIt

+//* \brief Enable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_EnableIt (

+	AT91PS_CAN pCAN,     // pointer to a CAN controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pCAN->CAN_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_DisableIt

+//* \brief Disable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_DisableIt (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pCAN->CAN_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetStatus

+//* \brief Return CAN Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetStatus( // \return CAN Interrupt Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInterruptMaskStatus

+//* \brief Return CAN Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInterruptMaskStatus( // \return CAN Interrupt Mask Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsInterruptMasked

+//* \brief Test if CAN Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsInterruptMasked(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetInterruptMaskStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsStatusSet

+//* \brief Test if CAN Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsStatusSet(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgModeReg

+//* \brief Configure the Mode Register of the CAN controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgModeReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pCAN->CAN_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetModeReg

+//* \brief Return the Mode Register of the CAN controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetModeReg (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgBaudrateReg

+//* \brief Configure the Baudrate of the CAN controller for the network

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgBaudrateReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int baudrate_cfg)

+{

+	//* Write to the BR register

+	pCAN->CAN_BR = baudrate_cfg;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetBaudrate

+//* \brief Return the Baudrate of the CAN controller for the network value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetBaudrate (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_BR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInternalCounter

+//* \brief Return CAN Timer Regsiter Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInternalCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIM;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetTimestamp

+//* \brief Return CAN Timestamp Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetTimestamp (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIMESTP;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetErrorCounter

+//* \brief Return CAN Error Counter Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetErrorCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_ECR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitTransferRequest

+//* \brief Request for a transfer on the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitTransferRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int transfer_cmd)

+{

+	pCAN->CAN_TCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitAbortRequest

+//* \brief Abort the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitAbortRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int abort_cmd)

+{

+	pCAN->CAN_ACR = abort_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageModeReg

+//* \brief Program the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mode)

+{

+	CAN_Mailbox->CAN_MB_MMR = mode;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageModeReg

+//* \brief Return the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MMR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageIDReg

+//* \brief Program the Message ID Register

+//* \brief Version == 0 for Standard messsage, Version == 1 for Extended  

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int id,

+    unsigned char version)

+{

+	if(version==0)	// IDvA Standard Format

+		CAN_Mailbox->CAN_MB_MID = id<<18;

+	else	// IDvB Extended Format

+		CAN_Mailbox->CAN_MB_MID = id | (1<<29);	// set MIDE bit

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageIDReg

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MID;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageAcceptanceMaskReg

+//* \brief Program the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mask)

+{

+	CAN_Mailbox->CAN_MB_MAM = mask;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageAcceptanceMaskReg

+//* \brief Return the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MAM;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetFamilyID

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetFamilyID (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MFID;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageCtrl

+//* \brief Request and config for a transfer on the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageCtrlReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int message_ctrl_cmd)

+{

+	CAN_Mailbox->CAN_MB_MCR = message_ctrl_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageStatus

+//* \brief Return CAN Mailbox Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageStatus (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataLow

+//* \brief Program data low value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDL = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataLow

+//* \brief Return data low value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDL;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataHigh

+//* \brief Program data high value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDH = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataHigh

+//* \brief Return data high value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDH;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_Open

+//* \brief Open a CAN Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+/* *****************************************************************************

+                SOFTWARE API FOR ADC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableIt

+//* \brief Enable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableIt (

+	AT91PS_ADC pADC,     // pointer to a ADC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pADC->ADC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableIt

+//* \brief Disable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableIt (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pADC->ADC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetStatus

+//* \brief Return ADC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetStatus( // \return ADC Interrupt Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetInterruptMaskStatus

+//* \brief Return ADC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetInterruptMaskStatus( // \return ADC Interrupt Mask Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsInterruptMasked

+//* \brief Test if ADC Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsInterruptMasked(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetInterruptMaskStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsStatusSet

+//* \brief Test if ADC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsStatusSet(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgModeReg

+//* \brief Configure the Mode Register of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgModeReg (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pADC->ADC_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetModeReg

+//* \brief Return the Mode Register of the ADC controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetModeReg (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgTimings

+//* \brief Configure the different necessary timings of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgTimings (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mck_clock, // in MHz 

+	unsigned int adc_clock, // in MHz 

+	unsigned int startup_time, // in us 

+	unsigned int sample_and_hold_time)	// in ns  

+{

+	unsigned int prescal,startup,shtim;

+	

+	prescal = mck_clock/(2*adc_clock) - 1;

+	startup = adc_clock*startup_time/8 - 1;

+	shtim = adc_clock*sample_and_hold_time/1000 - 1;

+	

+	//* Write to the MR register

+	pADC->ADC_MR = ( (prescal<<8) & AT91C_ADC_PRESCAL) | ( (startup<<16) & AT91C_ADC_STARTUP) | ( (shtim<<24) & AT91C_ADC_SHTIM);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHER register

+	pADC->ADC_CHER = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register 

+{

+	//* Write to the CHDR register

+	pADC->ADC_CHDR = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetChannelStatus

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetChannelStatus (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CHSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_StartConversion

+//* \brief Software request for a analog to digital conversion 

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_StartConversion (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_SoftReset

+//* \brief Software reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_SoftReset (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetLastConvertedData

+//* \brief Return the Last Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetLastConvertedData (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_LCDR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH0

+//* \brief Return the Channel 0 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH0 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR0;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH1

+//* \brief Return the Channel 1 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH1 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR1;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH2

+//* \brief Return the Channel 2 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH2 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR2;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH3

+//* \brief Return the Channel 3 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH3 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR3;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH4

+//* \brief Return the Channel 4 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH4 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR4;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH5

+//* \brief Return the Channel 5 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH5 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR5;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH6

+//* \brief Return the Channel 6 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH6 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR6;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH7

+//* \brief Return the Channel 7 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH7 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR7;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR AES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_EnableIt

+//* \brief Enable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_EnableIt (

+	AT91PS_AES pAES,     // pointer to a AES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pAES->AES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_DisableIt

+//* \brief Disable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_DisableIt (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pAES->AES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetStatus

+//* \brief Return AES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetStatus( // \return AES Interrupt Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetInterruptMaskStatus

+//* \brief Return AES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetInterruptMaskStatus( // \return AES Interrupt Mask Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsInterruptMasked

+//* \brief Test if AES Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsInterruptMasked(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetInterruptMaskStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsStatusSet

+//* \brief Test if AES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsStatusSet(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgModeReg

+//* \brief Configure the Mode Register of the AES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgModeReg (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pAES->AES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetModeReg

+//* \brief Return the Mode Register of the AES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetModeReg (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	return pAES->AES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_StartProcessing (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SoftReset

+//* \brief Reset AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SoftReset (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_LoadNewSeed

+//* \brief Load New Seed in the random number generator

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_LoadNewSeed (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_LOADSEED;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetCryptoKey

+//* \brief Set Cryptographic Key x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetCryptoKey (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pAES->AES_KEYWxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_InputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pAES->AES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetOutputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index

+	)

+{

+	return pAES->AES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetInitializationVector

+//* \brief Set Initialization Vector (or Counter) x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetInitializationVector (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pAES->AES_IVxR[index] = initvector;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TDES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_EnableIt

+//* \brief Enable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_EnableIt (

+	AT91PS_TDES pTDES,     // pointer to a TDES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pTDES->TDES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_DisableIt

+//* \brief Disable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_DisableIt (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pTDES->TDES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetStatus

+//* \brief Return TDES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetStatus( // \return TDES Interrupt Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetInterruptMaskStatus

+//* \brief Return TDES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetInterruptMaskStatus( // \return TDES Interrupt Mask Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsInterruptMasked

+//* \brief Test if TDES Interrupt is Masked 

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsInterruptMasked(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetInterruptMaskStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsStatusSet

+//* \brief Test if TDES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsStatusSet(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgModeReg

+//* \brief Configure the Mode Register of the TDES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgModeReg (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int mode)        // mode register 

+{

+	//* Write to the MR register

+	pTDES->TDES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetModeReg

+//* \brief Return the Mode Register of the TDES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetModeReg (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	return pTDES->TDES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_StartProcessing (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SoftReset

+//* \brief Reset TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SoftReset (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey1

+//* \brief Set Cryptographic Key 1 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey1 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY1WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey2

+//* \brief Set Cryptographic Key 2 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey2 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY2WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey3

+//* \brief Set Cryptographic Key 3 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey3 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY3WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_InputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pTDES->TDES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetOutputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index

+	)

+{

+	return pTDES->TDES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetInitializationVector

+//* \brief Set Initialization Vector x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetInitializationVector (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pTDES->TDES_IVxR[index] = initvector;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  DBGU

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPIO

+//* \brief Configure PIO controllers to drive DBGU signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA27_DRXD    ) |

+		((unsigned int) AT91C_PA28_DTXD    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPIO

+//* \brief Configure PIO controllers to drive PMC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB30_PCK2    ) |

+		((unsigned int) AT91C_PB29_PCK1    ), // Peripheral A

+		((unsigned int) AT91C_PB20_PCK0    ) |

+		((unsigned int) AT91C_PB0_PCK0    ) |

+		((unsigned int) AT91C_PB22_PCK2    ) |

+		((unsigned int) AT91C_PB21_PCK1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA30_PCK2    ) |

+		((unsigned int) AT91C_PA13_PCK1    ) |

+		((unsigned int) AT91C_PA27_PCK3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  VREG

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RSTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SSC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPIO

+//* \brief Configure PIO controllers to drive SSC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA25_RK      ) |

+		((unsigned int) AT91C_PA22_TK      ) |

+		((unsigned int) AT91C_PA21_TF      ) |

+		((unsigned int) AT91C_PA24_RD      ) |

+		((unsigned int) AT91C_PA26_RF      ) |

+		((unsigned int) AT91C_PA23_TD      ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  WDTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US1

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPIO

+//* \brief Configure PIO controllers to drive US1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB26_RI1     ) |

+		((unsigned int) AT91C_PB24_DSR1    ) |

+		((unsigned int) AT91C_PB23_DCD1    ) |

+		((unsigned int) AT91C_PB25_DTR1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA7_SCK1    ) |

+		((unsigned int) AT91C_PA8_RTS1    ) |

+		((unsigned int) AT91C_PA6_TXD1    ) |

+		((unsigned int) AT91C_PA5_RXD1    ) |

+		((unsigned int) AT91C_PA9_CTS1    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US0

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPIO

+//* \brief Configure PIO controllers to drive US0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA0_RXD0    ) |

+		((unsigned int) AT91C_PA4_CTS0    ) |

+		((unsigned int) AT91C_PA3_RTS0    ) |

+		((unsigned int) AT91C_PA2_SCK0    ) |

+		((unsigned int) AT91C_PA1_TXD0    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI1

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPIO

+//* \brief Configure PIO controllers to drive SPI1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB16_NPCS13  ) |

+		((unsigned int) AT91C_PB10_NPCS11  ) |

+		((unsigned int) AT91C_PB11_NPCS12  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA4_NPCS13  ) |

+		((unsigned int) AT91C_PA29_NPCS13  ) |

+		((unsigned int) AT91C_PA21_NPCS10  ) |

+		((unsigned int) AT91C_PA22_SPCK1   ) |

+		((unsigned int) AT91C_PA25_NPCS11  ) |

+		((unsigned int) AT91C_PA2_NPCS11  ) |

+		((unsigned int) AT91C_PA24_MISO1   ) |

+		((unsigned int) AT91C_PA3_NPCS12  ) |

+		((unsigned int) AT91C_PA26_NPCS12  ) |

+		((unsigned int) AT91C_PA23_MOSI1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI0

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPIO

+//* \brief Configure PIO controllers to drive SPI0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB13_NPCS01  ) |

+		((unsigned int) AT91C_PB17_NPCS03  ) |

+		((unsigned int) AT91C_PB14_NPCS02  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA16_MISO0   ) |

+		((unsigned int) AT91C_PA13_NPCS01  ) |

+		((unsigned int) AT91C_PA15_NPCS03  ) |

+		((unsigned int) AT91C_PA17_MOSI0   ) |

+		((unsigned int) AT91C_PA18_SPCK0   ) |

+		((unsigned int) AT91C_PA14_NPCS02  ) |

+		((unsigned int) AT91C_PA12_NPCS00  ), // Peripheral A

+		((unsigned int) AT91C_PA7_NPCS01  ) |

+		((unsigned int) AT91C_PA9_NPCS03  ) |

+		((unsigned int) AT91C_PA8_NPCS02  )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PITC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AIC

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_FIQ) |

+		((unsigned int) 1 << AT91C_ID_IRQ0) |

+		((unsigned int) 1 << AT91C_ID_IRQ1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPIO

+//* \brief Configure PIO controllers to drive AIC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA30_IRQ0    ) |

+		((unsigned int) AT91C_PA29_FIQ     ), // Peripheral A

+		((unsigned int) AT91C_PA14_IRQ1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_AES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TWI

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TWI));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPIO

+//* \brief Configure PIO controllers to drive TWI signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA11_TWCK    ) |

+		((unsigned int) AT91C_PA10_TWD     ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  ADC

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_ADC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPIO

+//* \brief Configure PIO controllers to drive ADC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB18_ADTRG   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH3_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH3 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH3_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB22_PWM3    ), // Peripheral A

+		((unsigned int) AT91C_PB30_PWM3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH2_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB21_PWM2    ), // Peripheral A

+		((unsigned int) AT91C_PB29_PWM2    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH1_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB20_PWM1    ), // Peripheral A

+		((unsigned int) AT91C_PB28_PWM1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH0_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB19_PWM0    ), // Peripheral A

+		((unsigned int) AT91C_PB27_PWM0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RTTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RTTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RTTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  UDP

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_UDP));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TDES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  EMAC

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_EMAC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPIO

+//* \brief Configure PIO controllers to drive EMAC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB2_ETX0    ) |

+		((unsigned int) AT91C_PB12_ETXER   ) |

+		((unsigned int) AT91C_PB16_ECOL    ) |

+		((unsigned int) AT91C_PB11_ETX3    ) |

+		((unsigned int) AT91C_PB6_ERX1    ) |

+		((unsigned int) AT91C_PB15_ERXDV   ) |

+		((unsigned int) AT91C_PB13_ERX2    ) |

+		((unsigned int) AT91C_PB3_ETX1    ) |

+		((unsigned int) AT91C_PB8_EMDC    ) |

+		((unsigned int) AT91C_PB5_ERX0    ) |

+		//((unsigned int) AT91C_PB18_EF100   ) |

+		((unsigned int) AT91C_PB14_ERX3    ) |

+		((unsigned int) AT91C_PB4_ECRS_ECRSDV) |

+		((unsigned int) AT91C_PB1_ETXEN   ) |

+		((unsigned int) AT91C_PB10_ETX2    ) |

+		((unsigned int) AT91C_PB0_ETXCK_EREFCK) |

+		((unsigned int) AT91C_PB9_EMDIO   ) |

+		((unsigned int) AT91C_PB7_ERXER   ) |

+		((unsigned int) AT91C_PB17_ERXCK   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC0

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPIO

+//* \brief Configure PIO controllers to drive TC0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB23_TIOA0   ) |

+		((unsigned int) AT91C_PB24_TIOB0   ), // Peripheral A

+		((unsigned int) AT91C_PB12_TCLK0   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC1

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPIO

+//* \brief Configure PIO controllers to drive TC1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB25_TIOA1   ) |

+		((unsigned int) AT91C_PB26_TIOB1   ), // Peripheral A

+		((unsigned int) AT91C_PB19_TCLK1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC2

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC2));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPIO

+//* \brief Configure PIO controllers to drive TC2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB28_TIOB2   ) |

+		((unsigned int) AT91C_PB27_TIOA2   ), // Peripheral A

+		0); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA15_TCLK2   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  MC

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOA_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOA

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOA_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOA));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOB_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOB

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOB_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOB));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  CAN

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_CAN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPIO

+//* \brief Configure PIO controllers to drive CAN signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA20_CANTX   ) |

+		((unsigned int) AT91C_PA19_CANRX   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PWMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PWMC));

+}

+

+#endif // lib_AT91SAM7X128_H

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X256.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X256.h
new file mode 100644
index 0000000..02ee900
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/lib_AT91SAM7X256.h
@@ -0,0 +1,4558 @@
+//* ----------------------------------------------------------------------------

+//*         ATMEL Microcontroller Software Support  -  ROUSSET  -

+//* ----------------------------------------------------------------------------

+//* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR

+//* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF

+//* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE

+//* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,

+//* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT

+//* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,

+//* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF

+//* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING

+//* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

+//* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

+//* ----------------------------------------------------------------------------

+//* File Name           : lib_AT91SAM7X256.h

+//* Object              : AT91SAM7X256 inlined functions

+//* Generated           : AT91 SW Application Group  05/20/2005 (16:22:29)

+//*

+//* CVS Reference       : /lib_dbgu.h/1.1/Fri Jan 31 12:18:40 2003//

+//* CVS Reference       : /lib_pmc_SAM7X.h/1.1/Tue Feb  1 08:32:10 2005//

+//* CVS Reference       : /lib_VREG_6085B.h/1.1/Tue Feb  1 16:20:47 2005//

+//* CVS Reference       : /lib_rstc_6098A.h/1.1/Wed Oct  6 10:39:20 2004//

+//* CVS Reference       : /lib_ssc.h/1.4/Fri Jan 31 12:19:20 2003//

+//* CVS Reference       : /lib_wdtc_6080A.h/1.1/Wed Oct  6 10:38:30 2004//

+//* CVS Reference       : /lib_usart.h/1.5/Thu Nov 21 16:01:54 2002//

+//* CVS Reference       : /lib_spi2.h/1.1/Mon Aug 25 14:23:52 2003//

+//* CVS Reference       : /lib_pitc_6079A.h/1.2/Tue Nov  9 14:43:56 2004//

+//* CVS Reference       : /lib_aic_6075b.h/1.1/Fri May 20 14:01:19 2005//

+//* CVS Reference       : /lib_aes_6149a.h/1.1/Mon Jan 17 07:43:09 2005//

+//* CVS Reference       : /lib_twi.h/1.3/Mon Jul 19 14:27:58 2004//

+//* CVS Reference       : /lib_adc.h/1.6/Fri Oct 17 09:12:38 2003//

+//* CVS Reference       : /lib_rttc_6081A.h/1.1/Wed Oct  6 10:39:38 2004//

+//* CVS Reference       : /lib_udp.h/1.4/Wed Feb 16 08:39:34 2005//

+//* CVS Reference       : /lib_des3_6150a.h/1.1/Mon Jan 17 09:19:19 2005//

+//* CVS Reference       : /lib_tc_1753b.h/1.1/Fri Jan 31 12:20:02 2003//

+//* CVS Reference       : /lib_MC_SAM7X.h/1.1/Thu Mar 25 15:19:14 2004//

+//* CVS Reference       : /lib_pio.h/1.3/Fri Jan 31 12:18:56 2003//

+//* CVS Reference       : /lib_can_AT91.h/1.4/Fri Oct 17 09:12:50 2003//

+//* CVS Reference       : /lib_PWM_SAM.h/1.3/Thu Jan 22 10:10:50 2004//

+//* CVS Reference       : /lib_pdc.h/1.2/Tue Jul  2 13:29:40 2002//

+//* ----------------------------------------------------------------------------

+

+#ifndef lib_AT91SAM7X256_H

+#define lib_AT91SAM7X256_H

+

+/* *****************************************************************************

+                SOFTWARE API FOR AIC

+   ***************************************************************************** */

+#define AT91C_AIC_BRANCH_OPCODE ((void (*) ()) 0xE51FFF20) // ldr, pc, [pc, #-&F20]

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ConfigureIt

+//* \brief Interrupt Handler Initialization

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AIC_ConfigureIt (

+	AT91PS_AIC pAic,  // \arg pointer to the AIC registers

+	unsigned int irq_id,     // \arg interrupt number to initialize

+	unsigned int priority,   // \arg priority to give to the interrupt

+	unsigned int src_type,   // \arg activation and sense of activation

+	void (*newHandler) (void) ) // \arg address of the interrupt handler

+{

+	unsigned int oldHandler;

+    unsigned int mask ;

+

+    oldHandler = pAic->AIC_SVR[irq_id];

+

+    mask = 0x1 << irq_id ;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Save the interrupt handler routine pointer and the interrupt priority

+    pAic->AIC_SVR[irq_id] = (unsigned int) newHandler ;

+    //* Store the Source Mode Register

+    pAic->AIC_SMR[irq_id] = src_type | priority  ;

+    //* Clear the interrupt on the interrupt controller

+    pAic->AIC_ICCR = mask ;

+

+	return oldHandler;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_EnableIt

+//* \brief Enable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_EnableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    //* Enable the interrupt on the interrupt controller

+    pAic->AIC_IECR = 0x1 << irq_id ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_DisableIt

+//* \brief Disable corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_DisableIt (

+	AT91PS_AIC pAic,      // \arg pointer to the AIC registers

+	unsigned int irq_id ) // \arg interrupt number to initialize

+{

+    unsigned int mask = 0x1 << irq_id;

+    //* Disable the interrupt on the interrupt controller

+    pAic->AIC_IDCR = mask ;

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = mask ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_ClearIt

+//* \brief Clear corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_ClearIt (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number to initialize

+{

+    //* Clear the interrupt on the Interrupt Controller ( if one is pending )

+    pAic->AIC_ICCR = (0x1 << irq_id);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_AcknowledgeIt

+//* \brief Acknowledge corresponding IT number

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_AcknowledgeIt (

+	AT91PS_AIC pAic)     // \arg pointer to the AIC registers

+{

+    pAic->AIC_EOICR = pAic->AIC_EOICR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_SetExceptionVector

+//* \brief Configure vector handler

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_SetExceptionVector (

+	unsigned int *pVector, // \arg pointer to the AIC registers

+	void (*Handler) () )   // \arg Interrupt Handler

+{

+	unsigned int oldVector = *pVector;

+

+	if ((unsigned int) Handler == (unsigned int) AT91C_AIC_BRANCH_OPCODE)

+		*pVector = (unsigned int) AT91C_AIC_BRANCH_OPCODE;

+	else

+		*pVector = (((((unsigned int) Handler) - ((unsigned int) pVector) - 0x8) >> 2) & 0x00FFFFFF) | 0xEA000000;

+

+	return oldVector;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Trig

+//* \brief Trig an IT

+//*----------------------------------------------------------------------------

+__inline void  AT91F_AIC_Trig (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg interrupt number

+{

+	pAic->AIC_ISCR = (0x1 << irq_id) ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsActive

+//* \brief Test if an IT is active

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsActive (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_ISR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_IsPending

+//* \brief Test if an IT is pending

+//*----------------------------------------------------------------------------

+__inline unsigned int  AT91F_AIC_IsPending (

+	AT91PS_AIC pAic,     // \arg pointer to the AIC registers

+	unsigned int irq_id) // \arg Interrupt Number

+{

+	return (pAic->AIC_IPR & (0x1 << irq_id));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_Open

+//* \brief Set exception vectors and AIC registers to default values

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_Open(

+	AT91PS_AIC pAic,        // \arg pointer to the AIC registers

+	void (*IrqHandler) (),  // \arg Default IRQ vector exception

+	void (*FiqHandler) (),  // \arg Default FIQ vector exception

+	void (*DefaultHandler)  (), // \arg Default Handler set in ISR

+	void (*SpuriousHandler) (), // \arg Default Spurious Handler

+	unsigned int protectMode)   // \arg Debug Control Register

+{

+	int i;

+

+	// Disable all interrupts and set IVR to the default handler

+	for (i = 0; i < 32; ++i) {

+		AT91F_AIC_DisableIt(pAic, i);

+		AT91F_AIC_ConfigureIt(pAic, i, AT91C_AIC_PRIOR_LOWEST, AT91C_AIC_SRCTYPE_HIGH_LEVEL, DefaultHandler);

+	}

+

+	// Set the IRQ exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x18, IrqHandler);

+	// Set the Fast Interrupt exception vector

+	AT91F_AIC_SetExceptionVector((unsigned int *) 0x1C, FiqHandler);

+

+	pAic->AIC_SPU = (unsigned int) SpuriousHandler;

+	pAic->AIC_DCR = protectMode;

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PDC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextRx

+//* \brief Set the next receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextRx (

+	AT91PS_PDC pPDC,     // \arg pointer to a PDC controller

+	char *address,       // \arg address to the next bloc to be received

+	unsigned int bytes)  // \arg number of bytes to be received

+{

+	pPDC->PDC_RNPR = (unsigned int) address;

+	pPDC->PDC_RNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetNextTx

+//* \brief Set the next transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetNextTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TNPR = (unsigned int) address;

+	pPDC->PDC_TNCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetRx

+//* \brief Set the receive transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetRx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be received

+	unsigned int bytes)    // \arg number of bytes to be received

+{

+	pPDC->PDC_RPR = (unsigned int) address;

+	pPDC->PDC_RCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SetTx

+//* \brief Set the transmit transfer descriptor

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_SetTx (

+	AT91PS_PDC pPDC,       // \arg pointer to a PDC controller

+	char *address,         // \arg address to the next bloc to be transmitted

+	unsigned int bytes)    // \arg number of bytes to be transmitted

+{

+	pPDC->PDC_TPR = (unsigned int) address;

+	pPDC->PDC_TCR = bytes;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableTx

+//* \brief Enable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_EnableRx

+//* \brief Enable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_EnableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableTx

+//* \brief Disable transmit

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableTx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_TXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_DisableRx

+//* \brief Disable receive

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_DisableRx (

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	pPDC->PDC_PTCR = AT91C_PDC_RXTDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsTxEmpty

+//* \brief Test if the current transfer descriptor has been sent

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextTxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextTxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_TNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsRxEmpty

+//* \brief Test if the current transfer descriptor has been filled

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_IsNextRxEmpty

+//* \brief Test if the next transfer descriptor has been moved to the current td

+//*----------------------------------------------------------------------------

+__inline int AT91F_PDC_IsNextRxEmpty ( // \return return 1 if transfer is complete

+	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller

+{

+	return !(pPDC->PDC_RNCR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Open

+//* \brief Open PDC: disable TX and RX reset transfer descriptors, re-enable RX and TX

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Open (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+    //* Enable the RX and TX PDC transfer requests

+	AT91F_PDC_EnableRx(pPDC);

+	AT91F_PDC_EnableTx(pPDC);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_Close

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline void AT91F_PDC_Close (

+	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller

+{

+    //* Disable the RX and TX PDC transfer requests

+	AT91F_PDC_DisableRx(pPDC);

+	AT91F_PDC_DisableTx(pPDC);

+

+	//* Reset all Counter register Next buffer first

+	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);

+	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_SendFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_SendFrame(

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsTxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetTx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextTx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextTxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextTx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PDC_ReceiveFrame

+//* \brief Close PDC: disable TX and RX reset transfer descriptors

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PDC_ReceiveFrame (

+	AT91PS_PDC pPDC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	if (AT91F_PDC_IsRxEmpty(pPDC)) {

+		//* Buffer and next buffer can be initialized

+		AT91F_PDC_SetRx(pPDC, pBuffer, szBuffer);

+		AT91F_PDC_SetNextRx(pPDC, pNextBuffer, szNextBuffer);

+		return 2;

+	}

+	else if (AT91F_PDC_IsNextRxEmpty(pPDC)) {

+		//* Only one buffer can be initialized

+		AT91F_PDC_SetNextRx(pPDC, pBuffer, szBuffer);

+		return 1;

+	}

+	else {

+		//* All buffer are in use...

+		return 0;

+	}

+}

+/* *****************************************************************************

+                SOFTWARE API FOR DBGU

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptEnable

+//* \brief Enable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptEnable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be enabled

+{

+        pDbgu->DBGU_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_InterruptDisable

+//* \brief Disable DBGU Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_InterruptDisable(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  dbgu interrupt to be disabled

+{

+        pDbgu->DBGU_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_GetInterruptMaskStatus

+//* \brief Return DBGU Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_DBGU_GetInterruptMaskStatus( // \return DBGU Interrupt Mask Status

+        AT91PS_DBGU pDbgu) // \arg  pointer to a DBGU controller

+{

+        return pDbgu->DBGU_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_IsInterruptMasked

+//* \brief Test if DBGU Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_DBGU_IsInterruptMasked(

+        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_DBGU_GetInterruptMaskStatus(pDbgu) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PIO

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPeriph

+//* \brief Enable pins to be drived by peripheral

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPeriph(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int periphAEnable,  // \arg PERIPH A to enable

+	unsigned int periphBEnable)  // \arg PERIPH B to enable

+

+{

+	pPio->PIO_ASR = periphAEnable;

+	pPio->PIO_BSR = periphBEnable;

+	pPio->PIO_PDR = (periphAEnable | periphBEnable); // Set in Periph mode

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOutput

+//* \brief Enable PIO in output mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOutput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pioEnable)      // \arg PIO to be enabled

+{

+	pPio->PIO_PER = pioEnable; // Set in PIO mode

+	pPio->PIO_OER = pioEnable; // Configure in Output

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInput

+//* \brief Enable PIO in input mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInput(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputEnable)      // \arg PIO to be enabled

+{

+	// Disable output

+	pPio->PIO_ODR  = inputEnable;

+	pPio->PIO_PER  = inputEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgOpendrain

+//* \brief Configure PIO in open drain

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgOpendrain(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int multiDrvEnable) // \arg pio to be configured in open drain

+{

+	// Configure the multi-drive option

+	pPio->PIO_MDDR = ~multiDrvEnable;

+	pPio->PIO_MDER = multiDrvEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgPullup

+//* \brief Enable pullup on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgPullup(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int pullupEnable)   // \arg enable pullup on PIO

+{

+		// Connect or not Pullup

+	pPio->PIO_PPUDR = ~pullupEnable;

+	pPio->PIO_PPUER = pullupEnable;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgDirectDrive

+//* \brief Enable direct drive on PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgDirectDrive(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int directDrive)    // \arg PIO to be configured with direct drive

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_OWDR  = ~directDrive;

+	pPio->PIO_OWER  = directDrive;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_CfgInputFilter

+//* \brief Enable input filter on input PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_CfgInputFilter(

+	AT91PS_PIO pPio,             // \arg pointer to a PIO controller

+	unsigned int inputFilter)    // \arg PIO to be configured with input filter

+

+{

+	// Configure the Direct Drive

+	pPio->PIO_IFDR  = ~inputFilter;

+	pPio->PIO_IFER  = inputFilter;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInput

+//* \brief Return PIO input value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInput( // \return PIO input

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+	return pPio->PIO_PDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputSet

+//* \brief Test if PIO is input flag is active

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputSet(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PIO_GetInput(pPio) & flag);

+}

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_SetOutput

+//* \brief Set to 1 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_SetOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be set

+{

+	pPio->PIO_SODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ClearOutput

+//* \brief Set to 0 output PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ClearOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be cleared

+{

+	pPio->PIO_CODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_ForceOutput

+//* \brief Force output when Direct drive option is enabled

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_ForceOutput(

+	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+	unsigned int flag) // \arg  output to be forced

+{

+	pPio->PIO_ODSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Enable

+//* \brief Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Enable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled

+{

+        pPio->PIO_PER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Disable

+//* \brief Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_Disable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled

+{

+        pPio->PIO_PDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetStatus

+//* \brief Return PIO Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetStatus( // \return PIO Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsSet

+//* \brief Test if PIO is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputEnable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be enabled

+{

+        pPio->PIO_OER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputDisable

+//* \brief Output Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output to be disabled

+{

+        pPio->PIO_ODR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputStatus

+//* \brief Return PIO Output Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputStatus( // \return PIO Output Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOuputSet

+//* \brief Test if PIO Output is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterEnable

+//* \brief Input Filter Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be enabled

+{

+        pPio->PIO_IFER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InputFilterDisable

+//* \brief Input Filter Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InputFilterDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio input filter to be disabled

+{

+        pPio->PIO_IFDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInputFilterStatus

+//* \brief Return PIO Input Filter Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInputFilterStatus( // \return PIO Input Filter Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IFSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInputFilterSet

+//* \brief Test if PIO Input filter is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInputFilterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInputFilterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputDataStatus

+//* \brief Return PIO Output Data Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputDataStatus( // \return PIO Output Data Status

+	AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ODSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptEnable

+//* \brief Enable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be enabled

+{

+        pPio->PIO_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_InterruptDisable

+//* \brief Disable PIO Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_InterruptDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio interrupt to be disabled

+{

+        pPio->PIO_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptMaskStatus

+//* \brief Return PIO Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptMaskStatus( // \return PIO Interrupt Mask Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetInterruptStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetInterruptStatus( // \return PIO Interrupt Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptMasked

+//* \brief Test if PIO Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptMasked(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptMaskStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsInterruptSet

+//* \brief Test if PIO Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsInterruptSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetInterruptStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverEnable

+//* \brief Multi Driver Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be enabled

+{

+        pPio->PIO_MDER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_MultiDriverDisable

+//* \brief Multi Driver Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_MultiDriverDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio to be disabled

+{

+        pPio->PIO_MDDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetMultiDriverStatus

+//* \brief Return PIO Multi Driver Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetMultiDriverStatus( // \return PIO Multi Driver Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_MDSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsMultiDriverSet

+//* \brief Test if PIO MultiDriver is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsMultiDriverSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetMultiDriverStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_A_RegisterSelection

+//* \brief PIO A Register Selection

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_A_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio A register selection

+{

+        pPio->PIO_ASR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_B_RegisterSelection

+//* \brief PIO B Register Selection

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_B_RegisterSelection(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio B register selection

+{

+        pPio->PIO_BSR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_Get_AB_RegisterStatus

+//* \brief Return PIO Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_Get_AB_RegisterStatus( // \return PIO AB Register Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_ABSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsAB_RegisterSet

+//* \brief Test if PIO AB Register is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsAB_RegisterSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_Get_AB_RegisterStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteEnable

+//* \brief Output Write Enable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteEnable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be enabled

+{

+        pPio->PIO_OWER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_OutputWriteDisable

+//* \brief Output Write Disable PIO

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIO_OutputWriteDisable(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  pio output write to be disabled

+{

+        pPio->PIO_OWDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetOutputWriteStatus

+//* \brief Return PIO Output Write Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetOutputWriteStatus( // \return PIO Output Write Status

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_OWSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputWriteSet

+//* \brief Test if PIO OutputWrite is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputWriteSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputWriteStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_GetCfgPullup

+//* \brief Return PIO Configuration Pullup

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PIO_GetCfgPullup( // \return PIO Configuration Pullup

+        AT91PS_PIO pPio) // \arg  pointer to a PIO controller

+{

+        return pPio->PIO_PPUSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsOutputDataStatusSet

+//* \brief Test if PIO Output Data Status is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsOutputDataStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_PIO_GetOutputDataStatus(pPio) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIO_IsCfgPullupStatusSet

+//* \brief Test if PIO Configuration Pullup Status is Set

+//*----------------------------------------------------------------------------

+__inline int AT91F_PIO_IsCfgPullupStatusSet(

+        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (~AT91F_PIO_GetCfgPullup(pPio) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkEnableReg

+//* \brief Configure the System Clock Enable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkEnableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCER register

+	pPMC->PMC_SCER = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgSysClkDisableReg

+//* \brief Configure the System Clock Disable Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgSysClkDisableReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	//* Write to the SCDR register

+	pPMC->PMC_SCDR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetSysClkStatusReg

+//* \brief Return the System Clock Status Register of the PMC controller

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetSysClkStatusReg (

+	AT91PS_PMC pPMC // pointer to a CAN controller

+	)

+{

+	return pPMC->PMC_SCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePeriphClock

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCER = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePeriphClock

+//* \brief Disable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePeriphClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int periphIds)  // \arg IDs of peripherals to enable

+{

+	pPMC->PMC_PCDR = periphIds;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetPeriphClock

+//* \brief Get peripheral clock status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetPeriphClock (

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_PCSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscillatorReg (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int mode)

+{

+	pCKGR->CKGR_MOR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainOscillatorReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainOscillatorReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MOR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_EnableMainOscillator

+//* \brief Enable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_EnableMainOscillator(

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR |= AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_DisableMainOscillator

+//* \brief Disable the main oscillator

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_DisableMainOscillator (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_MOSCEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_CfgMainOscStartUpTime

+//* \brief Cfg MOR Register according to the main osc startup time

+//*----------------------------------------------------------------------------

+__inline void AT91F_CKGR_CfgMainOscStartUpTime (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int startup_time,  // \arg main osc startup time in microsecond (us)

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	pCKGR->CKGR_MOR &= ~AT91C_CKGR_OSCOUNT;

+	pCKGR->CKGR_MOR |= ((slowClock * startup_time)/(8*1000000)) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClockFreqReg

+//* \brief Cfg the main oscillator

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClockFreqReg (

+	AT91PS_CKGR pCKGR) // \arg pointer to CKGR controller

+{

+	return pCKGR->CKGR_MCFR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CKGR_GetMainClock

+//* \brief Return Main clock in Hz

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CKGR_GetMainClock (

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	return ((pCKGR->CKGR_MCFR  & AT91C_CKGR_MAINF) * slowClock) >> 4;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgMCKReg

+//* \brief Cfg Master Clock Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgMCKReg (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int mode)

+{

+	pPMC->PMC_MCKR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMCKReg

+//* \brief Return Master Clock Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMCKReg(

+	AT91PS_PMC pPMC) // \arg pointer to PMC controller

+{

+	return pPMC->PMC_MCKR;

+}

+

+//*------------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetMasterClock

+//* \brief Return master clock in Hz which correponds to processor clock for ARM7

+//*------------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetMasterClock (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller

+	unsigned int slowClock)  // \arg slowClock in Hz

+{

+	unsigned int reg = pPMC->PMC_MCKR;

+	unsigned int prescaler = (1 << ((reg & AT91C_PMC_PRES) >> 2));

+	unsigned int pllDivider, pllMultiplier;

+

+	switch (reg & AT91C_PMC_CSS) {

+		case AT91C_PMC_CSS_SLOW_CLK: // Slow clock selected

+			return slowClock / prescaler;

+		case AT91C_PMC_CSS_MAIN_CLK: // Main clock is selected

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / prescaler;

+		case AT91C_PMC_CSS_PLL_CLK: // PLLB clock is selected

+			reg = pCKGR->CKGR_PLLR;

+			pllDivider    = (reg  & AT91C_CKGR_DIV);

+			pllMultiplier = ((reg  & AT91C_CKGR_MUL) >> 16) + 1;

+			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;

+	}

+	return 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck,  // \arg Peripheral clock identifier 0 .. 7

+	unsigned int mode)

+{

+	pPMC->PMC_PCKR[pck] = mode;

+	pPMC->PMC_SCER = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisablePCK

+//* \brief Enable peripheral clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisablePCK (

+	AT91PS_PMC pPMC, // \arg pointer to PMC controller

+	unsigned int pck)  // \arg Peripheral clock identifier 0 .. 7

+{

+	pPMC->PMC_SCDR = (1 << pck) << 8;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_EnableIt

+//* \brief Enable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_EnableIt (

+	AT91PS_PMC pPMC,     // pointer to a PMC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pPMC->PMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_DisableIt

+//* \brief Disable PMC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_DisableIt (

+	AT91PS_PMC pPMC, // pointer to a PMC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pPMC->PMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetStatus

+//* \brief Return PMC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetStatus( // \return PMC Interrupt Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_GetInterruptMaskStatus

+//* \brief Return PMC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_GetInterruptMaskStatus( // \return PMC Interrupt Mask Status

+	AT91PS_PMC pPMC) // pointer to a PMC controller

+{

+	return pPMC->PMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsInterruptMasked

+//* \brief Test if PMC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsInterruptMasked(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetInterruptMaskStatus(pPMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_IsStatusSet

+//* \brief Test if PMC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PMC_IsStatusSet(

+        AT91PS_PMC pPMC,   // \arg  pointer to a PMC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PMC_GetStatus(pPMC) & flag);

+}/* *****************************************************************************

+                SOFTWARE API FOR RSTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSoftReset

+//* \brief Start Software Reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSoftReset(

+        AT91PS_RSTC pRSTC,

+        unsigned int reset)

+{

+	pRSTC->RSTC_RCR = (0xA5000000 | reset);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTSetMode

+//* \brief Set Reset Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTSetMode(

+        AT91PS_RSTC pRSTC,

+        unsigned int mode)

+{

+	pRSTC->RSTC_RMR = (0xA5000000 | mode);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetMode

+//* \brief Get Reset Mode

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetMode(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTGetStatus

+//* \brief Get Reset Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTGetStatus(

+        AT91PS_RSTC pRSTC)

+{

+	return (pRSTC->RSTC_RSR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTIsSoftRstActive

+//* \brief Return !=0 if software reset is still not completed

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_RSTIsSoftRstActive(

+        AT91PS_RSTC pRSTC)

+{

+	return ((pRSTC->RSTC_RSR) & AT91C_RSTC_SRCMP);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR RTTC

+   ***************************************************************************** */

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_SetRTT_TimeBase()

+//* \brief  Set the RTT prescaler according to the TimeBase in ms

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetTimeBase(

+        AT91PS_RTTC pRTTC,

+        unsigned int ms)

+{

+	if (ms > 2000)

+		return 1;   // AT91C_TIME_OUT_OF_RANGE

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (((ms << 15) /1000) & 0xFFFF);	

+	return 0;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTSetPrescaler()

+//* \brief  Set the new prescaler value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTSetPrescaler(

+        AT91PS_RTTC pRTTC,

+        unsigned int rtpres)

+{

+	pRTTC->RTTC_RTMR &= ~0xFFFF;	

+	pRTTC->RTTC_RTMR |= (rtpres & 0xFFFF);	

+	return (pRTTC->RTTC_RTMR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTRestart()

+//* \brief  Restart the RTT prescaler

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTRestart(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTRST;	

+}

+

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmINT()

+//* \brief  Enable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearAlarmINT()

+//* \brief  Disable RTT Alarm Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearAlarmINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_ALMIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetRttIncINT()

+//* \brief  Enable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR |= AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ClearRttIncINT()

+//* \brief  Disable RTT INC Interrupt

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTClearRttIncINT(

+        AT91PS_RTTC pRTTC)

+{

+	pRTTC->RTTC_RTMR &= ~AT91C_RTTC_RTTINCIEN;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_SetAlarmValue()

+//* \brief  Set RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline void AT91F_RTTSetAlarmValue(

+        AT91PS_RTTC pRTTC, unsigned int alarm)

+{

+	pRTTC->RTTC_RTAR = alarm;

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_GetAlarmValue()

+//* \brief  Get RTT Alarm Value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetAlarmValue(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTAR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTTGetStatus()

+//* \brief  Read the RTT status

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTGetStatus(

+        AT91PS_RTTC pRTTC)

+{

+	return(pRTTC->RTTC_RTSR);

+}

+

+//*--------------------------------------------------------------------------------------

+//* \fn     AT91F_RTT_ReadValue()

+//* \brief  Read the RTT value

+//*--------------------------------------------------------------------------------------

+__inline unsigned int AT91F_RTTReadValue(

+        AT91PS_RTTC pRTTC)

+{

+        register volatile unsigned int val1,val2;

+	do

+	{

+		val1 = pRTTC->RTTC_RTVR;

+		val2 = pRTTC->RTTC_RTVR;

+	}	

+	while(val1 != val2);

+	return(val1);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR PITC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITInit

+//* \brief System timer init : period in µsecond, system clock freq in MHz

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITInit(

+        AT91PS_PITC pPITC,

+        unsigned int period,

+        unsigned int pit_frequency)

+{

+	pPITC->PITC_PIMR = period? (period * pit_frequency + 8) >> 4 : 0; // +8 to avoid %10 and /10

+	pPITC->PITC_PIMR |= AT91C_PITC_PITEN;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITSetPIV

+//* \brief Set the PIT Periodic Interval Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITSetPIV(

+        AT91PS_PITC pPITC,

+        unsigned int piv)

+{

+	pPITC->PITC_PIMR = piv | (pPITC->PITC_PIMR & (AT91C_PITC_PITEN | AT91C_PITC_PITIEN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITEnableInt

+//* \brief Enable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITEnableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR |= AT91C_PITC_PITIEN;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITDisableInt

+//* \brief Disable PIT periodic interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITDisableInt(

+        AT91PS_PITC pPITC)

+{

+	pPITC->PITC_PIMR &= ~AT91C_PITC_PITIEN;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetMode

+//* \brief Read PIT mode register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetMode(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIMR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetStatus

+//* \brief Read PIT status register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetStatus(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PISR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIIR

+//* \brief Read PIT CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIIR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIIR);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITGetPIVR

+//* \brief Read System timer CPIV and PICNT without ressetting the counters

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PITGetPIVR(

+        AT91PS_PITC pPITC)

+{

+	return(pPITC->PITC_PIVR);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR WDTC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSetMode

+//* \brief Set Watchdog Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTSetMode(

+        AT91PS_WDTC pWDTC,

+        unsigned int Mode)

+{

+	pWDTC->WDTC_WDMR = Mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTRestart

+//* \brief Restart Watchdog

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTRestart(

+        AT91PS_WDTC pWDTC)

+{

+	pWDTC->WDTC_WDCR = 0xA5000001;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTSGettatus

+//* \brief Get Watchdog Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTSGettatus(

+        AT91PS_WDTC pWDTC)

+{

+	return(pWDTC->WDTC_WDSR & 0x3);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTGetPeriod

+//* \brief Translate ms into Watchdog Compatible value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_WDTGetPeriod(unsigned int ms)

+{

+	if ((ms < 4) || (ms > 16000))

+		return 0;

+	return((ms << 8) / 1000);

+}

+/* *****************************************************************************

+                SOFTWARE API FOR VREG

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Enable_LowPowerMode

+//* \brief Enable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Enable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR |= AT91C_VREG_PSTDBY;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_Disable_LowPowerMode

+//* \brief Disable VREG Low Power Mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_Disable_LowPowerMode(

+        AT91PS_VREG pVREG)

+{

+	pVREG->VREG_MR &= ~AT91C_VREG_PSTDBY;	

+}/* *****************************************************************************

+                SOFTWARE API FOR MC

+   ***************************************************************************** */

+

+#define AT91C_MC_CORRECT_KEY  ((unsigned int) 0x5A << 24) // (MC) Correct Protect Key

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_Remap

+//* \brief Make Remap

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_Remap (void)     //

+{

+    AT91PS_MC pMC = (AT91PS_MC) AT91C_BASE_MC;

+

+    pMC->MC_RCR = AT91C_MC_RCB;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_CfgModeReg

+//* \brief Configure the EFC Mode Register of the MC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_CfgModeReg (

+	AT91PS_MC pMC, // pointer to a MC controller

+	unsigned int mode)        // mode register

+{

+	// Write to the FMR register

+	pMC->MC_FMR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetModeReg

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetModeReg(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_ComputeFMCN

+//* \brief Return MC EFC Mode Regsiter

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_ComputeFMCN(

+	int master_clock) // master clock in Hz

+{

+	return (master_clock/1000000 +2);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_PerformCmd

+//* \brief Perform EFC Command

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_EFC_PerformCmd (

+	AT91PS_MC pMC, // pointer to a MC controller

+    unsigned int transfer_cmd)

+{

+	pMC->MC_FCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_GetStatus

+//* \brief Return MC EFC Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_GetStatus(

+	AT91PS_MC pMC) // pointer to a MC controller

+{

+	return pMC->MC_FSR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptMasked

+//* \brief Test if EFC MC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptMasked(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetModeReg(pMC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_EFC_IsInterruptSet

+//* \brief Test if EFC MC Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_MC_EFC_IsInterruptSet(

+        AT91PS_MC pMC,   // \arg  pointer to a MC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_MC_EFC_GetStatus(pMC) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SPI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Open

+//* \brief Open a SPI Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgCs

+//* \brief Configure SPI chip select register

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgCs (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	int cs,     // SPI cs number (0 to 3)

+ 	int val)   //  chip select register

+{

+	//* Write to the CSR register

+	*(pSPI->SPI_CSR + cs) = val;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_EnableIt

+//* \brief Enable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_EnableIt (

+	AT91PS_SPI pSPI,     // pointer to a SPI controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pSPI->SPI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_DisableIt

+//* \brief Disable SPI interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_DisableIt (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pSPI->SPI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Reset

+//* \brief Reset the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Reset (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SWRST;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Enable

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Enable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Disable

+//* \brief Disable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Disable (

+	AT91PS_SPI pSPI // pointer to a SPI controller

+	)

+{

+	//* Write to the CR register

+	pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgMode

+//* \brief Enable the SPI controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgMode (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	int mode)        // mode register

+{

+	//* Write to the MR register

+	pSPI->SPI_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_CfgPCS

+//* \brief Switch to the correct PCS of SPI Mode Register : Fixed Peripheral Selected

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_CfgPCS (

+	AT91PS_SPI pSPI, // pointer to a SPI controller

+	char PCS_Device) // PCS of the Device

+{	

+ 	//* Write to the MR register

+	pSPI->SPI_MR &= 0xFFF0FFFF;

+	pSPI->SPI_MR |= ( (PCS_Device<<16) & AT91C_SPI_PCS );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_ReceiveFrame (

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is bSPIy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_SendFrame(

+	AT91PS_SPI pSPI,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSPI->SPI_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_Close

+//* \brief Close SPI: disable IT disable transfert, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_Close (

+	AT91PS_SPI pSPI)     // \arg pointer to a SPI controller

+{

+    //* Reset all the Chip Select register

+    pSPI->SPI_CSR[0] = 0 ;

+    pSPI->SPI_CSR[1] = 0 ;

+    pSPI->SPI_CSR[2] = 0 ;

+    pSPI->SPI_CSR[3] = 0 ;

+

+    //* Reset the SPI mode

+    pSPI->SPI_MR = 0  ;

+

+    //* Disable all interrupts

+    pSPI->SPI_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pSPI->SPI_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pSPI->SPI_CR = AT91C_SPI_SPIDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI_PutChar (

+	AT91PS_SPI pSPI,

+	unsigned int character,

+             unsigned int cs_number )

+{

+    unsigned int value_for_cs;

+    value_for_cs = (~(1 << cs_number)) & 0xF;  //Place a zero among a 4 ONEs number

+    pSPI->SPI_TDR = (character & 0xFFFF) | (value_for_cs << 16);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_GetChar (

+	const AT91PS_SPI pSPI)

+{

+    return((pSPI->SPI_RDR) & 0xFFFF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_GetInterruptMaskStatus

+//* \brief Return SPI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SPI_GetInterruptMaskStatus( // \return SPI Interrupt Mask Status

+        AT91PS_SPI pSpi) // \arg  pointer to a SPI controller

+{

+        return pSpi->SPI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI_IsInterruptMasked

+//* \brief Test if SPI Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_SPI_IsInterruptMasked(

+        AT91PS_SPI pSpi,   // \arg  pointer to a SPI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SPI_GetInterruptMaskStatus(pSpi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR USART

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Calculate the baudrate

+//* Standard Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_MODE ( AT91C_US_USMODE_NORMAL + \

+                        AT91C_US_NBSTOP_1_BIT + \

+                        AT91C_US_PAR_NONE + \

+                        AT91C_US_CHRL_8_BITS + \

+                        AT91C_US_CLKS_CLOCK )

+

+//* Standard External Asynchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_ASYNC_SCK_MODE ( AT91C_US_USMODE_NORMAL + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_EXT )

+

+//* Standard Synchronous Mode : 8 bits , 1 stop , no parity

+#define AT91C_US_SYNC_MODE ( AT91C_US_SYNC + \

+                       AT91C_US_USMODE_NORMAL + \

+                       AT91C_US_NBSTOP_1_BIT + \

+                       AT91C_US_PAR_NONE + \

+                       AT91C_US_CHRL_8_BITS + \

+                       AT91C_US_CLKS_CLOCK )

+

+//* SCK used Label

+#define AT91C_US_SCK_USED (AT91C_US_CKLO | AT91C_US_CLKS_EXT)

+

+//* Standard ISO T=0 Mode : 8 bits , 1 stop , parity

+#define AT91C_US_ISO_READER_MODE ( AT91C_US_USMODE_ISO7816_0 + \

+					   		 AT91C_US_CLKS_CLOCK +\

+                       		 AT91C_US_NBSTOP_1_BIT + \

+                       		 AT91C_US_PAR_EVEN + \

+                       		 AT91C_US_CHRL_8_BITS + \

+                       		 AT91C_US_CKLO +\

+                       		 AT91C_US_OVER)

+

+//* Standard IRDA mode

+#define AT91C_US_ASYNC_IRDA_MODE (  AT91C_US_USMODE_IRDA + \

+                            AT91C_US_NBSTOP_1_BIT + \

+                            AT91C_US_PAR_NONE + \

+                            AT91C_US_CHRL_8_BITS + \

+                            AT91C_US_CLKS_CLOCK )

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Baudrate

+//* \brief Caluculate baud_value according to the main clock and the baud rate

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Baudrate (

+	const unsigned int main_clock, // \arg peripheral clock

+	const unsigned int baud_rate)  // \arg UART baudrate

+{

+	unsigned int baud_value = ((main_clock*10)/(baud_rate * 16));

+	if ((baud_value % 10) >= 5)

+		baud_value = (baud_value / 10) + 1;

+	else

+		baud_value /= 10;

+	return baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetBaudrate (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int mainClock, // \arg peripheral clock

+	unsigned int speed)     // \arg UART baudrate

+{

+	//* Define the baud rate divisor register

+	pUSART->US_BRGR = AT91F_US_Baudrate(mainClock, speed);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetTimeguard

+//* \brief Set USART timeguard

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetTimeguard (

+	AT91PS_USART pUSART,    // \arg pointer to a USART controller

+	unsigned int timeguard) // \arg timeguard value

+{

+	//* Write the Timeguard Register

+	pUSART->US_TTGR = timeguard ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableIt

+//* \brief Enable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUSART->US_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableIt

+//* \brief Disable USART IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableIt (

+	AT91PS_USART pUSART, // \arg pointer to a USART controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IER register

+	pUSART->US_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Configure

+//* \brief Configure USART

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Configure (

+	AT91PS_USART pUSART,     // \arg pointer to a USART controller

+	unsigned int mainClock,  // \arg peripheral clock

+	unsigned int mode ,      // \arg mode Register to be programmed

+	unsigned int baudRate ,  // \arg baudrate to be programmed

+	unsigned int timeguard ) // \arg timeguard to be programmed

+{

+    //* Disable interrupts

+    pUSART->US_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+    pUSART->US_CR = AT91C_US_RSTRX | AT91C_US_RSTTX | AT91C_US_RXDIS | AT91C_US_TXDIS ;

+

+	//* Define the baud rate divisor register

+	AT91F_US_SetBaudrate(pUSART, mainClock, baudRate);

+

+	//* Write the Timeguard Register

+	AT91F_US_SetTimeguard(pUSART, timeguard);

+

+    //* Clear Transmit and Receive Counters

+    AT91F_PDC_Open((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Define the USART mode

+    pUSART->US_MR = mode  ;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableRx

+//* \brief Enable receiving characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_EnableTx

+//* \brief Enable sending characters

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_EnableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Enable  transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetRx

+//* \brief Reset Receiver and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset receiver

+	pUSART->US_CR = AT91C_US_RSTRX;

+    //* Re-Enable receiver

+    pUSART->US_CR = AT91C_US_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ResetTx

+//* \brief Reset Transmitter and re-enable it

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_ResetTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+	//* Reset transmitter

+	pUSART->US_CR = AT91C_US_RSTTX;

+    //* Enable transmitter

+    pUSART->US_CR = AT91C_US_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableRx

+//* \brief Disable Receiver

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableRx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable receiver

+    pUSART->US_CR = AT91C_US_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_DisableTx

+//* \brief Disable Transmitter

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_DisableTx (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Disable transmitter

+    pUSART->US_CR = AT91C_US_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Close

+//* \brief Close USART: disable IT disable receiver and transmitter, close PDC

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_Close (

+	AT91PS_USART pUSART)     // \arg pointer to a USART controller

+{

+    //* Reset the baud rate divisor register

+    pUSART->US_BRGR = 0 ;

+

+    //* Reset the USART mode

+    pUSART->US_MR = 0  ;

+

+    //* Reset the Timeguard Register

+    pUSART->US_TTGR = 0;

+

+    //* Disable all interrupts

+    pUSART->US_IDR = 0xFFFFFFFF ;

+

+    //* Abort the Peripheral Data Transfers

+    AT91F_PDC_Close((AT91PS_PDC) &(pUSART->US_RPR));

+

+    //* Disable receiver and transmitter and stop any activity immediately

+    pUSART->US_CR = AT91C_US_TXDIS | AT91C_US_RXDIS | AT91C_US_RSTTX | AT91C_US_RSTRX ;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_TxReady

+//* \brief Return 1 if a character can be written in US_THR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_TxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_TXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_RxReady

+//* \brief Return 1 if a character can be read in US_RHR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_RxReady (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR & AT91C_US_RXRDY);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_Error

+//* \brief Return the error flag

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_Error (

+	AT91PS_USART pUSART )     // \arg pointer to a USART controller

+{

+    return (pUSART->US_CSR &

+    	(AT91C_US_OVRE |  // Overrun error

+    	 AT91C_US_FRAME | // Framing error

+    	 AT91C_US_PARE));  // Parity error

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_PutChar

+//* \brief Send a character,does not check if ready to send

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_PutChar (

+	AT91PS_USART pUSART,

+	int character )

+{

+    pUSART->US_THR = (character & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_GetChar

+//* \brief Receive a character,does not check if a character is available

+//*----------------------------------------------------------------------------

+__inline int AT91F_US_GetChar (

+	const AT91PS_USART pUSART)

+{

+    return((pUSART->US_RHR) & 0x1FF);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_SendFrame(

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_US_ReceiveFrame (

+	AT91PS_USART pUSART,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pUSART->US_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US_SetIrdaFilter

+//* \brief Set the value of IrDa filter tregister

+//*----------------------------------------------------------------------------

+__inline void AT91F_US_SetIrdaFilter (

+	AT91PS_USART pUSART,

+	unsigned char value

+)

+{

+	pUSART->US_IF = value;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR SSC

+   ***************************************************************************** */

+//* Define the standard I2S mode configuration

+

+//* Configuration to set in the SSC Transmit Clock Mode Register

+//* Parameters :  nb_bit_by_slot : 8, 16 or 32 bits

+//* 			  nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_MASTER_TX_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									   AT91C_SSC_CKS_DIV   +\

+                            		   AT91C_SSC_CKO_CONTINOUS      +\

+                            		   AT91C_SSC_CKG_NONE    +\

+                                       AT91C_SSC_START_FALL_RF +\

+                           			   AT91C_SSC_STTOUT  +\

+                            		   ((1<<16) & AT91C_SSC_STTDLY) +\

+                            		   ((((nb_bit_by_slot*nb_slot_by_frame)/2)-1) <<24))

+

+

+//* Configuration to set in the SSC Transmit Frame Mode Register

+//* Parameters : nb_bit_by_slot : 8, 16 or 32 bits

+//* 			 nb_slot_by_frame : number of channels

+#define AT91C_I2S_ASY_TX_FRAME_SETTING(nb_bit_by_slot, nb_slot_by_frame)( +\

+									(nb_bit_by_slot-1)  +\

+                            		AT91C_SSC_MSBF   +\

+                            		(((nb_slot_by_frame-1)<<8) & AT91C_SSC_DATNB)  +\

+                            		(((nb_bit_by_slot-1)<<16) & AT91C_SSC_FSLEN) +\

+                            		AT91C_SSC_FSOS_NEGATIVE)

+

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SetBaudrate

+//* \brief Set the baudrate according to the CPU clock

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_SetBaudrate (

+        AT91PS_SSC pSSC,        // \arg pointer to a SSC controller

+        unsigned int mainClock, // \arg peripheral clock

+        unsigned int speed)     // \arg SSC baudrate

+{

+        unsigned int baud_value;

+        //* Define the baud rate divisor register

+        if (speed == 0)

+           baud_value = 0;

+        else

+        {

+           baud_value = (unsigned int) (mainClock * 10)/(2*speed);

+           if ((baud_value % 10) >= 5)

+                  baud_value = (baud_value / 10) + 1;

+           else

+                  baud_value /= 10;

+        }

+

+        pSSC->SSC_CMR = baud_value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_Configure

+//* \brief Configure SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_Configure (

+             AT91PS_SSC pSSC,          // \arg pointer to a SSC controller

+             unsigned int syst_clock,  // \arg System Clock Frequency

+             unsigned int baud_rate,   // \arg Expected Baud Rate Frequency

+             unsigned int clock_rx,    // \arg Receiver Clock Parameters

+             unsigned int mode_rx,     // \arg mode Register to be programmed

+             unsigned int clock_tx,    // \arg Transmitter Clock Parameters

+             unsigned int mode_tx)     // \arg mode Register to be programmed

+{

+    //* Disable interrupts

+	pSSC->SSC_IDR = (unsigned int) -1;

+

+    //* Reset receiver and transmitter

+	pSSC->SSC_CR = AT91C_SSC_SWRST | AT91C_SSC_RXDIS | AT91C_SSC_TXDIS ;

+

+    //* Define the Clock Mode Register

+	AT91F_SSC_SetBaudrate(pSSC, syst_clock, baud_rate);

+

+     //* Write the Receive Clock Mode Register

+	pSSC->SSC_RCMR =  clock_rx;

+

+     //* Write the Transmit Clock Mode Register

+	pSSC->SSC_TCMR =  clock_tx;

+

+     //* Write the Receive Frame Mode Register

+	pSSC->SSC_RFMR =  mode_rx;

+

+     //* Write the Transmit Frame Mode Register

+	pSSC->SSC_TFMR =  mode_tx;

+

+    //* Clear Transmit and Receive Counters

+	AT91F_PDC_Open((AT91PS_PDC) &(pSSC->SSC_RPR));

+

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableRx

+//* \brief Enable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableRx

+//* \brief Disable receiving datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableRx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable receiver

+    pSSC->SSC_CR = AT91C_SSC_RXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableTx

+//* \brief Enable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Enable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableTx

+//* \brief Disable sending datas

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableTx (

+	AT91PS_SSC pSSC)     // \arg pointer to a SSC controller

+{

+    //* Disable  transmitter

+    pSSC->SSC_CR = AT91C_SSC_TXDIS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_EnableIt

+//* \brief Enable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_EnableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pSSC->SSC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_DisableIt

+//* \brief Disable SSC IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_DisableIt (

+	AT91PS_SSC pSSC, // \arg pointer to a SSC controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pSSC->SSC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_ReceiveFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_ReceiveFrame (

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_ReceiveFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_SendFrame

+//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initialized with Next Buffer, 0 if PDC is busy

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_SendFrame(

+	AT91PS_SSC pSSC,

+	char *pBuffer,

+	unsigned int szBuffer,

+	char *pNextBuffer,

+	unsigned int szNextBuffer )

+{

+	return AT91F_PDC_SendFrame(

+		(AT91PS_PDC) &(pSSC->SSC_RPR),

+		pBuffer,

+		szBuffer,

+		pNextBuffer,

+		szNextBuffer);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_GetInterruptMaskStatus

+//* \brief Return SSC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_SSC_GetInterruptMaskStatus( // \return SSC Interrupt Mask Status

+        AT91PS_SSC pSsc) // \arg  pointer to a SSC controller

+{

+        return pSsc->SSC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_IsInterruptMasked

+//* \brief Test if SSC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_SSC_IsInterruptMasked(

+        AT91PS_SSC pSsc,   // \arg  pointer to a SSC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_SSC_GetInterruptMaskStatus(pSsc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TWI

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_EnableIt

+//* \brief Enable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_EnableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pTWI->TWI_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_DisableIt

+//* \brief Disable TWI IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_DisableIt (

+	AT91PS_TWI pTWI, // \arg pointer to a TWI controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pTWI->TWI_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_Configure

+//* \brief Configure TWI in master mode

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_Configure ( AT91PS_TWI pTWI )          // \arg pointer to a TWI controller

+{

+    //* Disable interrupts

+	pTWI->TWI_IDR = (unsigned int) -1;

+

+    //* Reset peripheral

+	pTWI->TWI_CR = AT91C_TWI_SWRST;

+

+	//* Set Master mode

+	pTWI->TWI_CR = AT91C_TWI_MSEN;

+

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_GetInterruptMaskStatus

+//* \brief Return TWI Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TWI_GetInterruptMaskStatus( // \return TWI Interrupt Mask Status

+        AT91PS_TWI pTwi) // \arg  pointer to a TWI controller

+{

+        return pTwi->TWI_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_IsInterruptMasked

+//* \brief Test if TWI Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_TWI_IsInterruptMasked(

+        AT91PS_TWI pTwi,   // \arg  pointer to a TWI controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TWI_GetInterruptMaskStatus(pTwi) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR PWMC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetStatus

+//* \brief Return PWM Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetStatus( // \return PWM Interrupt Status

+	AT91PS_PWMC pPWM) // pointer to a PWM controller

+{

+	return pPWM->PWMC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptEnable

+//* \brief Enable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptEnable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be enabled

+{

+        pPwm->PWMC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_InterruptDisable

+//* \brief Disable PWM Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_InterruptDisable(

+        AT91PS_PWMC pPwm,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  PWM interrupt to be disabled

+{

+        pPwm->PWMC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_GetInterruptMaskStatus

+//* \brief Return PWM Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_GetInterruptMaskStatus( // \return PWM Interrupt Mask Status

+        AT91PS_PWMC pPwm) // \arg  pointer to a PWM controller

+{

+        return pPwm->PWMC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsInterruptMasked

+//* \brief Test if PWM Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsInterruptMasked(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetInterruptMaskStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_IsStatusSet

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_PWMC_IsStatusSet(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_PWMC_GetStatus(pPWM) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_CfgChannel

+//* \brief Test if PWM Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int mode, // \arg  PWM mode

+        unsigned int period, // \arg PWM period

+        unsigned int duty) // \arg PWM duty cycle

+{

+	pPWM->PWMC_CH[channelId].PWMC_CMR = mode;

+	pPWM->PWMC_CH[channelId].PWMC_CDTYR = duty;

+	pPWM->PWMC_CH[channelId].PWMC_CPRDR = period;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StartChannel

+//* \brief Enable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StartChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_ENA = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_StopChannel

+//* \brief Disable channel

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_StopChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int flag) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_DIS = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWM_UpdateChannel

+//* \brief Update Period or Duty Cycle

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_UpdateChannel(

+        AT91PS_PWMC pPWM,   // \arg  pointer to a PWM controller

+        unsigned int channelId, // \arg PWM channel ID

+        unsigned int update) // \arg  Channels IDs to be enabled

+{

+	pPWM->PWMC_CH[channelId].PWMC_CUPDR = update;

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR UDP

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableIt

+//* \brief Enable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be enabled

+{

+	//* Write to the IER register

+	pUDP->UDP_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableIt

+//* \brief Disable UDP IT

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableIt (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg IT to be disabled

+{

+	//* Write to the IDR register

+	pUDP->UDP_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetAddress

+//* \brief Set UDP functional address

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetAddress (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char address)   // \arg new UDP address

+{

+	pUDP->UDP_FADDR = (AT91C_UDP_FEN | address);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EnableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EnableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_DisableEp

+//* \brief Enable Endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_DisableEp (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] &= ~AT91C_UDP_EPEDS;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_SetState

+//* \brief Set UDP Device state

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_SetState (

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg new UDP address

+{

+	pUDP->UDP_GLBSTATE  &= ~(AT91C_UDP_FADDEN | AT91C_UDP_CONFG);

+	pUDP->UDP_GLBSTATE  |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetState

+//* \brief return UDP Device state

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetState ( // \return the UDP device state

+	AT91PS_UDP pUDP)     // \arg pointer to a UDP controller

+{

+	return (pUDP->UDP_GLBSTATE  & (AT91C_UDP_FADDEN | AT91C_UDP_CONFG));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_ResetEp

+//* \brief Reset UDP endpoint

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_ResetEp ( // \return the UDP device state

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned int flag)   // \arg Endpoints to be reset

+{

+	pUDP->UDP_RSTEP = flag;

+	pUDP->UDP_RSTEP = 0;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStall

+//* \brief Endpoint will STALL requests

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpStall(

+	AT91PS_UDP pUDP,     // \arg pointer to a UDP controller

+	unsigned char endpoint)   // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_FORCESTALL;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpWrite

+//* \brief Write value in the DPR

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpWrite(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned char value)     // \arg value to be written in the DPR

+{

+	pUDP->UDP_FDR[endpoint] = value;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpRead

+//* \brief Return value from the DPR

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpRead(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_FDR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpEndOfWr

+//* \brief Notify the UDP that values in DPR are ready to be sent

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpEndOfWr(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	pUDP->UDP_CSR[endpoint] |= AT91C_UDP_TXPKTRDY;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpClear

+//* \brief Clear flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpClear(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] &= ~(flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpSet

+//* \brief Set flag in the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_EpSet(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint,  // \arg endpoint number

+	unsigned int flag)       // \arg flag to be cleared

+{

+	pUDP->UDP_CSR[endpoint] |= flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_EpStatus

+//* \brief Return the endpoint CSR register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_EpStatus(

+	AT91PS_UDP pUDP,         // \arg pointer to a UDP controller

+	unsigned char endpoint)  // \arg endpoint number

+{

+	return pUDP->UDP_CSR[endpoint];

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_GetInterruptMaskStatus

+//* \brief Return UDP Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_UDP_GetInterruptMaskStatus( // \return UDP Interrupt Mask Status

+        AT91PS_UDP pUdp) // \arg  pointer to a UDP controller

+{

+        return pUdp->UDP_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_IsInterruptMasked

+//* \brief Test if UDP Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_UDP_IsInterruptMasked(

+        AT91PS_UDP pUdp,   // \arg  pointer to a UDP controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_UDP_GetInterruptMaskStatus(pUdp) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptEnable

+//* \brief Enable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptEnable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be enabled

+{

+        pTc->TC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_InterruptDisable

+//* \brief Disable TC Interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC_InterruptDisable(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  TC interrupt to be disabled

+{

+        pTc->TC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_GetInterruptMaskStatus

+//* \brief Return TC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TC_GetInterruptMaskStatus( // \return TC Interrupt Mask Status

+        AT91PS_TC pTc) // \arg  pointer to a TC controller

+{

+        return pTc->TC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC_IsInterruptMasked

+//* \brief Test if TC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline int AT91F_TC_IsInterruptMasked(

+        AT91PS_TC pTc,   // \arg  pointer to a TC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+        return (AT91F_TC_GetInterruptMaskStatus(pTc) & flag);

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR CAN

+   ***************************************************************************** */

+#define	STANDARD_FORMAT 0

+#define	EXTENDED_FORMAT 1

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_InitMailboxRegisters()

+//* \brief Configure the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_InitMailboxRegisters(AT91PS_CAN_MB	CAN_Mailbox,

+								int  			mode_reg,

+								int 			acceptance_mask_reg,

+								int  			id_reg,

+								int  			data_low_reg,

+								int  			data_high_reg,

+								int  			control_reg)

+{

+	CAN_Mailbox->CAN_MB_MCR 	= 0x0;

+	CAN_Mailbox->CAN_MB_MMR 	= mode_reg;

+	CAN_Mailbox->CAN_MB_MAM 	= acceptance_mask_reg;

+	CAN_Mailbox->CAN_MB_MID 	= id_reg;

+	CAN_Mailbox->CAN_MB_MDL 	= data_low_reg; 		

+	CAN_Mailbox->CAN_MB_MDH 	= data_high_reg;

+	CAN_Mailbox->CAN_MB_MCR 	= control_reg;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EnableCAN()

+//* \brief

+//*----------------------------------------------------------------------------

+__inline void AT91F_EnableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR |= AT91C_CAN_CANEN;

+

+	// Wait for WAKEUP flag raising <=> 11-recessive-bit were scanned by the transceiver

+	while( (pCAN->CAN_SR & AT91C_CAN_WAKEUP) != AT91C_CAN_WAKEUP );

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DisableCAN()

+//* \brief

+//*----------------------------------------------------------------------------

+__inline void AT91F_DisableCAN(

+	AT91PS_CAN pCAN)     // pointer to a CAN controller

+{

+	pCAN->CAN_MR &= ~AT91C_CAN_CANEN;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_EnableIt

+//* \brief Enable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_EnableIt (

+	AT91PS_CAN pCAN,     // pointer to a CAN controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pCAN->CAN_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_DisableIt

+//* \brief Disable CAN interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_DisableIt (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pCAN->CAN_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetStatus

+//* \brief Return CAN Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetStatus( // \return CAN Interrupt Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInterruptMaskStatus

+//* \brief Return CAN Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInterruptMaskStatus( // \return CAN Interrupt Mask Status

+	AT91PS_CAN pCAN) // pointer to a CAN controller

+{

+	return pCAN->CAN_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsInterruptMasked

+//* \brief Test if CAN Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsInterruptMasked(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetInterruptMaskStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_IsStatusSet

+//* \brief Test if CAN Interrupt is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_IsStatusSet(

+        AT91PS_CAN pCAN,   // \arg  pointer to a CAN controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_CAN_GetStatus(pCAN) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgModeReg

+//* \brief Configure the Mode Register of the CAN controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgModeReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int mode)        // mode register

+{

+	//* Write to the MR register

+	pCAN->CAN_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetModeReg

+//* \brief Return the Mode Register of the CAN controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetModeReg (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgBaudrateReg

+//* \brief Configure the Baudrate of the CAN controller for the network

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgBaudrateReg (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+	unsigned int baudrate_cfg)

+{

+	//* Write to the BR register

+	pCAN->CAN_BR = baudrate_cfg;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetBaudrate

+//* \brief Return the Baudrate of the CAN controller for the network value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetBaudrate (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_BR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetInternalCounter

+//* \brief Return CAN Timer Regsiter Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetInternalCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIM;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetTimestamp

+//* \brief Return CAN Timestamp Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetTimestamp (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_TIMESTP;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetErrorCounter

+//* \brief Return CAN Error Counter Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetErrorCounter (

+	AT91PS_CAN pCAN // pointer to a CAN controller

+	)

+{

+	return pCAN->CAN_ECR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitTransferRequest

+//* \brief Request for a transfer on the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitTransferRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int transfer_cmd)

+{

+	pCAN->CAN_TCR = transfer_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_InitAbortRequest

+//* \brief Abort the corresponding mailboxes

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_InitAbortRequest (

+	AT91PS_CAN pCAN, // pointer to a CAN controller

+    unsigned int abort_cmd)

+{

+	pCAN->CAN_ACR = abort_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageModeReg

+//* \brief Program the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mode)

+{

+	CAN_Mailbox->CAN_MB_MMR = mode;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageModeReg

+//* \brief Return the Message Mode Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageModeReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MMR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageIDReg

+//* \brief Program the Message ID Register

+//* \brief Version == 0 for Standard messsage, Version == 1 for Extended

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int id,

+    unsigned char version)

+{

+	if(version==0)	// IDvA Standard Format

+		CAN_Mailbox->CAN_MB_MID = id<<18;

+	else	// IDvB Extended Format

+		CAN_Mailbox->CAN_MB_MID = id | (1<<29);	// set MIDE bit

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageIDReg

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageIDReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MID;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageAcceptanceMaskReg

+//* \brief Program the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int mask)

+{

+	CAN_Mailbox->CAN_MB_MAM = mask;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageAcceptanceMaskReg

+//* \brief Return the Message Acceptance Mask Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageAcceptanceMaskReg (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MAM;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetFamilyID

+//* \brief Return the Message ID Register

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetFamilyID (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MFID;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageCtrl

+//* \brief Request and config for a transfer on the corresponding mailbox

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageCtrlReg (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int message_ctrl_cmd)

+{

+	CAN_Mailbox->CAN_MB_MCR = message_ctrl_cmd;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageStatus

+//* \brief Return CAN Mailbox Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageStatus (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataLow

+//* \brief Program data low value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDL = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataLow

+//* \brief Return data low value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataLow (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDL;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgMessageDataHigh

+//* \brief Program data high value

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox, // pointer to a CAN Mailbox

+    unsigned int data)

+{

+	CAN_Mailbox->CAN_MB_MDH = data;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_GetMessageDataHigh

+//* \brief Return data high value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_GetMessageDataHigh (

+	AT91PS_CAN_MB	CAN_Mailbox) // pointer to a CAN Mailbox

+{

+	return CAN_Mailbox->CAN_MB_MDH;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_Open

+//* \brief Open a CAN Port

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_CAN_Open (

+        const unsigned int null)  // \arg

+{

+        /* NOT DEFINED AT THIS MOMENT */

+        return ( 0 );

+}

+/* *****************************************************************************

+                SOFTWARE API FOR ADC

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableIt

+//* \brief Enable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableIt (

+	AT91PS_ADC pADC,     // pointer to a ADC controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pADC->ADC_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableIt

+//* \brief Disable ADC interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableIt (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pADC->ADC_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetStatus

+//* \brief Return ADC Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetStatus( // \return ADC Interrupt Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_SR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetInterruptMaskStatus

+//* \brief Return ADC Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetInterruptMaskStatus( // \return ADC Interrupt Mask Status

+	AT91PS_ADC pADC) // pointer to a ADC controller

+{

+	return pADC->ADC_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsInterruptMasked

+//* \brief Test if ADC Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsInterruptMasked(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetInterruptMaskStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_IsStatusSet

+//* \brief Test if ADC Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_IsStatusSet(

+        AT91PS_ADC pADC,   // \arg  pointer to a ADC controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_ADC_GetStatus(pADC) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgModeReg

+//* \brief Configure the Mode Register of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgModeReg (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mode)        // mode register

+{

+	//* Write to the MR register

+	pADC->ADC_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetModeReg

+//* \brief Return the Mode Register of the ADC controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetModeReg (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgTimings

+//* \brief Configure the different necessary timings of the ADC controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgTimings (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int mck_clock, // in MHz

+	unsigned int adc_clock, // in MHz

+	unsigned int startup_time, // in us

+	unsigned int sample_and_hold_time)	// in ns

+{

+	unsigned int prescal,startup,shtim;

+	

+	prescal = mck_clock/(2*adc_clock) - 1;

+	startup = adc_clock*startup_time/8 - 1;

+	shtim = adc_clock*sample_and_hold_time/1000 - 1;

+	

+	//* Write to the MR register

+	pADC->ADC_MR = ( (prescal<<8) & AT91C_ADC_PRESCAL) | ( (startup<<16) & AT91C_ADC_STARTUP) | ( (shtim<<24) & AT91C_ADC_SHTIM);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_EnableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_EnableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register

+{

+	//* Write to the CHER register

+	pADC->ADC_CHER = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_DisableChannel

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_DisableChannel (

+	AT91PS_ADC pADC, // pointer to a ADC controller

+	unsigned int channel)        // mode register

+{

+	//* Write to the CHDR register

+	pADC->ADC_CHDR = channel;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetChannelStatus

+//* \brief Return ADC Timer Register Value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetChannelStatus (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CHSR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_StartConversion

+//* \brief Software request for a analog to digital conversion

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_StartConversion (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_SoftReset

+//* \brief Software reset

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_SoftReset (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	pADC->ADC_CR = AT91C_ADC_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetLastConvertedData

+//* \brief Return the Last Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetLastConvertedData (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_LCDR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH0

+//* \brief Return the Channel 0 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH0 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR0;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH1

+//* \brief Return the Channel 1 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH1 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR1;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH2

+//* \brief Return the Channel 2 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH2 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR2;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH3

+//* \brief Return the Channel 3 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH3 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR3;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH4

+//* \brief Return the Channel 4 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH4 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR4;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH5

+//* \brief Return the Channel 5 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH5 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR5;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH6

+//* \brief Return the Channel 6 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH6 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR6;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_GetConvertedDataCH7

+//* \brief Return the Channel 7 Converted Data

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_ADC_GetConvertedDataCH7 (

+	AT91PS_ADC pADC // pointer to a ADC controller

+	)

+{

+	return pADC->ADC_CDR7;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR AES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_EnableIt

+//* \brief Enable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_EnableIt (

+	AT91PS_AES pAES,     // pointer to a AES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pAES->AES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_DisableIt

+//* \brief Disable AES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_DisableIt (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pAES->AES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetStatus

+//* \brief Return AES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetStatus( // \return AES Interrupt Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetInterruptMaskStatus

+//* \brief Return AES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetInterruptMaskStatus( // \return AES Interrupt Mask Status

+	AT91PS_AES pAES) // pointer to a AES controller

+{

+	return pAES->AES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsInterruptMasked

+//* \brief Test if AES Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsInterruptMasked(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetInterruptMaskStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_IsStatusSet

+//* \brief Test if AES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_IsStatusSet(

+        AT91PS_AES pAES,   // \arg  pointer to a AES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_AES_GetStatus(pAES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgModeReg

+//* \brief Configure the Mode Register of the AES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgModeReg (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned int mode)        // mode register

+{

+	//* Write to the MR register

+	pAES->AES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetModeReg

+//* \brief Return the Mode Register of the AES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetModeReg (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	return pAES->AES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_StartProcessing (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SoftReset

+//* \brief Reset AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SoftReset (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_LoadNewSeed

+//* \brief Load New Seed in the random number generator

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_LoadNewSeed (

+	AT91PS_AES pAES // pointer to a AES controller

+	)

+{

+	pAES->AES_CR = AT91C_AES_LOADSEED;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetCryptoKey

+//* \brief Set Cryptographic Key x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetCryptoKey (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pAES->AES_KEYWxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_InputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pAES->AES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_AES_GetOutputData (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index

+	)

+{

+	return pAES->AES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_SetInitializationVector

+//* \brief Set Initialization Vector (or Counter) x

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_SetInitializationVector (

+	AT91PS_AES pAES, // pointer to a AES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pAES->AES_IVxR[index] = initvector;	

+}

+

+/* *****************************************************************************

+                SOFTWARE API FOR TDES

+   ***************************************************************************** */

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_EnableIt

+//* \brief Enable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_EnableIt (

+	AT91PS_TDES pTDES,     // pointer to a TDES controller

+	unsigned int flag)   // IT to be enabled

+{

+	//* Write to the IER register

+	pTDES->TDES_IER = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_DisableIt

+//* \brief Disable TDES interrupt

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_DisableIt (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int flag) // IT to be disabled

+{

+	//* Write to the IDR register

+	pTDES->TDES_IDR = flag;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetStatus

+//* \brief Return TDES Interrupt Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetStatus( // \return TDES Interrupt Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_ISR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetInterruptMaskStatus

+//* \brief Return TDES Interrupt Mask Status

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetInterruptMaskStatus( // \return TDES Interrupt Mask Status

+	AT91PS_TDES pTDES) // pointer to a TDES controller

+{

+	return pTDES->TDES_IMR;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsInterruptMasked

+//* \brief Test if TDES Interrupt is Masked

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsInterruptMasked(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetInterruptMaskStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_IsStatusSet

+//* \brief Test if TDES Status is Set

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_IsStatusSet(

+        AT91PS_TDES pTDES,   // \arg  pointer to a TDES controller

+        unsigned int flag) // \arg  flag to be tested

+{

+	return (AT91F_TDES_GetStatus(pTDES) & flag);

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgModeReg

+//* \brief Configure the Mode Register of the TDES controller

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgModeReg (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned int mode)        // mode register

+{

+	//* Write to the MR register

+	pTDES->TDES_MR = mode;

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetModeReg

+//* \brief Return the Mode Register of the TDES controller value

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetModeReg (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	return pTDES->TDES_MR;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_StartProcessing

+//* \brief Start Encryption or Decryption

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_StartProcessing (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_START;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SoftReset

+//* \brief Reset TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SoftReset (

+	AT91PS_TDES pTDES // pointer to a TDES controller

+	)

+{

+	pTDES->TDES_CR = AT91C_TDES_SWRST;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey1

+//* \brief Set Cryptographic Key 1 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey1 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY1WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey2

+//* \brief Set Cryptographic Key 2 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey2 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY2WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetCryptoKey3

+//* \brief Set Cryptographic Key 3 Word x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetCryptoKey3 (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int keyword

+	)

+{

+	pTDES->TDES_KEY3WxR[index] = keyword;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_InputData

+//* \brief Set Input Data x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_InputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int indata

+	)

+{

+	pTDES->TDES_IDATAxR[index] = indata;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_GetOutputData

+//* \brief Get Output Data x

+//*----------------------------------------------------------------------------

+__inline unsigned int AT91F_TDES_GetOutputData (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index

+	)

+{

+	return pTDES->TDES_ODATAxR[index];	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_SetInitializationVector

+//* \brief Set Initialization Vector x

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_SetInitializationVector (

+	AT91PS_TDES pTDES, // pointer to a TDES controller

+	unsigned char index,

+	unsigned int initvector

+	)

+{

+	pTDES->TDES_IVxR[index] = initvector;	

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  DBGU

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_DBGU_CfgPIO

+//* \brief Configure PIO controllers to drive DBGU signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_DBGU_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA27_DRXD    ) |

+		((unsigned int) AT91C_PA28_DTXD    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PMC_CfgPIO

+//* \brief Configure PIO controllers to drive PMC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PMC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB30_PCK2    ) |

+		((unsigned int) AT91C_PB29_PCK1    ), // Peripheral A

+		((unsigned int) AT91C_PB20_PCK0    ) |

+		((unsigned int) AT91C_PB0_PCK0    ) |

+		((unsigned int) AT91C_PB22_PCK2    ) |

+		((unsigned int) AT91C_PB21_PCK1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA30_PCK2    ) |

+		((unsigned int) AT91C_PA13_PCK1    ) |

+		((unsigned int) AT91C_PA27_PCK3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_VREG_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  VREG

+//*----------------------------------------------------------------------------

+__inline void AT91F_VREG_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RSTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RSTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RSTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SSC

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SSC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SSC_CfgPIO

+//* \brief Configure PIO controllers to drive SSC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SSC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA25_RK      ) |

+		((unsigned int) AT91C_PA22_TK      ) |

+		((unsigned int) AT91C_PA21_TF      ) |

+		((unsigned int) AT91C_PA24_RD      ) |

+		((unsigned int) AT91C_PA26_RF      ) |

+		((unsigned int) AT91C_PA23_TD      ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_WDTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  WDTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_WDTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US1

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US1_CfgPIO

+//* \brief Configure PIO controllers to drive US1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB26_RI1     ) |

+		((unsigned int) AT91C_PB24_DSR1    ) |

+		((unsigned int) AT91C_PB23_DCD1    ) |

+		((unsigned int) AT91C_PB25_DTR1    )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA7_SCK1    ) |

+		((unsigned int) AT91C_PA8_RTS1    ) |

+		((unsigned int) AT91C_PA6_TXD1    ) |

+		((unsigned int) AT91C_PA5_RXD1    ) |

+		((unsigned int) AT91C_PA9_CTS1    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  US0

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_US0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_US0_CfgPIO

+//* \brief Configure PIO controllers to drive US0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_US0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA0_RXD0    ) |

+		((unsigned int) AT91C_PA4_CTS0    ) |

+		((unsigned int) AT91C_PA3_RTS0    ) |

+		((unsigned int) AT91C_PA2_SCK0    ) |

+		((unsigned int) AT91C_PA1_TXD0    ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI1

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI1_CfgPIO

+//* \brief Configure PIO controllers to drive SPI1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB16_NPCS13  ) |

+		((unsigned int) AT91C_PB10_NPCS11  ) |

+		((unsigned int) AT91C_PB11_NPCS12  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA4_NPCS13  ) |

+		((unsigned int) AT91C_PA29_NPCS13  ) |

+		((unsigned int) AT91C_PA21_NPCS10  ) |

+		((unsigned int) AT91C_PA22_SPCK1   ) |

+		((unsigned int) AT91C_PA25_NPCS11  ) |

+		((unsigned int) AT91C_PA2_NPCS11  ) |

+		((unsigned int) AT91C_PA24_MISO1   ) |

+		((unsigned int) AT91C_PA3_NPCS12  ) |

+		((unsigned int) AT91C_PA26_NPCS12  ) |

+		((unsigned int) AT91C_PA23_MOSI1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  SPI0

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SPI0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_SPI0_CfgPIO

+//* \brief Configure PIO controllers to drive SPI0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_SPI0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB13_NPCS01  ) |

+		((unsigned int) AT91C_PB17_NPCS03  ) |

+		((unsigned int) AT91C_PB14_NPCS02  )); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA16_MISO0   ) |

+		((unsigned int) AT91C_PA13_NPCS01  ) |

+		((unsigned int) AT91C_PA15_NPCS03  ) |

+		((unsigned int) AT91C_PA17_MOSI0   ) |

+		((unsigned int) AT91C_PA18_SPCK0   ) |

+		((unsigned int) AT91C_PA14_NPCS02  ) |

+		((unsigned int) AT91C_PA12_NPCS00  ), // Peripheral A

+		((unsigned int) AT91C_PA7_NPCS01  ) |

+		((unsigned int) AT91C_PA9_NPCS03  ) |

+		((unsigned int) AT91C_PA8_NPCS02  )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PITC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PITC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PITC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AIC

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_FIQ) |

+		((unsigned int) 1 << AT91C_ID_IRQ0) |

+		((unsigned int) 1 << AT91C_ID_IRQ1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AIC_CfgPIO

+//* \brief Configure PIO controllers to drive AIC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_AIC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA30_IRQ0    ) |

+		((unsigned int) AT91C_PA29_FIQ     ), // Peripheral A

+		((unsigned int) AT91C_PA14_IRQ1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_AES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  AES

+//*----------------------------------------------------------------------------

+__inline void AT91F_AES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_AES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TWI

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TWI));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TWI_CfgPIO

+//* \brief Configure PIO controllers to drive TWI signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TWI_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA11_TWCK    ) |

+		((unsigned int) AT91C_PA10_TWD     ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  ADC

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_ADC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_ADC_CfgPIO

+//* \brief Configure PIO controllers to drive ADC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_ADC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PB18_ADTRG   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH3_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH3 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH3_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB22_PWM3    ), // Peripheral A

+		((unsigned int) AT91C_PB30_PWM3    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH2_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB21_PWM2    ), // Peripheral A

+		((unsigned int) AT91C_PB29_PWM2    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH1_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB20_PWM1    ), // Peripheral A

+		((unsigned int) AT91C_PB28_PWM1    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CH0_CfgPIO

+//* \brief Configure PIO controllers to drive PWMC_CH0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CH0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB19_PWM0    ), // Peripheral A

+		((unsigned int) AT91C_PB27_PWM0    )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_RTTC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  RTTC

+//*----------------------------------------------------------------------------

+__inline void AT91F_RTTC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_UDP_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  UDP

+//*----------------------------------------------------------------------------

+__inline void AT91F_UDP_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_UDP));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TDES_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TDES

+//*----------------------------------------------------------------------------

+__inline void AT91F_TDES_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TDES));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  EMAC

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_EMAC));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_EMAC_CfgPIO

+//* \brief Configure PIO controllers to drive EMAC signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_EMAC_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB2_ETX0    ) |

+		((unsigned int) AT91C_PB12_ETXER   ) |

+		((unsigned int) AT91C_PB16_ECOL    ) |

+		((unsigned int) AT91C_PB11_ETX3    ) |

+		((unsigned int) AT91C_PB6_ERX1    ) |

+		((unsigned int) AT91C_PB15_ERXDV   ) |

+		((unsigned int) AT91C_PB13_ERX2    ) |

+		((unsigned int) AT91C_PB3_ETX1    ) |

+		((unsigned int) AT91C_PB8_EMDC    ) |

+		((unsigned int) AT91C_PB5_ERX0    ) |

+		//((unsigned int) AT91C_PB18_EF100   ) |

+		((unsigned int) AT91C_PB14_ERX3    ) |

+		((unsigned int) AT91C_PB4_ECRS_ECRSDV) |

+		((unsigned int) AT91C_PB1_ETXEN   ) |

+		((unsigned int) AT91C_PB10_ETX2    ) |

+		((unsigned int) AT91C_PB0_ETXCK_EREFCK) |

+		((unsigned int) AT91C_PB9_EMDIO   ) |

+		((unsigned int) AT91C_PB7_ERXER   ) |

+		((unsigned int) AT91C_PB17_ERXCK   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC0

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC0));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC0_CfgPIO

+//* \brief Configure PIO controllers to drive TC0 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC0_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB23_TIOA0   ) |

+		((unsigned int) AT91C_PB24_TIOB0   ), // Peripheral A

+		((unsigned int) AT91C_PB12_TCLK0   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC1

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC1));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC1_CfgPIO

+//* \brief Configure PIO controllers to drive TC1 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC1_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB25_TIOA1   ) |

+		((unsigned int) AT91C_PB26_TIOB1   ), // Peripheral A

+		((unsigned int) AT91C_PB19_TCLK1   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  TC2

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_TC2));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_TC2_CfgPIO

+//* \brief Configure PIO controllers to drive TC2 signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_TC2_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOB, // PIO controller base address

+		((unsigned int) AT91C_PB28_TIOB2   ) |

+		((unsigned int) AT91C_PB27_TIOA2   ), // Peripheral A

+		0); // Peripheral B

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		0, // Peripheral A

+		((unsigned int) AT91C_PA15_TCLK2   )); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_MC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  MC

+//*----------------------------------------------------------------------------

+__inline void AT91F_MC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_SYS));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOA_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOA

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOA_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOA));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PIOB_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PIOB

+//*----------------------------------------------------------------------------

+__inline void AT91F_PIOB_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PIOB));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  CAN

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_CAN));

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_CAN_CfgPIO

+//* \brief Configure PIO controllers to drive CAN signals

+//*----------------------------------------------------------------------------

+__inline void AT91F_CAN_CfgPIO (void)

+{

+	// Configure PIO controllers to periph mode

+	AT91F_PIO_CfgPeriph(

+		AT91C_BASE_PIOA, // PIO controller base address

+		((unsigned int) AT91C_PA20_CANTX   ) |

+		((unsigned int) AT91C_PA19_CANRX   ), // Peripheral A

+		0); // Peripheral B

+}

+

+//*----------------------------------------------------------------------------

+//* \fn    AT91F_PWMC_CfgPMC

+//* \brief Enable Peripheral clock in PMC for  PWMC

+//*----------------------------------------------------------------------------

+__inline void AT91F_PWMC_CfgPMC (void)

+{

+	AT91F_PMC_EnablePeriphClock(

+		AT91C_BASE_PMC, // PIO controller base address

+		((unsigned int) 1 << AT91C_ID_PWMC));

+}

+

+#endif // lib_AT91SAM7X256_H

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/port.c b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/port.c
new file mode 100644
index 0000000..e57f1d2
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/port.c
@@ -0,0 +1,298 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Atmel ARM7 port.

+ *----------------------------------------------------------*/

+

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to setup the PIT. */

+#define portPIT_CLOCK_DIVISOR			( ( unsigned long ) 16 )

+#define portPIT_COUNTER_VALUE			( ( ( configCPU_CLOCK_HZ / portPIT_CLOCK_DIVISOR ) / 1000UL ) * portTICK_RATE_MS )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+

+#define portINT_LEVEL_SENSITIVE  0

+#define portPIT_ENABLE      	( ( unsigned short ) 0x1 << 24 )

+#define portPIT_INT_ENABLE     	( ( unsigned short ) 0x1 << 25 )

+/*-----------------------------------------------------------*/

+

+/* Setup the PIT to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00UL )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}	

+	

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 0

+

+	/* The cooperative scheduler requires a normal IRQ service routine to

+	simply increment the system tick. */

+	static __arm __irq void vPortNonPreemptiveTick( void );

+	static __arm __irq void vPortNonPreemptiveTick( void )

+	{

+		unsigned long ulDummy;

+		

+		/* Increment the tick count - which may wake some tasks but as the

+		preemptive scheduler is not being used any woken task is not given

+		processor time no matter what its priority. */

+		vTaskIncrementTick();

+		

+		/* Clear the PIT interrupt. */

+		ulDummy = AT91C_BASE_PITC->PITC_PIVR;

+		

+		/* End the interrupt in the AIC. */

+		AT91C_BASE_AIC->AIC_EOICR = ulDummy;

+	}

+

+#else

+

+	/* Currently the IAR port requires the preemptive tick function to be

+	defined in an asm file. */

+

+#endif

+

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+AT91PS_PITC pxPIT = AT91C_BASE_PITC;

+

+	/* Setup the AIC for PIT interrupts.  The interrupt routine chosen depends

+	on whether the preemptive or cooperative scheduler is being used. */

+	#if configUSE_PREEMPTION == 0

+

+		AT91F_AIC_ConfigureIt( AT91C_BASE_AIC, AT91C_ID_SYS, AT91C_AIC_PRIOR_HIGHEST, portINT_LEVEL_SENSITIVE, ( void (*)(void) ) vPortNonPreemptiveTick );

+

+	#else

+		

+		extern void ( vPortPreemptiveTick )( void );

+		AT91F_AIC_ConfigureIt( AT91C_BASE_AIC, AT91C_ID_SYS, AT91C_AIC_PRIOR_HIGHEST, portINT_LEVEL_SENSITIVE, ( void (*)(void) ) vPortPreemptiveTick );

+

+	#endif

+

+	/* Configure the PIT period. */

+	pxPIT->PITC_PIMR = portPIT_ENABLE | portPIT_INT_ENABLE | portPIT_COUNTER_VALUE;

+

+	/* Enable the interrupt.  Global interrupts are disables at this point so

+	this is safe. */

+	AT91F_AIC_EnableIt( AT91C_BASE_AIC, AT91C_ID_SYS );

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	__disable_interrupt();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			__enable_interrupt();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portasm.s79 b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portasm.s79
new file mode 100644
index 0000000..687ad1c
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portasm.s79
@@ -0,0 +1,111 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+		RSEG ICODE:CODE

+		CODE32

+

+	EXTERN vTaskSwitchContext

+	EXTERN vTaskIncrementTick

+

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortPreemptiveTick

+	PUBLIC vPortStartFirstTask

+

+#include "AT91SAM7S64_inc.h"

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly 

+								; as if the context was saved during and IRQ 

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Preemptive context switch function.  This will only ever get installed if

+; portUSE_PREEMPTION is set to 1 in portmacro.h.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortPreemptiveTick:

+	portSAVE_CONTEXT			; Save the context of the current task.

+

+	LDR R0, =vTaskIncrementTick ; Increment the tick count - this may wake a task.

+	mov lr, pc

+	BX R0

+	LDR R0, =vTaskSwitchContext ; Select the next task to execute.

+	mov lr, pc

+	BX R0

+

+	LDR	R14, =AT91C_BASE_PITC	; Clear the PIT interrupt

+	LDR	R0, [R14, #PITC_PIVR ]

+

+	LDR R14, =AT91C_BASE_AIC	; Mark the End of Interrupt on the AIC

+    STR	R14, [R14, #AIC_EOICR]

+

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portmacro.h b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portmacro.h
new file mode 100644
index 0000000..4af3afe
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM7S64/portmacro.h
@@ -0,0 +1,146 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortDisableInterruptsFromThumb( void );

+__arm __interwork void vPortEnableInterruptsFromThumb( void );

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	__disable_interrupt()

+#define portENABLE_INTERRUPTS()		__enable_interrupt()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/ISR_Support.h b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/ISR_Support.h
new file mode 100644
index 0000000..4a32f39
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/ISR_Support.h
@@ -0,0 +1,78 @@
+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/port.c b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/port.c
new file mode 100644
index 0000000..63b4203
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/port.c
@@ -0,0 +1,296 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Atmel ARM7 port.

+ *----------------------------------------------------------*/

+

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Hardware includes. */

+#include <board.h>

+#include <pio/pio.h>

+#include <pio/pio_it.h>

+#include <pit/pit.h>

+#include <aic/aic.h>

+#include <tc/tc.h>

+#include <utility/led.h>

+#include <utility/trace.h>

+

+/*-----------------------------------------------------------*/

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to setup the PIT. */

+#define port1MHz_IN_Hz 					( 1000000ul )

+#define port1SECOND_IN_uS				( 1000000.0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+

+#define portINT_LEVEL_SENSITIVE  0

+#define portPIT_ENABLE      	( ( unsigned short ) 0x1 << 24 )

+#define portPIT_INT_ENABLE     	( ( unsigned short ) 0x1 << 25 )

+/*-----------------------------------------------------------*/

+

+/* Setup the PIT to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* The PIT interrupt handler - the RTOS tick. */

+static void vPortTickISR( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	

+	#ifdef THUMB_INTERWORK

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+	#endif

+	

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+static __arm void vPortTickISR( void )

+{

+volatile unsigned long ulDummy;

+	

+	/* Increment the tick count - which may wake some tasks but as the

+	preemptive scheduler is not being used any woken task is not given

+	processor time no matter what its priority. */

+	vTaskIncrementTick();

+

+	#if configUSE_PREEMPTION == 1

+		vTaskSwitchContext();

+	#endif	

+		

+	/* Clear the PIT interrupt. */

+	ulDummy = AT91C_BASE_PITC->PITC_PIVR;

+	

+	/* To remove compiler warning. */

+	( void ) ulDummy;

+	

+	/* The AIC is cleared in the asm wrapper, outside of this function. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulPeriodIn_uS = ( 1.0 / ( double ) configTICK_RATE_HZ ) * port1SECOND_IN_uS;

+

+	/* Setup the PIT for the required frequency. */

+	PIT_Init( ulPeriodIn_uS, BOARD_MCK / port1MHz_IN_Hz );

+	

+	/* Setup the PIT interrupt. */

+	AIC_DisableIT( AT91C_ID_SYS );

+	AIC_ConfigureIT( AT91C_ID_SYS, AT91C_AIC_PRIOR_LOWEST, vPortTickISR );

+	AIC_EnableIT( AT91C_ID_SYS );

+	PIT_EnableIT();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	__disable_irq();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			__enable_irq();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portasm.s79 b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portasm.s79
new file mode 100644
index 0000000..d5ac7eb
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portasm.s79
@@ -0,0 +1,34 @@
+		RSEG ICODE:CODE

+		CODE32

+

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortStartFirstTask

+

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly

+								; as if the context was saved during and IRQ

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portmacro.h b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portmacro.h
new file mode 100644
index 0000000..13217ac
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/AtmelSAM9XE/portmacro.h
@@ -0,0 +1,148 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include <intrinsics.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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortDisableInterruptsFromThumb( void );

+__arm __interwork void vPortEnableInterruptsFromThumb( void );

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	__disable_irq()

+#define portENABLE_INTERRUPTS()		__enable_irq()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/LPC2000/ISR_Support.h b/FreeRTOS/Source/portable/IAR/LPC2000/ISR_Support.h
new file mode 100644
index 0000000..8e1cb83
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/LPC2000/ISR_Support.h
@@ -0,0 +1,130 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/LPC2000/port.c b/FreeRTOS/Source/portable/IAR/LPC2000/port.c
new file mode 100644
index 0000000..073b5f8
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/LPC2000/port.c
@@ -0,0 +1,355 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Philips ARM7 port.

+ *----------------------------------------------------------*/

+

+/*

+	Changes from V3.2.2

+

+	+ Bug fix - The prescale value for the timer setup is now written to T0PR

+	  instead of T0PC.  This bug would have had no effect unless a prescale

+	  value was actually used.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+#include <intrinsics.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the tick ISR. */

+#define portENABLE_TIMER			( ( unsigned char ) 0x01 )

+#define portPRESCALE_VALUE			0x00

+#define portINTERRUPT_ON_MATCH		( ( unsigned long ) 0x01 )

+#define portRESET_COUNT_ON_MATCH	( ( unsigned long ) 0x02 )

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to setup the PIT. */

+#define portPIT_CLOCK_DIVISOR			( ( unsigned long ) 16 )

+#define portPIT_COUNTER_VALUE			( ( ( configCPU_CLOCK_HZ / portPIT_CLOCK_DIVISOR ) / 1000UL ) * portTICK_RATE_MS )

+

+/* Constants required to handle interrupts. */

+#define portTIMER_MATCH_ISR_BIT		( ( unsigned char ) 0x01 )

+#define portCLEAR_VIC_INTERRUPT		( ( unsigned long ) 0 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+

+#define portINT_LEVEL_SENSITIVE  0

+#define portPIT_ENABLE      	( ( unsigned short ) 0x1 << 24 )

+#define portPIT_INT_ENABLE     	( ( unsigned short ) 0x1 << 25 )

+

+/* Constants required to setup the VIC for the tick ISR. */

+#define portTIMER_VIC_CHANNEL		( ( unsigned long ) 0x0004 )

+#define portTIMER_VIC_CHANNEL_BIT	( ( unsigned long ) 0x0010 )

+#define portTIMER_VIC_ENABLE		( ( unsigned long ) 0x0020 )

+

+/*-----------------------------------------------------------*/

+

+/* Setup the PIT to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00UL )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+	

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 0

+

+	/* The cooperative scheduler requires a normal IRQ service routine to

+	simply increment the system tick. */

+	static __arm __irq void vPortNonPreemptiveTick( void );

+	static __arm __irq void vPortNonPreemptiveTick( void )

+	{

+		/* Increment the tick count - which may wake some tasks but as the

+		preemptive scheduler is not being used any woken task is not given

+		processor time no matter what its priority. */

+		vTaskIncrementTick();

+		

+		/* Ready for the next interrupt. */

+		T0IR = portTIMER_MATCH_ISR_BIT;

+		VICVectAddr = portCLEAR_VIC_INTERRUPT;

+	}

+

+#else

+

+	/* This function is called from an asm wrapper, so does not require the __irq

+	keyword. */

+	void vPortPreemptiveTick( void );

+	void vPortPreemptiveTick( void )

+	{

+		/* Increment the tick counter. */

+		vTaskIncrementTick();

+	

+		/* The new tick value might unblock a task.  Ensure the highest task that

+		is ready to execute is the task that will execute when the tick ISR

+		exits. */

+		vTaskSwitchContext();

+	

+		/* Ready for the next interrupt. */

+		T0IR = portTIMER_MATCH_ISR_BIT;

+		VICVectAddr = portCLEAR_VIC_INTERRUPT;

+	}

+

+#endif

+

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+unsigned long ulCompareMatch;

+

+	/* A 1ms tick does not require the use of the timer prescale.  This is

+	defaulted to zero but can be used if necessary. */

+	T0PR = portPRESCALE_VALUE;

+

+	/* Calculate the match value required for our wanted tick rate. */

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* Protect against divide by zero.  Using an if() statement still results

+	in a warning - hence the #if. */

+	#if portPRESCALE_VALUE != 0

+	{

+		ulCompareMatch /= ( portPRESCALE_VALUE + 1 );

+	}

+	#endif

+

+	T0MR0 = ulCompareMatch;

+

+	/* Generate tick with timer 0 compare match. */

+	T0MCR = portRESET_COUNT_ON_MATCH | portINTERRUPT_ON_MATCH;

+

+	/* Setup the VIC for the timer. */

+	VICIntSelect &= ~( portTIMER_VIC_CHANNEL_BIT );

+	VICIntEnable |= portTIMER_VIC_CHANNEL_BIT;

+	

+	/* The ISR installed depends on whether the preemptive or cooperative

+	scheduler is being used. */

+	#if configUSE_PREEMPTION == 1

+	{	

+		extern void ( vPortPreemptiveTickEntry )( void );

+

+		VICVectAddr0 = ( unsigned long ) vPortPreemptiveTickEntry;

+	}

+	#else

+	{

+		extern void ( vNonPreemptiveTick )( void );

+

+		VICVectAddr0 = ( long ) vPortNonPreemptiveTick;

+	}

+	#endif

+

+	VICVectCntl0 = portTIMER_VIC_CHANNEL | portTIMER_VIC_ENABLE;

+

+	/* Start the timer - interrupts are disabled when this function is called

+	so it is okay to do this here. */

+	T0TCR = portENABLE_TIMER;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	__disable_interrupt();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			__enable_interrupt();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/LPC2000/portasm.s79 b/FreeRTOS/Source/portable/IAR/LPC2000/portasm.s79
new file mode 100644
index 0000000..74184f6
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/LPC2000/portasm.s79
@@ -0,0 +1,102 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+		RSEG ICODE:CODE

+		CODE32

+

+	EXTERN vTaskSwitchContext

+	EXTERN vTaskIncrementTick

+	EXTERN vPortPreemptiveTick

+	

+	PUBLIC vPortPreemptiveTickEntry

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortStartFirstTask

+

+#include "FreeRTOSConfig.h"

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly

+								; as if the context was saved during and IRQ

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Preemptive context switch function.  This will only ever get installed if

+; portUSE_PREEMPTION is set to 1 in portmacro.h.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortPreemptiveTickEntry:

+#if configUSE_PREEMPTION == 1

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vPortPreemptiveTick; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+#endif

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/LPC2000/portmacro.h b/FreeRTOS/Source/portable/IAR/LPC2000/portmacro.h
new file mode 100644
index 0000000..e518e4f
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/LPC2000/portmacro.h
@@ -0,0 +1,147 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include <intrinsics.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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortDisableInterruptsFromThumb( void );

+__arm __interwork void vPortEnableInterruptsFromThumb( void );

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	__disable_interrupt()

+#define portENABLE_INTERRUPTS()		__enable_interrupt()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/MSP430/port.c b/FreeRTOS/Source/portable/IAR/MSP430/port.c
new file mode 100644
index 0000000..ba49e29
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430/port.c
@@ -0,0 +1,212 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MSP430 port.

+ *----------------------------------------------------------*/

+

+/* Constants required for hardware setup.  The tick ISR runs off the ACLK,

+not the MCLK. */

+#define portACLK_FREQUENCY_HZ			( ( portTickType ) 32768 )

+#define portINITIAL_CRITICAL_NESTING	( ( unsigned short ) 10 )

+#define portFLAGS_INT_ENABLED			( ( portSTACK_TYPE ) 0x08 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Each task maintains a count of the critical section nesting depth.  Each

+time a critical section is entered the count is incremented.  Each time a

+critical section is exited the count is decremented - with interrupts only

+being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+void vPortSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/*

+		Place a few bytes of known values on the bottom of the stack.

+		This is just useful for debugging and can be included if required.

+

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;

+		pxTopOfStack--;

+	*/

+

+	/* The msp430 automatically pushes the PC then SR onto the stack before

+	executing an ISR.  We want the stack to look just as if this has happened

+	so place a pointer to the start of the task on the stack first - followed

+	by the flags we want the task to use when it starts up. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+	*pxTopOfStack = portFLAGS_INT_ENABLED;

+	pxTopOfStack--;

+

+	/* Next the general purpose registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x7777;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaa;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xbbbb;

+	pxTopOfStack--;	

+	

+	/* When the task starts is will expect to find the function parameter in

+	R15. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xdddd;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xeeee;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xffff;

+	pxTopOfStack--;

+

+	/* A variable is used to keep track of the critical section nesting.

+	This variable has to be stored as part of the task context and is

+	initially set to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the MSP430 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.  This uses timer 0

+ * but could alternatively use the watchdog timer or timer 1.

+ */

+void vPortSetupTimerInterrupt( void )

+{

+	/* Ensure the timer is stopped. */

+	TACTL = 0;

+

+	/* Run the timer of the ACLK. */

+	TACTL = TASSEL_1;

+

+	/* Clear everything to start with. */

+	TACTL |= TACLR;

+

+	/* Set the compare match value according to the tick rate we want. */

+	TACCR0 = portACLK_FREQUENCY_HZ / configTICK_RATE_HZ;

+

+	/* Enable the interrupts. */

+	TACCTL0 = CCIE;

+

+	/* Start up clean. */

+	TACTL |= TACLR;

+

+	/* Up mode. */

+	TACTL |= MC_1;

+}

+/*-----------------------------------------------------------*/

+

+

+	

diff --git a/FreeRTOS/Source/portable/IAR/MSP430/portasm.h b/FreeRTOS/Source/portable/IAR/MSP430/portasm.h
new file mode 100644
index 0000000..dc875a3
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430/portasm.h
@@ -0,0 +1,123 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTASM_H

+#define PORTASM_H

+

+portSAVE_CONTEXT macro

+

+		IMPORT pxCurrentTCB

+		IMPORT usCriticalNesting

+

+		/* Save the remaining registers. */

+		push	r4

+		push	r5

+		push	r6

+		push	r7

+		push	r8

+		push	r9

+		push	r10

+		push	r11

+		push	r12

+		push	r13

+		push	r14

+		push	r15

+		mov.w	&usCriticalNesting, r14

+		push	r14

+		mov.w	&pxCurrentTCB, r12

+		mov.w	r1, 0(r12)

+		endm

+/*-----------------------------------------------------------*/

+		

+portRESTORE_CONTEXT macro

+		mov.w	&pxCurrentTCB, r12

+		mov.w	@r12, r1

+		pop		r15

+		mov.w	r15, &usCriticalNesting

+		pop		r15

+		pop		r14

+		pop		r13

+		pop		r12

+		pop		r11

+		pop		r10

+		pop		r9

+		pop		r8

+		pop		r7

+		pop		r6

+		pop		r5

+		pop		r4

+

+		/* The last thing on the stack will be the status register.

+        Ensure the power down bits are clear ready for the next

+        time this power down register is popped from the stack. */

+		bic.w   #0xf0,0(SP)

+

+		reti

+		endm

+/*-----------------------------------------------------------*/

+

+#endif

+

diff --git a/FreeRTOS/Source/portable/IAR/MSP430/portext.s43 b/FreeRTOS/Source/portable/IAR/MSP430/portext.s43
new file mode 100644
index 0000000..fcff058
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430/portext.s43
@@ -0,0 +1,145 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+#include "FreeRTOSConfig.h"

+#include "portasm.h"

+

+	IMPORT vTaskIncrementTick

+	IMPORT vTaskSwitchContext

+	IMPORT vPortSetupTimerInterrupt

+

+	EXPORT vTickISR

+	EXPORT vPortYield

+	EXPORT xPortStartScheduler

+	

+	RSEG CODE

+

+/*

+ * The RTOS tick ISR.

+ *

+ * If the cooperative scheduler is in use this simply increments the tick

+ * count.

+ *

+ * If the preemptive scheduler is in use a context switch can also occur.

+ */

+vTickISR:

+	portSAVE_CONTEXT

+				

+	call	#vTaskIncrementTick

+

+	#if configUSE_PREEMPTION == 1

+		call	#vTaskSwitchContext

+	#endif

+		

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Manual context switch called by the portYIELD() macro.

+ */

+vPortYield:

+

+	/* Mimic an interrupt by pushing the SR. */

+	push	SR			

+

+	/* Now the SR is stacked we can disable interrupts. */

+	dint			

+				

+	/* Save the context of the current task. */

+	portSAVE_CONTEXT			

+

+	/* Switch to the highest priority task that is ready to run. */

+	call	#vTaskSwitchContext		

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Start off the scheduler by initialising the RTOS tick timer, then restoring

+ * the context of the first task.

+ */

+xPortStartScheduler:

+

+	/* Setup the hardware to generate the tick.  Interrupts are disabled

+	when this function is called. */

+	call	#vPortSetupTimerInterrupt

+

+	/* Restore the context of the first task that is going to run. */

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+      		

+

+	/* Install vTickISR as the timer A0 interrupt. */

+	ASEG

+	ORG 0xFFE0 + TIMERA0_VECTOR

+	

+	_vTickISR_: DC16 vTickISR

+	

+

+	END

+		

diff --git a/FreeRTOS/Source/portable/IAR/MSP430/portmacro.h b/FreeRTOS/Source/portable/IAR/MSP430/portmacro.h
new file mode 100644
index 0000000..376ed55
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430/portmacro.h
@@ -0,0 +1,166 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()	_DINT(); _NOP()

+#define portENABLE_INTERRUPTS()		_EINT();

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled usCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.

+ */

+extern void vPortYield( void );

+#define portYIELD() vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )	

+#define portNOP()	

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#if configINTERRUPT_EXAMPLE_METHOD == 2

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( x ) if( x ) vTaskSwitchContext()

+

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/MSP430X/data_model.h b/FreeRTOS/Source/portable/IAR/MSP430X/data_model.h
new file mode 100644
index 0000000..c81c761
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430X/data_model.h
@@ -0,0 +1,102 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef DATA_MODEL_H

+#define DATA_MODEL_H

+

+#ifdef __DATA_MODEL_SMALL__

+	#define pushm_x pushm.w

+	#define popm_x popm.w

+	#define push_x push.w

+	#define pop_x pop.w

+	#define mov_x mov.w

+	#define cmp_x cmp.w

+#endif

+

+#ifdef __DATA_MODEL_MEDIUM__

+	#define pushm_x pushm.a

+	#define popm_x popm.a

+	#define push_x pushx.a

+	#define pop_x popx.a

+	#define mov_x mov.w

+	#define cmp_x cmp.w

+#endif

+

+#ifdef __DATA_MODEL_LARGE__

+	#define pushm_x pushm.a

+	#define popm_x popm.a

+	#define push_x pushx.a

+	#define pop_x popx.a

+	#define mov_x movx.a

+	#define cmp_x cmpx.a

+#endif

+

+#ifndef pushm_x

+	#error The assembler options must define one of the following symbols: __DATA_MODEL_SMALL__, __DATA_MODEL_MEDIUM__, or __DATA_MODEL_LARGE__

+#endif

+

+#endif /* DATA_MODEL_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/MSP430X/port.c b/FreeRTOS/Source/portable/IAR/MSP430X/port.c
new file mode 100644
index 0000000..5e26e70
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430X/port.c
@@ -0,0 +1,221 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MSP430X port.

+ *----------------------------------------------------------*/

+

+/* Constants required for hardware setup.  The tick ISR runs off the ACLK,

+not the MCLK. */

+#define portACLK_FREQUENCY_HZ			( ( portTickType ) 32768 )

+#define portINITIAL_CRITICAL_NESTING	( ( unsigned short ) 10 )

+#define portFLAGS_INT_ENABLED			( ( portSTACK_TYPE ) 0x08 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Each task maintains a count of the critical section nesting depth.  Each

+time a critical section is entered the count is incremented.  Each time a

+critical section is exited the count is decremented - with interrupts only

+being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+void vPortSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned short *pusTopOfStack;

+unsigned long *pulTopOfStack;

+

+	/*

+		Place a few bytes of known values on the bottom of the stack.

+		This is just useful for debugging and can be included if required.

+	

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;

+	*/

+

+	/* portSTACK_TYPE is either 16 bits or 32 bits depending on the data model.

+	Some stacked items do not change size depending on the data model so have

+	to be explicitly cast to the correct size so this function will work

+	whichever data model is being used. */

+	if( sizeof( portSTACK_TYPE ) == sizeof( unsigned short ) )

+	{

+		/* Make room for a 20 bit value stored as a 32 bit value. */

+		pusTopOfStack = ( unsigned short * ) pxTopOfStack;

+		pusTopOfStack--;

+		pulTopOfStack = ( unsigned long * ) pusTopOfStack;

+	}

+	else

+	{

+		pulTopOfStack = ( unsigned long * ) pxTopOfStack;

+	}

+	*pulTopOfStack = ( unsigned long ) pxCode;

+	

+	pusTopOfStack = ( unsigned short * ) pulTopOfStack;

+	pusTopOfStack--;

+	*pusTopOfStack = portFLAGS_INT_ENABLED;

+	pusTopOfStack -= ( sizeof( portSTACK_TYPE ) / 2 );

+	

+	/* From here on the size of stacked items depends on the memory model. */

+	pxTopOfStack = ( portSTACK_TYPE * ) pusTopOfStack;

+

+	/* Next the general purpose registers. */

+	#ifdef PRELOAD_REGISTER_VALUES

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xffff;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xdddd;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;

+		pxTopOfStack--;	

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;

+		pxTopOfStack--;

+	#else

+		pxTopOfStack -= 3;

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack -= 9;

+	#endif

+

+

+	/* A variable is used to keep track of the critical section nesting.

+	This variable has to be stored as part of the task context and is

+	initially set to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the MSP430 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.

+ */

+void vPortSetupTimerInterrupt( void )

+{

+	vApplicationSetupTimerInterrupt();

+}

+/*-----------------------------------------------------------*/

+

+#pragma vector=configTICK_VECTOR

+__interrupt __raw void vTickISREntry( void )

+{

+extern void vPortTickISR( void );

+

+	__bic_SR_register_on_exit( SCG1 + SCG0 + OSCOFF + CPUOFF );

+	vPortTickISR();

+}

+

+	

diff --git a/FreeRTOS/Source/portable/IAR/MSP430X/portext.s43 b/FreeRTOS/Source/portable/IAR/MSP430X/portext.s43
new file mode 100644
index 0000000..4f61f52
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430X/portext.s43
@@ -0,0 +1,176 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+#include "msp430.h"

+#include "FreeRTOSConfig.h"

+#include "data_model.h"

+

+	IMPORT vTaskIncrementTick

+	IMPORT vTaskSwitchContext

+	IMPORT vPortSetupTimerInterrupt

+	IMPORT pxCurrentTCB

+	IMPORT usCriticalNesting

+

+	EXPORT vPortTickISR

+	EXPORT vPortYield

+	EXPORT xPortStartScheduler

+

+portSAVE_CONTEXT macro

+

+	/* Save the remaining registers. */

+	pushm_x	#12, r15

+	mov.w	&usCriticalNesting, r14

+	push_x r14

+	mov_x	&pxCurrentTCB, r12

+	mov_x	sp, 0( r12 )

+	endm

+/*-----------------------------------------------------------*/

+		

+portRESTORE_CONTEXT macro

+

+	mov_x	&pxCurrentTCB, r12

+	mov_x	@r12, sp

+	pop_x	r15

+	mov.w	r15, &usCriticalNesting

+	popm_x	#12, r15

+	pop.w	sr

+	reta

+	endm

+/*-----------------------------------------------------------*/

+

+

+/*

+ * The RTOS tick ISR.

+ *

+ * If the cooperative scheduler is in use this simply increments the tick

+ * count.

+ *

+ * If the preemptive scheduler is in use a context switch can also occur.

+ */

+

+	RSEG CODE

+	EVEN

+

+vPortTickISR:

+

+	/* The sr is not saved in portSAVE_CONTEXT() because vPortYield() needs

+	to save it manually before it gets modified (interrupts get disabled).

+	Entering through this interrupt means the SR is already on the stack, but

+	this keeps the stack frames identical. */

+	push.w sr

+	portSAVE_CONTEXT

+

+	calla	#vTaskIncrementTick

+

+	#if configUSE_PREEMPTION == 1

+		calla	#vTaskSwitchContext

+	#endif

+

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch called by the portYIELD() macro.

+ */

+ 	EVEN

+

+vPortYield:

+

+	/* The sr needs saving before it is modified. */

+	push.w	sr

+

+	/* Now the SR is stacked we can disable interrupts. */

+	dint

+	nop

+

+	/* Save the context of the current task. */

+	portSAVE_CONTEXT

+

+	/* Select the next task to run. */

+	calla	#vTaskSwitchContext

+

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Start off the scheduler by initialising the RTOS tick timer, then restoring

+ * the context of the first task.

+ */

+ 	EVEN

+

+xPortStartScheduler:

+

+	/* Setup the hardware to generate the tick.  Interrupts are disabled

+	when this function is called. */

+	calla	#vPortSetupTimerInterrupt

+

+	/* Restore the context of the first task that is going to run. */

+	portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/MSP430X/portmacro.h b/FreeRTOS/Source/portable/IAR/MSP430X/portmacro.h
new file mode 100644
index 0000000..8aea186
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/MSP430X/portmacro.h
@@ -0,0 +1,177 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+

+/* Hardware includes. */

+#include "msp430.h"

+

+/* Type definitions. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		int

+#define portBASE_TYPE	portSHORT

+

+/* The stack type changes depending on the data model. */

+#if( __DATA_MODEL__ == __DATA_MODEL_SMALL__ )

+	#define portSTACK_TYPE unsigned short

+#else

+	#define portSTACK_TYPE unsigned long

+#endif

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()	_DINT();_NOP()

+#define portENABLE_INTERRUPTS()		_EINT()

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned short usCriticalNesting;								\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled usCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned short usCriticalNesting;							\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.

+ */

+extern void vPortYield( void );

+#define portYIELD() vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )	

+#define portNOP()					__no_operation()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( x ) if( x ) vPortYield()

+	

+void vApplicationSetupTimerInterrupt( void );

+

+/* sizeof( int ) != sizeof( long ) so a full printf() library is required if

+run time stats information is to be displayed. */

+#define portLU_PRINTF_SPECIFIER_REQUIRED

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/RL78/ISR_Support.h b/FreeRTOS/Source/portable/IAR/RL78/ISR_Support.h
new file mode 100644
index 0000000..28b9808
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RL78/ISR_Support.h
@@ -0,0 +1,119 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+

+#include "FreeRTOSConfig.h"

+

+; Variables used by scheduler

+;------------------------------------------------------------------------------

+	EXTERN    pxCurrentTCB

+	EXTERN    usCriticalNesting

+

+;------------------------------------------------------------------------------

+;   portSAVE_CONTEXT MACRO

+;   Saves the context of the general purpose registers, CS and ES (only in far 

+;	memory mode) registers the usCriticalNesting Value and the Stack Pointer

+;   of the active Task onto the task stack

+;------------------------------------------------------------------------------

+portSAVE_CONTEXT MACRO

+

+	PUSH      AX                    ; Save AX Register to stack.

+	PUSH      HL

+#if __DATA_MODEL__ == __DATA_MODEL_FAR__

+	MOV       A, CS                 ; Save CS register.

+	XCH       A, X

+	MOV       A, ES                 ; Save ES register.

+	PUSH      AX

+#else

+	MOV       A, CS                 ; Save CS register.

+	PUSH      AX

+#endif

+	PUSH      DE                    ; Save the remaining general purpose registers.

+	PUSH      BC

+	MOVW      AX, usCriticalNesting ; Save the usCriticalNesting value.

+	PUSH      AX	

+	MOVW      AX, pxCurrentTCB 	    ; Save the Stack pointer.

+	MOVW      HL, AX					

+	MOVW      AX, SP					

+	MOVW      [HL], AX					

+	ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   portRESTORE_CONTEXT MACRO

+;   Restores the task Stack Pointer then use this to restore usCriticalNesting,

+;   general purpose registers and the CS and ES (only in far memory mode)

+;   of the selected task from the task stack

+;------------------------------------------------------------------------------

+portRESTORE_CONTEXT MACRO

+	MOVW      AX, pxCurrentTCB	    ; Restore the Stack pointer.

+	MOVW      HL, AX

+	MOVW      AX, [HL]

+	MOVW      SP, AX

+	POP	      AX	                ; Restore usCriticalNesting value.

+	MOVW      usCriticalNesting, AX

+	POP	      BC                    ; Restore the necessary general purpose registers.

+	POP	      DE

+#if __DATA_MODEL__ == __DATA_MODEL_FAR__

+	POP       AX                    ; Restore the ES register.

+	MOV       ES, A

+	XCH       A, X                  ; Restore the CS register.

+	MOV       CS, A

+#else

+	POP       AX

+	MOV       CS, A                 ; Restore CS register.

+#endif

+	POP       HL                    ; Restore general purpose register HL.

+	POP       AX                    ; Restore AX.

+	ENDM

+;------------------------------------------------------------------------------

diff --git a/FreeRTOS/Source/portable/IAR/RL78/port.c b/FreeRTOS/Source/portable/IAR/RL78/port.c
new file mode 100644
index 0000000..3b3c39f
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RL78/port.c
@@ -0,0 +1,256 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* The critical nesting value is initialised to a non zero value to ensure

+interrupts don't accidentally become enabled before the scheduler is started. */

+#define portINITIAL_CRITICAL_NESTING  ( ( unsigned short ) 10 )

+

+/* Initial PSW value allocated to a newly created task.

+ *   1100011000000000

+ *   ||||||||-------------- Fill byte

+ *   |||||||--------------- Carry Flag cleared

+ *   |||||----------------- In-service priority Flags set to low level

+ *   ||||------------------ Register bank Select 0 Flag cleared

+ *   |||------------------- Auxiliary Carry Flag cleared

+ *   ||-------------------- Register bank Select 1 Flag cleared

+ *   |--------------------- Zero Flag set

+ *   ---------------------- Global Interrupt Flag set (enabled)

+ */

+#define portPSW		  ( 0xc6UL )

+

+/* The address of the pxCurrentTCB variable, but don't know or need to know its

+type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Each task maintains a count of the critical section nesting depth.  Each time

+a critical section is entered the count is incremented.  Each time a critical

+section is exited the count is decremented - with interrupts only being

+re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as that could cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Defined in portasm.s87, this function starts the scheduler by loading the

+ * context of the first task to run.

+ */

+extern void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long *pulLocal;

+

+	#if __DATA_MODEL__ == __DATA_MODEL_FAR__

+	{

+		/* Parameters are passed in on the stack, and written using a 32bit value

+		hence a space is left for the second two bytes. */

+		pxTopOfStack--;

+

+		/* Write in the parameter value. */

+		pulLocal =  ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( unsigned long ) pvParameters;

+		pxTopOfStack--;

+

+		/* These values are just spacers.  The return address of the function

+		would normally be written here. */

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xcdcd;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0xcdcd;

+		pxTopOfStack--;

+

+		/* The start address / PSW value is also written in as a 32bit value,

+		so leave a space for the second two bytes. */

+		pxTopOfStack--;

+	

+		/* Task function start address combined with the PSW. */

+		pulLocal = ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( ( ( unsigned long ) pxCode ) | ( portPSW << 24UL ) );

+		pxTopOfStack--;

+

+		/* An initial value for the AX register. */

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		/* Task function address is written to the stack first.  As it is

+		written as a 32bit value a space is left on the stack for the second

+		two bytes. */

+		pxTopOfStack--;

+

+		/* Task function start address combined with the PSW. */

+		pulLocal = ( unsigned long * ) pxTopOfStack;

+		*pulLocal = ( ( ( unsigned long ) pxCode ) | ( portPSW << 24UL ) );

+		pxTopOfStack--;

+

+		/* The parameter is passed in AX. */

+		*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+		pxTopOfStack--;

+	}

+	#endif

+

+	/* An initial value for the HL register. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+	pxTopOfStack--;

+

+	/* CS and ES registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0F00;

+	pxTopOfStack--;

+

+	/* Finally the remaining general purpose registers DE and BC */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDEDE;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBCBC;

+	pxTopOfStack--;

+

+	/* Finally the critical section nesting count is set to zero when the task

+	first starts. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack that has beene generated so it

+	can	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	vPortStartFirstTask();

+

+	/* Execution should not reach here as the tasks are now running! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the RL78/G13 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned short usClockHz = 15000UL; /* Internal clock. */

+const unsigned short usCompareMatch = ( usClockHz / configTICK_RATE_HZ ) + 1UL;

+

+	/* Use the internal 15K clock. */

+	OSMC = 0x16U;

+

+	/* Supply the RTC clock. */

+	RTCEN = 1U;

+	

+	/* Disable ITMC operation. */

+	ITMC = 0x0000;

+	

+	/* Disable INTIT interrupt. */

+	ITMK = 1U;

+	

+	/* Set INTIT high priority */

+	ITPR1 = 1U;

+	ITPR0 = 1U;

+	

+	/* Set interval. */

+	ITMC = usCompareMatch;

+

+	/* Clear INIT interrupt. */

+	ITIF = 0U;

+	

+	/* Enable INTIT interrupt. */

+	ITMK = 0U;

+	

+	/* Enable IT operation. */

+	ITMC |= 0x8000;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/IAR/RL78/portasm.s87 b/FreeRTOS/Source/portable/IAR/RL78/portasm.s87
new file mode 100644
index 0000000..d264ad6
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RL78/portasm.s87
@@ -0,0 +1,114 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+#include "ISR_Support.h"

+

+

+#if __CORE__ != __RL78_1__

+	#error "This file is only for RL78 Devices"

+#endif

+

+#define CS                    0xFFFFC

+#define ES                    0xFFFFD

+

+	PUBLIC    vPortYield

+	PUBLIC    vPortStartFirstTask

+	PUBLIC    vPortTickISR

+

+	EXTERN    vTaskSwitchContext

+	EXTERN    vTaskIncrementTick

+

+; FreeRTOS yield handler.  This is installed as the BRK software interrupt

+; handler.

+    RSEG CODE:CODE

+vPortYield:

+	portSAVE_CONTEXT		        ; Save the context of the current task.

+	call      vTaskSwitchContext    ; Call the scheduler to select the next task.

+	portRESTORE_CONTEXT		        ; Restore the context of the next task to run.

+	retb

+

+	

+; Starts the scheduler by restoring the context of the task that will execute

+; first.

+    RSEG CODE:CODE

+vPortStartFirstTask:

+	portRESTORE_CONTEXT	            ; Restore the context of whichever task the ...

+	reti					        ; An interrupt stack frame is used so the task

+                                    ; is started using a RETI instruction.

+

+; FreeRTOS tick handler.  This is installed as the interval timer interrupt

+; handler.

+	 RSEG CODE:CODE

+vPortTickISR:

+

+	portSAVE_CONTEXT		        ; Save the context of the current task.

+	call      vTaskIncrementTick    ; Call the timer tick function.

+#if configUSE_PREEMPTION == 1

+	call      vTaskSwitchContext    ; Call the scheduler to select the next task.

+#endif

+	portRESTORE_CONTEXT		        ; Restore the context of the next task to run.

+	reti

+

+

+; Install the interrupt handlers

+

+	COMMON INTVEC:CODE:ROOT(1)

+	ORG 56

+	DW vPortTickISR

+

+	COMMON INTVEC:CODE:ROOT(1)

+	ORG 126

+	DW vPortYield

+

+

+      END
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/IAR/RL78/portmacro.h b/FreeRTOS/Source/portable/IAR/RL78/portmacro.h
new file mode 100644
index 0000000..2ecdbe8
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RL78/portmacro.h
@@ -0,0 +1,191 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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.

+ *-----------------------------------------------------------

+ */

+

+#if __DATA_MODEL__ == __DATA_MODEL_FAR__ && __CODE_MODEL__ == __CODE_MODEL_NEAR__

+	#warning This port has not been tested with your selected memory model combination. If a far data model is required it is recommended to also use a far code model.

+#endif

+

+#if __DATA_MODEL__ == __DATA_MODEL_NEAR__ && __CODE_MODEL__ == __CODE_MODEL_FAR__

+	#warning This port has not been tested with your selected memory model combination. If a far code model is required it is recommended to also use a far data model.

+#endif

+	

+/* Type definitions. */

+

+#define portCHAR        char

+#define portFLOAT       float

+#define portDOUBLE      double

+#define portLONG        long

+#define portSHORT       short

+#define portSTACK_TYPE  unsigned short

+#define portBASE_TYPE   short

+

+#if __DATA_MODEL__ == __DATA_MODEL_FAR__

+	#define portPOINTER_SIZE_TYPE unsigned long

+#else

+	#define portPOINTER_SIZE_TYPE unsigned short

+#endif

+

+	

+#if ( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned int portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned long portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS() __asm ( "DI" )

+#define portENABLE_INTERRUPTS()	 __asm ( "EI" )

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned short usCriticalNesting;								\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled ulCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned short usCriticalNesting;								\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+#define portYIELD()	__asm( "BRK" )

+#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) if( xHigherPriorityTaskWoken ) vTaskSwitchContext()

+#define portNOP()	__asm( "NOP" )

+/*-----------------------------------------------------------*/

+

+/* Hardwware specifics. */

+#define portBYTE_ALIGNMENT	2

+#define portSTACK_GROWTH	( -1 )

+#define portTICK_RATE_MS	( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+/* --------------------------------------------------------------------------*/

+/* Option-bytes and security ID                                              */

+/* --------------------------------------------------------------------------*/

+#define OPT_BYTES_SIZE     4

+#define SECU_ID_SIZE       10

+#define WATCHDOG_DISABLED  0x00

+#define LVI_ENABLED        0xFE

+#define LVI_DISABLED       0xFF

+#define RESERVED_FF        0xFF

+#define OCD_DISABLED       0x04

+#define OCD_ENABLED        0x81

+#define OCD_ENABLED_ERASE  0x80

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/RX600/port.c b/FreeRTOS/Source/portable/IAR/RX600/port.c
new file mode 100644
index 0000000..8895f5a
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RX600/port.c
@@ -0,0 +1,232 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the SH2A port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "string.h"

+

+/* Hardware specifics. */

+#include <iorx62n.h>

+

+/*-----------------------------------------------------------*/

+

+/* Tasks should start with interrupts enabled and in Supervisor mode, therefore

+PSW is set with U and I set, and PM and IPL clear. */

+#define portINITIAL_PSW	 ( ( portSTACK_TYPE ) 0x00030000 )

+#define portINITIAL_FPSW	( ( portSTACK_TYPE ) 0x00000100 )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Function to start the first task executing - written in asm code as direct

+ * access to registers is required.

+ */

+extern void prvStartFirstTask( void );

+

+/*

+ * The tick ISR handler.  The peripheral used is configured by the application

+ * via a hook/callback function.

+ */

+__interrupt void vTickISR( void );

+

+/*-----------------------------------------------------------*/

+

+extern void *pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* R0 is not included as it is the stack pointer. */

+	

+	*pxTopOfStack = 0x00;

+	pxTopOfStack--;

+ 	*pxTopOfStack = portINITIAL_PSW;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	

+	/* When debugging it can be useful if every register is set to a known

+	value.  Otherwise code space can be saved by just setting the registers

+	that need to be set. */

+	#ifdef USE_FULL_REGISTER_INITIALISATION

+	{

+		pxTopOfStack--;

+		*pxTopOfStack = 0xffffffff;	/* r15. */

+		pxTopOfStack--;

+		*pxTopOfStack = 0xeeeeeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xdddddddd;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xcccccccc;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xbbbbbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xaaaaaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x99999999;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x88888888;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x77777777;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x66666666;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x55555555;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x44444444;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x33333333;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x22222222;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		pxTopOfStack -= 15;

+	}

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R1 */

+	pxTopOfStack--;				

+	*pxTopOfStack = portINITIAL_FPSW;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x12345678; /* Accumulator. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x87654321; /* Accumulator. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vApplicationSetupTimerInterrupt( void );

+

+	/* Use pxCurrentTCB just so it does not get optimised away. */

+	if( pxCurrentTCB != NULL )

+	{

+		/* Call an application function to set up the timer that will generate the

+		tick interrupt.  This way the application can decide which peripheral to

+		use.  A demo application is provided to show a suitable example. */

+		vApplicationSetupTimerInterrupt();

+

+		/* Enable the software interrupt. */		

+		_IEN( _ICU_SWINT ) = 1;

+		

+		/* Ensure the software interrupt is clear. */

+		_IR( _ICU_SWINT ) = 0;

+		

+		/* Ensure the software interrupt is set to the kernel priority. */

+		_IPR( _ICU_SWINT ) = configKERNEL_INTERRUPT_PRIORITY;

+

+		/* Start the first task. */

+		prvStartFirstTask();

+	}

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+#pragma vector = configTICK_VECTOR

+__interrupt void vTickISR( void )

+{

+	/* Re-enable interrupts. */

+	__enable_interrupt();

+	

+	/* Increment the tick, and perform any processing the new tick value

+	necessitates. */

+	__set_interrupt_level( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+	{

+		vTaskIncrementTick();

+	}

+	__set_interrupt_level( configKERNEL_INTERRUPT_PRIORITY );

+	

+	/* Only select a new task if the preemptive scheduler is being used. */

+	#if( configUSE_PREEMPTION == 1 )

+		taskYIELD();

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/RX600/port_asm.s b/FreeRTOS/Source/portable/IAR/RX600/port_asm.s
new file mode 100644
index 0000000..ae19299
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RX600/port_asm.s
@@ -0,0 +1,198 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "PriorityDefinitions.h"

+

+	PUBLIC _prvStartFirstTask

+	PUBLIC ___interrupt_27

+

+	EXTERN _pxCurrentTCB

+	EXTERN _vTaskSwitchContext

+

+	RSEG CODE:CODE(4)

+

+_prvStartFirstTask:

+

+		/* When starting the scheduler there is nothing that needs moving to the

+		interrupt stack because the function is not called from an interrupt.

+		Just ensure the current stack is the user stack. */

+		SETPSW		U

+

+		/* Obtain the location of the stack associated with which ever task

+		pxCurrentTCB is currently pointing to. */

+		MOV.L		#_pxCurrentTCB, R15

+		MOV.L		[R15], R15

+		MOV.L		[R15], R0

+

+		/* Restore the registers from the stack of the task pointed to by

+		pxCurrentTCB. */

+		POP			R15

+

+		/* Accumulator low 32 bits. */

+		MVTACLO		R15

+		POP			R15

+

+		/* Accumulator high 32 bits. */

+		MVTACHI		R15

+		POP			R15

+

+		/* Floating point status word. */

+		MVTC		R15, FPSW

+

+		/* R1 to R15 - R0 is not included as it is the SP. */

+		POPM		R1-R15

+

+		/* This pops the remaining registers. */

+		RTE

+		NOP

+		NOP

+

+/*-----------------------------------------------------------*/

+

+/* The software interrupt - overwrite the default 'weak' definition. */

+___interrupt_27:

+

+		/* Re-enable interrupts. */

+		SETPSW		I

+

+		/* Move the data that was automatically pushed onto the interrupt stack when

+		the interrupt occurred from the interrupt stack to the user stack.

+

+		R15 is saved before it is clobbered. */

+		PUSH.L		R15

+

+		/* Read the user stack pointer. */

+		MVFC		USP, R15

+

+		/* Move the address down to the data being moved. */

+		SUB			#12, R15

+		MVTC		R15, USP

+

+		/* Copy the data across, R15, then PC, then PSW. */

+		MOV.L		[ R0 ], [ R15 ]

+		MOV.L 		4[ R0 ], 4[ R15 ]

+		MOV.L		8[ R0 ], 8[ R15 ]

+

+		/* Move the interrupt stack pointer to its new correct position. */

+		ADD		#12, R0

+

+		/* All the rest of the registers are saved directly to the user stack. */

+		SETPSW		U

+

+		/* Save the rest of the general registers (R15 has been saved already). */

+		PUSHM		R1-R14

+

+		/* Save the FPSW and accumulator. */

+		MVFC		FPSW, R15

+		PUSH.L		R15

+		MVFACHI 	R15

+		PUSH.L		R15

+

+		/* Middle word. */

+		MVFACMI	R15

+

+		/* Shifted left as it is restored to the low order word. */

+		SHLL		#16, R15

+		PUSH.L		R15

+

+		/* Save the stack pointer to the TCB. */

+		MOV.L		#_pxCurrentTCB, R15

+		MOV.L		[ R15 ], R15

+		MOV.L		R0, [ R15 ]

+

+		/* Ensure the interrupt mask is set to the syscall priority while the kernel

+		structures are being accessed. */

+		MVTIPL		#configMAX_SYSCALL_INTERRUPT_PRIORITY

+

+		/* Select the next task to run. */

+		BSR.A		_vTaskSwitchContext

+

+		/* Reset the interrupt mask as no more data structure access is required. */

+		MVTIPL		#configKERNEL_INTERRUPT_PRIORITY

+

+		/* Load the stack pointer of the task that is now selected as the Running

+		state task from its TCB. */

+		MOV.L		#_pxCurrentTCB,R15

+		MOV.L		[ R15 ], R15

+		MOV.L		[ R15 ], R0

+

+		/* Restore the context of the new task.  The PSW (Program Status Word) and

+		PC will be popped by the RTE instruction. */

+		POP			R15

+		MVTACLO 	R15

+		POP			R15

+		MVTACHI 	R15

+		POP			R15

+		MVTC		R15, FPSW

+		POPM		R1-R15

+		RTE

+		NOP

+		NOP

+

+/*-----------------------------------------------------------*/

+

+		END

+

diff --git a/FreeRTOS/Source/portable/IAR/RX600/portmacro.h b/FreeRTOS/Source/portable/IAR/RX600/portmacro.h
new file mode 100644
index 0000000..bc71c65
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/RX600/portmacro.h
@@ -0,0 +1,151 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include <intrinsics.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 - these are a bit legacy and not really used now, other than

+portSTACK_TYPE and portBASE_TYPE. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			8	/* Could make four, according to manual. */

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()					__no_operation()

+

+/* The location of the software interrupt register.  Software interrupts use

+vector 27. */

+#define portITU_SWINTR			( ( unsigned char * ) 0x000872E0 )

+#define portYIELD()				*portITU_SWINTR = ( unsigned char ) 0x01; portNOP(); portNOP(); portNOP(); portNOP(); portNOP()

+#define portYIELD_FROM_ISR( x )	if( ( x ) != pdFALSE ) portYIELD()

+

+/*

+ * These macros should be called directly, but through the taskENTER_CRITICAL()

+ * and taskEXIT_CRITICAL() macros.

+ */

+#define portENABLE_INTERRUPTS() 	__set_interrupt_level( ( unsigned char ) 0 )

+#define portDISABLE_INTERRUPTS() 	__set_interrupt_level( ( unsigned char ) configMAX_SYSCALL_INTERRUPT_PRIORITY )

+

+/* Critical nesting counts are stored in the TCB. */

+#define portCRITICAL_NESTING_IN_TCB ( 1 )

+

+/* The critical nesting functions defined within tasks.c. */

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()	vTaskEnterCritical()

+#define portEXIT_CRITICAL()		vTaskExitCritical()

+

+/* As this port allows interrupt nesting... */

+unsigned long ulPortGetIPL( void );

+void vPortSetIPL( unsigned long ulNewIPL );

+#define portSET_INTERRUPT_MASK_FROM_ISR() __get_interrupt_level(); portDISABLE_INTERRUPTS()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus ) __set_interrupt_level( ( unsigned char ) ( uxSavedInterruptStatus ) )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/IAR/STR71x/ISR_Support.h b/FreeRTOS/Source/portable/IAR/STR71x/ISR_Support.h
new file mode 100644
index 0000000..8e1cb83
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR71x/ISR_Support.h
@@ -0,0 +1,130 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/STR71x/port.c b/FreeRTOS/Source/portable/IAR/STR71x/port.c
new file mode 100644
index 0000000..3e66780
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR71x/port.c
@@ -0,0 +1,298 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ST STR71x ARM7

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include "wdg.h"

+#include "eic.h"

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+#define portMICROS_PER_SECOND 1000000

+

+/*-----------------------------------------------------------*/

+

+/* Setup the watchdog to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/* Tick interrupt routines for cooperative and preemptive operation

+respectively.  The preemptive version is not defined as __irq as it is called

+from an asm wrapper function. */

+__arm __irq void vPortNonPreemptiveTick( void );

+void vPortPreemptiveTick( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00UL )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}		

+	

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/* The cooperative scheduler requires a normal IRQ service routine to

+simply increment the system tick. */

+__arm __irq void vPortNonPreemptiveTick( void )

+{

+	/* Increment the tick count - which may wake some tasks but as the

+	preemptive scheduler is not being used any woken task is not given

+	processor time no matter what its priority. */

+	vTaskIncrementTick();

+

+	/* Clear the interrupt in the watchdog and EIC. */

+	WDG->SR = 0x0000;

+	portCLEAR_EIC();		

+}

+/*-----------------------------------------------------------*/

+

+/* This function is called from an asm wrapper, so does not require the __irq

+keyword. */

+void vPortPreemptiveTick( void )

+{

+	/* Increment the tick counter. */

+	vTaskIncrementTick();

+

+	/* The new tick value might unblock a task.  Ensure the highest task that

+	is ready to execute is the task that will execute when the tick ISR

+	exits. */

+	vTaskSwitchContext();

+

+	/* Clear the interrupt in the watchdog and EIC. */

+	WDG->SR = 0x0000;

+	portCLEAR_EIC();			

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+	/* Set the watchdog up to generate a periodic tick. */

+	WDG_ECITConfig( DISABLE );

+	WDG_CntOnOffConfig( DISABLE );

+	WDG_PeriodValueConfig( portMICROS_PER_SECOND / configTICK_RATE_HZ );

+

+	/* Setup the tick interrupt in the EIC. */

+	EIC_IRQChannelPriorityConfig( WDG_IRQChannel, 1 );

+	EIC_IRQChannelConfig( WDG_IRQChannel, ENABLE );

+	EIC_IRQConfig( ENABLE );

+	WDG_ECITConfig( ENABLE );

+

+	/* Start the timer - interrupts are actually disabled at this point so

+	it is safe to do this here. */

+	WDG_CntOnOffConfig( ENABLE );

+}

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	__disable_interrupt();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			__enable_interrupt();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/STR71x/portasm.s79 b/FreeRTOS/Source/portable/IAR/STR71x/portasm.s79
new file mode 100644
index 0000000..1c0bf31
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR71x/portasm.s79
@@ -0,0 +1,101 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+		RSEG ICODE:CODE

+		CODE32

+

+	EXTERN vPortPreemptiveTick

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortStartFirstTask

+	PUBLIC vPortPreemptiveTickISR

+

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly

+								; as if the context was saved during and IRQ

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Preemptive context switch function.  This will only ever get used if

+; portUSE_PREEMPTION is set to 1 in portmacro.h.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortPreemptiveTickISR:

+	portSAVE_CONTEXT			; Save the context of the current task.

+

+	LDR R0, =vPortPreemptiveTick ; Increment the tick count - this may wake a task.

+	MOV lr, pc

+	BX R0

+

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/STR71x/portmacro.h b/FreeRTOS/Source/portable/IAR/STR71x/portmacro.h
new file mode 100644
index 0000000..aef9ae1
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR71x/portmacro.h
@@ -0,0 +1,155 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+

+#include <intrinsics.h>

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+

+/* Type definitions. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortDisableInterruptsFromThumb( void );

+__arm __interwork void vPortEnableInterruptsFromThumb( void );

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	__disable_interrupt()

+#define portENABLE_INTERRUPTS()		__enable_interrupt()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+/* EIC utilities. */

+#define portEIC_CICR_ADDR		*( ( unsigned portLONG * ) 0xFFFFF804 )

+#define portEIC_IPR_ADDR		*( ( unsigned portLONG * ) 0xFFFFF840 )

+#define portCLEAR_EIC()			portEIC_IPR_ADDR = 0x01 << portEIC_CICR_ADDR

+

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/STR75x/ISR_Support.h b/FreeRTOS/Source/portable/IAR/STR75x/ISR_Support.h
new file mode 100644
index 0000000..e230589
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR75x/ISR_Support.h
@@ -0,0 +1,131 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/STR75x/port.c b/FreeRTOS/Source/portable/IAR/STR75x/port.c
new file mode 100644
index 0000000..8517c8c
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR75x/port.c
@@ -0,0 +1,279 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ST STR75x ARM7

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include "75x_tb.h"

+#include "75x_eic.h"

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the initial stack. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x3f ) /* System mode, THUMB mode, interrupts enabled. */

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+/* Prescale used on the timer clock when calculating the tick period. */

+#define portPRESCALE 20

+

+

+/*-----------------------------------------------------------*/

+

+/* Setup the TB to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/* Tick interrupt routines for preemptive operation. */

+__arm void vPortPreemptiveTick( void );

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+__arm void vPortPreemptiveTick( void )

+{

+	/* Increment the tick counter. */

+	vTaskIncrementTick();

+

+	/* The new tick value might unblock a task.  Ensure the highest task that

+	is ready to execute is the task that will execute when the tick ISR

+	exits. */

+	#if configUSE_PREEMPTION == 1

+		vTaskSwitchContext();

+	#endif

+

+	TB_ClearITPendingBit( TB_IT_Update );

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+EIC_IRQInitTypeDef  EIC_IRQInitStructure;	

+TB_InitTypeDef      TB_InitStructure;

+

+	/* Setup the EIC for the TB. */

+	EIC_IRQInitStructure.EIC_IRQChannelCmd = ENABLE;

+	EIC_IRQInitStructure.EIC_IRQChannel = TB_IRQChannel;

+	EIC_IRQInitStructure.EIC_IRQChannelPriority = 1;

+	EIC_IRQInit(&EIC_IRQInitStructure);

+	

+	/* Setup the TB for the generation of the tick interrupt. */

+	TB_InitStructure.TB_Mode = TB_Mode_Timing;

+	TB_InitStructure.TB_CounterMode = TB_CounterMode_Down;

+	TB_InitStructure.TB_Prescaler = portPRESCALE - 1;

+	TB_InitStructure.TB_AutoReload = ( ( configCPU_CLOCK_HZ / portPRESCALE ) / configTICK_RATE_HZ );

+	TB_Init(&TB_InitStructure);

+	

+	/* Enable TB Update interrupt */

+	TB_ITConfig(TB_IT_Update, ENABLE);

+

+	/* Clear TB Update interrupt pending bit */

+	TB_ClearITPendingBit(TB_IT_Update);

+

+	/* Enable TB */

+	TB_Cmd(ENABLE);

+}

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	__disable_interrupt();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			__enable_interrupt();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/STR75x/portasm.s79 b/FreeRTOS/Source/portable/IAR/STR75x/portasm.s79
new file mode 100644
index 0000000..3fc3579
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR75x/portasm.s79
@@ -0,0 +1,89 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	RSEG ICODE:CODE

+	CODE32

+

+	EXTERN vPortPreemptiveTick

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortStartFirstTask

+

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly

+								; as if the context was saved during and IRQ

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	mov     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/STR75x/portmacro.h b/FreeRTOS/Source/portable/IAR/STR75x/portmacro.h
new file mode 100644
index 0000000..45037fb
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR75x/portmacro.h
@@ -0,0 +1,146 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+

+#include <intrinsics.h>

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* Type definitions. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	__disable_interrupt()

+#define portENABLE_INTERRUPTS()		__enable_interrupt()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/STR91x/ISR_Support.h b/FreeRTOS/Source/portable/IAR/STR91x/ISR_Support.h
new file mode 100644
index 0000000..70f96d2
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR91x/ISR_Support.h
@@ -0,0 +1,144 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+	EXTERN pxCurrentTCB

+	EXTERN ulCriticalNesting

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+	; Push R0 as we are going to use the register. 					

+	STMDB	SP!, {R0}

+

+	; Set R0 to point to the task stack pointer. 					

+	STMDB	SP, {SP}^

+	NOP

+	SUB		SP, SP, #4

+	LDMIA	SP!, {R0}

+

+	; Push the return address onto the stack. 						

+	STMDB	R0!, {LR}

+

+	; Now we have saved LR we can use it instead of R0. 				

+	MOV		LR, R0

+

+	; Pop R0 so we can save it onto the system mode stack. 			

+	LDMIA	SP!, {R0}

+

+	; Push all the system mode registers onto the task stack. 		

+	STMDB	LR, {R0-LR}^

+	NOP

+	SUB		LR, LR, #60

+

+	; Push the SPSR onto the task stack. 							

+	MRS		R0, SPSR

+	STMDB	LR!, {R0}

+

+	LDR		R0, =ulCriticalNesting 

+	LDR		R0, [R0]

+	STMDB	LR!, {R0}

+

+	; Store the new top of stack for the task. 						

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	STR		LR, [R0]

+

+	ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+	; Set the LR to the task stack. 									

+	LDR		R1, =pxCurrentTCB

+	LDR		R0, [R1]

+	LDR		LR, [R0]

+

+	; The critical nesting depth is the first item on the stack. 	

+	; Load it into the ulCriticalNesting variable. 					

+	LDR		R0, =ulCriticalNesting

+	LDMFD	LR!, {R1}

+	STR		R1, [R0]

+

+	; Get the SPSR from the stack. 									

+	LDMFD	LR!, {R0}

+	MSR		SPSR_cxsf, R0

+

+	; Restore all system mode registers for the task. 				

+	LDMFD	LR, {R0-R14}^

+	NOP

+

+	; Restore the return address. 									

+	LDR		LR, [LR, #+60]

+

+	; And return - correcting the offset in the LR to obtain the 	

+	; correct address. 												

+	SUBS	PC, LR, #4

+

+	ENDM

+

diff --git a/FreeRTOS/Source/portable/IAR/STR91x/port.c b/FreeRTOS/Source/portable/IAR/STR91x/port.c
new file mode 100644
index 0000000..9ff6313
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR91x/port.c
@@ -0,0 +1,470 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ST STR91x ARM9

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include "91x_lib.h"

+

+/* Standard includes. */

+#include <stdlib.h>

+#include <assert.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#ifndef configUSE_WATCHDOG_TICK

+	#error configUSE_WATCHDOG_TICK must be set to either 1 or 0 in FreeRTOSConfig.h to use either the Watchdog or timer 2 to generate the tick interrupt respectively.

+#endif

+

+/* Constants required to setup the initial stack. */

+#ifndef _RUN_TASK_IN_ARM_MODE_

+	#define portINITIAL_SPSR			( ( portSTACK_TYPE ) 0x3f ) /* System mode, THUMB mode, interrupts enabled. */

+#else

+	#define portINITIAL_SPSR 			( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#endif

+

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+

+/* Constants required to handle critical sections. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+#ifndef abs

+	#define abs(x) ((x)>0 ? (x) : -(x))

+#endif

+

+/**

+ * Toggle a led using the following algorithm:

+ * if ( GPIO_ReadBit(GPIO9, GPIO_Pin_2) )

+ * {

+ *   GPIO_WriteBit( GPIO9, GPIO_Pin_2, Bit_RESET );

+ * }

+ * else

+ * {

+ *   GPIO_WriteBit( GPIO9, GPIO_Pin_2, Bit_RESET );

+ * }

+ *

+ */

+#define TOGGLE_LED(port,pin) 									\

+	if ( ((((port)->DR[(pin)<<2])) & (pin)) != Bit_RESET ) 		\

+	{															\

+    	(port)->DR[(pin) <<2] = 0x00;							\

+  	}															\

+  	else														\

+	{															\

+    	(port)->DR[(pin) <<2] = (pin);							\

+  	}

+

+

+/*-----------------------------------------------------------*/

+

+/* Setup the watchdog to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* ulCriticalNesting will get set to zero when the first task starts.  It

+cannot be initialised to 0 as this will cause interrupts to be enabled

+during the kernel initialisation process. */

+unsigned long ulCriticalNesting = ( unsigned long ) 9999;

+

+/* Tick interrupt routines for cooperative and preemptive operation

+respectively.  The preemptive version is not defined as __irq as it is called

+from an asm wrapper function. */

+void WDG_IRQHandler( void );

+

+/* VIC interrupt default handler. */

+static void prvDefaultHandler( void );

+

+#if configUSE_WATCHDOG_TICK == 0

+	/* Used to update the OCR timer register */

+	static u16 s_nPulseLength;

+#endif

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Initialise the stack of a task to look exactly as if a call to

+ * portSAVE_CONTEXT had been called.

+ *

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	portSTACK_TYPE *pxOriginalTOS;

+

+	pxOriginalTOS = pxTopOfStack;

+

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as

+	expected by the portRESTORE_CONTEXT() macro. */

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+

+	/* When the task starts is will expect to find the function parameter in

+	R0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The status register is set for system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+	pxTopOfStack--;

+

+	/* Interrupt flags cannot always be stored on the stack and will

+	instead be stored in a variable, which is then saved as part of the

+	tasks context. */

+	*pxTopOfStack = portNO_CRITICAL_NESTING;

+

+	return pxTopOfStack;	

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task. */

+	vPortStartFirstTask();	

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+/* This function is called from an asm wrapper, so does not require the __irq

+keyword. */

+#if configUSE_WATCHDOG_TICK == 1

+

+	static void prvFindFactors(u32 n, u16 *a, u32 *b)

+	{

+		/* This function is copied from the ST STR7 library and is

+		copyright STMicroelectronics.  Reproduced with permission. */

+	

+		u32 b0;

+		u16 a0;

+		long err, err_min=n;

+	

+		*a = a0 = ((n-1)/65536ul) + 1;

+		*b = b0 = n / *a;

+	

+		for (; *a <= 256; (*a)++)

+		{

+			*b = n / *a;

+			err = (long)*a * (long)*b - (long)n;

+			if (abs(err) > (*a / 2))

+			{

+				(*b)++;

+				err = (long)*a * (long)*b - (long)n;

+			}

+			if (abs(err) < abs(err_min))

+			{

+				err_min = err;

+				a0 = *a;

+				b0 = *b;

+				if (err == 0) break;

+			}

+		}

+	

+		*a = a0;

+		*b = b0;

+	}

+	/*-----------------------------------------------------------*/

+

+	static void prvSetupTimerInterrupt( void )

+	{

+	WDG_InitTypeDef xWdg;

+	unsigned short a;

+	unsigned long n = configCPU_PERIPH_HZ / configTICK_RATE_HZ, b;

+	

+		/* Configure the watchdog as a free running timer that generates a

+		periodic interrupt. */

+	

+		SCU_APBPeriphClockConfig( __WDG, ENABLE );

+		WDG_DeInit();

+		WDG_StructInit(&xWdg);

+		prvFindFactors( n, &a, &b );

+		xWdg.WDG_Prescaler = a - 1;

+		xWdg.WDG_Preload = b - 1;

+		WDG_Init( &xWdg );

+		WDG_ITConfig(ENABLE);

+		

+		/* Configure the VIC for the WDG interrupt. */

+		VIC_Config( WDG_ITLine, VIC_IRQ, 10 );

+		VIC_ITCmd( WDG_ITLine, ENABLE );

+		

+		/* Install the default handlers for both VIC's. */

+		VIC0->DVAR = ( unsigned long ) prvDefaultHandler;

+		VIC1->DVAR = ( unsigned long ) prvDefaultHandler;

+		

+		WDG_Cmd(ENABLE);

+	}

+	/*-----------------------------------------------------------*/

+

+	void WDG_IRQHandler( void )

+	{

+		{

+			/* Increment the tick counter. */

+			vTaskIncrementTick();

+		

+			#if configUSE_PREEMPTION == 1

+			{

+				/* The new tick value might unblock a task.  Ensure the highest task that

+				is ready to execute is the task that will execute when the tick ISR

+				exits. */

+				vTaskSwitchContext();

+			}

+			#endif /* configUSE_PREEMPTION. */

+		

+			/* Clear the interrupt in the watchdog. */

+			WDG->SR &= ~0x0001;

+		}

+	}

+

+#else

+

+	static void prvFindFactors(u32 n, u8 *a, u16 *b)

+	{

+		/* This function is copied from the ST STR7 library and is

+		copyright STMicroelectronics.  Reproduced with permission. */

+	

+		u16 b0;

+		u8 a0;

+		long err, err_min=n;

+	

+	

+		*a = a0 = ((n-1)/256) + 1;

+		*b = b0 = n / *a;

+	

+		for (; *a <= 256; (*a)++)

+		{

+			*b = n / *a;

+			err = (long)*a * (long)*b - (long)n;

+			if (abs(err) > (*a / 2))

+			{

+				(*b)++;

+				err = (long)*a * (long)*b - (long)n;

+			}

+			if (abs(err) < abs(err_min))

+			{

+				err_min = err;

+				a0 = *a;

+				b0 = *b;

+				if (err == 0) break;

+			}

+		}

+	

+		*a = a0;

+		*b = b0;

+	}

+	/*-----------------------------------------------------------*/

+

+	static void prvSetupTimerInterrupt( void )

+	{

+		unsigned char a;

+		unsigned short b;

+		unsigned long n = configCPU_PERIPH_HZ / configTICK_RATE_HZ;

+		

+		TIM_InitTypeDef timer;

+		

+		SCU_APBPeriphClockConfig( __TIM23, ENABLE );

+		TIM_DeInit(TIM2);

+		TIM_StructInit(&timer);

+		prvFindFactors( n, &a, &b );

+		

+		timer.TIM_Mode           = TIM_OCM_CHANNEL_1;

+		timer.TIM_OC1_Modes      = TIM_TIMING;

+		timer.TIM_Clock_Source   = TIM_CLK_APB;

+		timer.TIM_Clock_Edge     = TIM_CLK_EDGE_RISING;

+		timer.TIM_Prescaler      = a-1;

+		timer.TIM_Pulse_Level_1  = TIM_HIGH;

+		timer.TIM_Pulse_Length_1 = s_nPulseLength  = b-1;

+		

+		TIM_Init (TIM2, &timer);

+		TIM_ITConfig(TIM2, TIM_IT_OC1, ENABLE);

+		/* Configure the VIC for the WDG interrupt. */

+		VIC_Config( TIM2_ITLine, VIC_IRQ, 10 );

+		VIC_ITCmd( TIM2_ITLine, ENABLE );

+		

+		/* Install the default handlers for both VIC's. */

+		VIC0->DVAR = ( unsigned long ) prvDefaultHandler;

+		VIC1->DVAR = ( unsigned long ) prvDefaultHandler;

+		

+		TIM_CounterCmd(TIM2, TIM_CLEAR);

+		TIM_CounterCmd(TIM2, TIM_START);

+	}

+	/*-----------------------------------------------------------*/

+

+	void TIM2_IRQHandler( void )

+	{

+		/* Reset the timer counter to avioid overflow. */

+		TIM2->OC1R += s_nPulseLength;

+		

+		/* Increment the tick counter. */

+		vTaskIncrementTick();

+		

+		#if configUSE_PREEMPTION == 1

+		{

+			/* The new tick value might unblock a task.  Ensure the highest task that

+			is ready to execute is the task that will execute when the tick ISR

+			exits. */

+			vTaskSwitchContext();

+		}

+		#endif

+		

+		/* Clear the interrupt in the watchdog. */

+		TIM2->SR &= ~TIM_FLAG_OC1;

+	}

+

+#endif /* USE_WATCHDOG_TICK */

+

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortEnterCritical( void )

+{

+	/* Disable interrupts first! */

+	portDISABLE_INTERRUPTS();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+__arm __interwork void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			portENABLE_INTERRUPTS();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvDefaultHandler( void )

+{

+}

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/IAR/STR91x/portasm.s79 b/FreeRTOS/Source/portable/IAR/STR91x/portasm.s79
new file mode 100644
index 0000000..8b2cb56
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR91x/portasm.s79
@@ -0,0 +1,99 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+		RSEG ICODE:CODE

+		CODE32

+

+	EXTERN vTaskSwitchContext

+

+	PUBLIC vPortYieldProcessor

+	PUBLIC vPortStartFirstTask

+

+#include "ISR_Support.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is just a matter of restoring the context that

+; was created by pxPortInitialiseStack().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask:

+	portRESTORE_CONTEXT

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Manual context switch function.  This is the SWI hander.

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortYieldProcessor:

+	ADD		LR, LR, #4			; Add 4 to the LR to make the LR appear exactly

+								; as if the context was saved during and IRQ

+								; handler.

+								

+	portSAVE_CONTEXT			; Save the context of the current task...

+	LDR R0, =vTaskSwitchContext	; before selecting the next task to execute.

+	MOV     lr, pc

+	BX R0

+	portRESTORE_CONTEXT			; Restore the context of the selected task.

+

+	END

+

diff --git a/FreeRTOS/Source/portable/IAR/STR91x/portmacro.h b/FreeRTOS/Source/portable/IAR/STR91x/portmacro.h
new file mode 100644
index 0000000..1f924a7
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/STR91x/portmacro.h
@@ -0,0 +1,148 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * Port specific definitions.

+ *

+ * The settings in this file configure FreeRTOS correctly for the

+ * given hardware and compiler.

+ *

+ * These settings should not be altered.

+ *-----------------------------------------------------------

+ */

+

+#include <intrinsics.h>

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* Type definitions. */

+#define portCHAR			char

+#define portFLOAT			float

+#define portDOUBLE			double

+#define portLONG			long

+#define portSHORT			short

+#define portSTACK_TYPE		unsigned portLONG

+#define portBASE_TYPE		portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT			8

+#define portYIELD()					asm ( "SWI 0" )

+#define portNOP()					asm ( "NOP" )

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+__arm __interwork void vPortEnterCritical( void );

+__arm __interwork void vPortExitCritical( void );

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+#define portDISABLE_INTERRUPTS()	__disable_interrupt()

+#define portENABLE_INTERRUPTS()		__enable_interrupt()

+

+

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+#define portEND_SWITCHING_ISR( xSwitchRequired ) 	\

+{													\

+extern void vTaskSwitchContext( void );				\

+													\

+	if( xSwitchRequired ) 							\

+	{												\

+		vTaskSwitchContext();						\

+	}												\

+}

+/*-----------------------------------------------------------*/	

+

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/IAR/V850ES/ISR_Support.h b/FreeRTOS/Source/portable/IAR/V850ES/ISR_Support.h
new file mode 100644
index 0000000..6e18812
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/ISR_Support.h
@@ -0,0 +1,188 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+	EXTERN pxCurrentTCB

+	EXTERN usCriticalNesting

+

+#include "FreeRTOSConfig.h"

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Context save and restore macro definitions

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+portSAVE_CONTEXT MACRO

+

+    add     -0x0C,sp			; prepare stack to save necessary values

+    st.w    lp,8[sp]			; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]			; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]			; store EIPSW to stack

+#if configDATA_MODE == 1                                        ; Using the Tiny data model

+    prepare {r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30},76,sp ; save general purpose registers

+    sst.w   r19,72[ep]

+    sst.w   r18,68[ep]

+    sst.w   r17,64[ep]

+    sst.w   r16,60[ep]

+    sst.w   r15,56[ep]

+    sst.w   r14,52[ep]

+    sst.w   r13,48[ep]

+    sst.w   r12,44[ep]

+    sst.w   r11,40[ep]

+    sst.w   r10,36[ep]

+    sst.w   r9,32[ep]

+    sst.w   r8,28[ep]

+    sst.w   r7,24[ep]

+    sst.w   r6,20[ep]

+    sst.w   r5,16[ep]

+    sst.w   r4,12[ep]

+#else                                                           ; Using the Small/Large data model

+    prepare {r20,r21,r22,r23,r24,r26,r27,r28,r29,r30},72,sp     ; save general purpose registers

+    sst.w   r19,68[ep]

+    sst.w   r18,64[ep]

+    sst.w   r17,60[ep]

+    sst.w   r16,56[ep]

+    sst.w   r15,52[ep]

+    sst.w   r14,48[ep]

+    sst.w   r13,44[ep]

+    sst.w   r12,40[ep]

+    sst.w   r11,36[ep]

+    sst.w   r10,32[ep]

+    sst.w   r9,28[ep]

+    sst.w   r8,24[ep]

+    sst.w   r7,20[ep]

+    sst.w   r6,16[ep]

+    sst.w   r5,12[ep]

+#endif /* configDATA_MODE */

+    sst.w   r2,8[ep]

+    sst.w   r1,4[ep]

+    MOVHI   hi1(usCriticalNesting),r0,r1	; save usCriticalNesting value to stack

+    ld.w    lw1(usCriticalNesting)[r1],r2

+    sst.w   r2,0[ep]

+    MOVHI   hi1(pxCurrentTCB),r0,r1			; save SP to top of current TCB

+    ld.w    lw1(pxCurrentTCB)[r1],r2

+    st.w    sp,0[r2]

+    ENDM

+

+

+portRESTORE_CONTEXT MACRO

+

+    MOVHI   hi1(pxCurrentTCB),r0,r1			; get Stackpointer address

+    ld.w    lw1(pxCurrentTCB)[r1],sp

+    MOV     sp,r1

+    ld.w    0[r1],sp						; load stackpointer

+    MOV     sp,ep							; set stack pointer to element pointer

+    sld.w   0[ep],r1						; load usCriticalNesting value from stack

+    MOVHI   hi1(usCriticalNesting),r0,r2

+    st.w    r1,lw1(usCriticalNesting)[r2]

+    sld.w   4[ep],r1						; restore general purpose registers

+    sld.w   8[ep],r2

+#if configDATA_MODE == 1					; Using Tiny data model

+    sld.w   12[ep],r4

+    sld.w   16[ep],r5

+    sld.w   20[ep],r6

+    sld.w   24[ep],r7

+    sld.w   28[ep],r8

+    sld.w   32[ep],r9

+    sld.w   36[ep],r10

+    sld.w   40[ep],r11

+    sld.w   44[ep],r12

+    sld.w   48[ep],r13

+    sld.w   52[ep],r14

+    sld.w   56[ep],r15

+    sld.w   60[ep],r16

+    sld.w   64[ep],r17

+    sld.w   68[ep],r18

+    sld.w   72[ep],r19

+    dispose 76,{r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30}

+#else										; Using Small/Large data model

+    sld.w   12[ep],r5

+    sld.w   16[ep],r6

+    sld.w   20[ep],r7

+    sld.w   24[ep],r8

+    sld.w   28[ep],r9

+    sld.w   32[ep],r10

+    sld.w   36[ep],r11

+    sld.w   40[ep],r12

+    sld.w   44[ep],r13

+    sld.w   48[ep],r14

+    sld.w   52[ep],r15

+    sld.w   56[ep],r16

+    sld.w   60[ep],r17

+    sld.w   64[ep],r18

+    sld.w   68[ep],r19

+    dispose 72,{r20,r21,r22,r23,r24,r26,r27,r28,r29,r30}

+#endif /* configDATA_MODE */

+    ld.w    0[sp],lp						; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp						; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp						; restore LP from stack

+    add     0x0C,sp							; set SP to right position

+

+    RETI

+

+    ENDM

diff --git a/FreeRTOS/Source/portable/IAR/V850ES/port.c b/FreeRTOS/Source/portable/IAR/V850ES/port.c
new file mode 100644
index 0000000..d93bfbb
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/port.c
@@ -0,0 +1,222 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Critical nesting should be initialised to a non zero value so interrupts don't

+accidentally get enabled before the scheduler is started. */

+#define portINITIAL_CRITICAL_NESTING  (( portSTACK_TYPE ) 10)

+

+/* The PSW value assigned to tasks when they start to run for the first time. */

+#define portPSW		  (( portSTACK_TYPE ) 0x00000000)

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Keeps track of the nesting level of critical sections. */

+volatile portSTACK_TYPE usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+/* Sets up the timer to generate the tick interrupt. */

+static void prvSetupTimerInterrupt( void );

+

+/*-----------------------------------------------------------*/

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;          /* Task function start address */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;          /* Task function start address */

+	pxTopOfStack--;

+	*pxTopOfStack = portPSW;                            /* Initial PSW value */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x20202020;      /* Initial Value of R20 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x21212121;      /* Initial Value of R21 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22222222;      /* Initial Value of R22 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x23232323;      /* Initial Value of R23 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x24242424;      /* Initial Value of R24 */

+	pxTopOfStack--;

+#if (__DATA_MODEL__ == 0) || (__DATA_MODEL__ == 1)

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x25252525;      /* Initial Value of R25 */

+	pxTopOfStack--;

+#endif /* configDATA_MODE */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x26262626;      /* Initial Value of R26 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x27272727;      /* Initial Value of R27 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x28282828;      /* Initial Value of R28 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x29292929;      /* Initial Value of R29 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x30303030;      /* Initial Value of R30 */

+	pxTopOfStack--; 	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x19191919;      /* Initial Value of R19 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x18181818;      /* Initial Value of R18 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x17171717;      /* Initial Value of R17 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x16161616;      /* Initial Value of R16 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x15151515;      /* Initial Value of R15 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x14141414;      /* Initial Value of R14 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x13131313;      /* Initial Value of R13 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;      /* Initial Value of R12 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;      /* Initial Value of R11 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;      /* Initial Value of R10 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x99999999;      /* Initial Value of R09 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x88888888;      /* Initial Value of R08 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x77777777;      /* Initial Value of R07 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x66666666;      /* Initial Value of R06 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x55555555;      /* Initial Value of R05 */

+	pxTopOfStack--;

+#if __DATA_MODEL__ == 0 || __DATA_MODEL__ == 1

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x44444444;      /* Initial Value of R04 */

+	pxTopOfStack--;

+#endif /* configDATA_MODE */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22222222;      /* Initial Value of R02 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;    /* R1 is expected to hold the function parameter*/

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/*

+	 * Return a pointer to the top of the stack we have generated so this can

+	 * be stored in the task control block for the task.

+	 */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick.  Interrupts are disabled when

+	this function is called. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	vPortStart();

+

+	/* Should not get here as the tasks are now running! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the V850ES/Fx3 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.  This uses

+ */

+static void prvSetupTimerInterrupt( void )

+{

+	TM0CE     = 0;	/* TMM0 operation disable */

+	TM0EQMK0  = 1;	/* INTTM0EQ0 interrupt disable */

+	TM0EQIF0  = 0;	/* clear INTTM0EQ0 interrupt flag */

+

+	#ifdef __IAR_V850ES_Fx3__

+	{

+		TM0CMP0   = (((configCPU_CLOCK_HZ / configTICK_RATE_HZ) / 2)-1);    /* divided by 2 because peripherals only run at CPU_CLOCK/2 */

+	}

+	#else

+	{

+		TM0CMP0   = (configCPU_CLOCK_HZ / configTICK_RATE_HZ);	

+	}

+	#endif

+

+	TM0EQIC0 &= 0xF8;

+	TM0CTL0   = 0x00;

+	TM0EQIF0 =  0;	/* clear INTTM0EQ0 interrupt flag */

+	TM0EQMK0 =  0;	/* INTTM0EQ0 interrupt enable */

+	TM0CE =     1;	/* TMM0 operation enable */

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/IAR/V850ES/portasm.s85 b/FreeRTOS/Source/portable/IAR/V850ES/portasm.s85
new file mode 100644
index 0000000..b2d2d63
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/portasm.s85
@@ -0,0 +1,341 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+; Note: Select the correct include files for the device used by the application.

+#include "FreeRTOSConfig.h"

+;------------------------------------------------------------------------------

+

+; Functions used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    vTaskSwitchContext

+    EXTERN    vTaskIncrementTick

+

+; Variables used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    pxCurrentTCB

+    EXTERN    usCriticalNesting

+

+; Functions implemented in this file

+;------------------------------------------------------------------------------

+    PUBLIC    vPortYield

+    PUBLIC    vPortStart

+

+; Security ID definition

+;------------------------------------------------------------------------------

+#define	CG_SECURITY0	0FFH

+#define	CG_SECURITY1	0FFH

+#define	CG_SECURITY2	0FFH

+#define	CG_SECURITY3	0FFH

+#define	CG_SECURITY4	0FFH

+#define	CG_SECURITY5	0FFH

+#define	CG_SECURITY6	0FFH

+#define	CG_SECURITY7	0FFH

+#define	CG_SECURITY8	0FFH

+#define	CG_SECURITY9	0FFH

+

+; Tick ISR Prototype

+;------------------------------------------------------------------------------

+        PUBWEAK `??MD_INTTM0EQ0??INTVEC 640`

+        PUBLIC MD_INTTM0EQ0

+

+MD_INTTM0EQ0        SYMBOL "MD_INTTM0EQ0"

+`??MD_INTTM0EQ0??INTVEC 640` SYMBOL "??INTVEC 640", MD_INTTM0EQ0

+

+;------------------------------------------------------------------------------

+;   portSAVE_CONTEXT MACRO

+;   Saves the context of the remaining general purpose registers

+;   and the usCriticalNesting Value of the active Task onto the task stack

+;   saves stack pointer to the TCB

+;------------------------------------------------------------------------------

+portSAVE_CONTEXT MACRO

+#if configDATA_MODE == 1                                        ; Using the Tiny data model

+    prepare {r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30},76,sp ; save general purpose registers

+    sst.w   r19,72[ep]

+    sst.w   r18,68[ep]

+    sst.w   r17,64[ep]

+    sst.w   r16,60[ep]

+    sst.w   r15,56[ep]

+    sst.w   r14,52[ep]

+    sst.w   r13,48[ep]

+    sst.w   r12,44[ep]

+    sst.w   r11,40[ep]

+    sst.w   r10,36[ep]

+    sst.w   r9,32[ep]

+    sst.w   r8,28[ep]

+    sst.w   r7,24[ep]

+    sst.w   r6,20[ep]

+    sst.w   r5,16[ep]

+    sst.w   r4,12[ep]

+#else                                                           ; Using the Small/Large data model

+    prepare {r20,r21,r22,r23,r24,r26,r27,r28,r29,r30},72,sp     ; save general purpose registers

+    sst.w   r19,68[ep]

+    sst.w   r18,64[ep]

+    sst.w   r17,60[ep]

+    sst.w   r16,56[ep]

+    sst.w   r15,52[ep]

+    sst.w   r14,48[ep]

+    sst.w   r13,44[ep]

+    sst.w   r12,40[ep]

+    sst.w   r11,36[ep]

+    sst.w   r10,32[ep]

+    sst.w   r9,28[ep]

+    sst.w   r8,24[ep]

+    sst.w   r7,20[ep]

+    sst.w   r6,16[ep]

+    sst.w   r5,12[ep]

+#endif /* configDATA_MODE */

+    sst.w   r2,8[ep]

+    sst.w   r1,4[ep]

+    MOVHI   hi1(usCriticalNesting),r0,r1                        ; save usCriticalNesting value to stack

+    ld.w    lw1(usCriticalNesting)[r1],r2

+    sst.w   r2,0[ep]

+    MOVHI   hi1(pxCurrentTCB),r0,r1                             ; save SP to top of current TCB

+    ld.w    lw1(pxCurrentTCB)[r1],r2

+    st.w    sp,0[r2]

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   portRESTORE_CONTEXT MACRO

+;   Gets stack pointer from the current TCB

+;   Restores the context of the usCriticalNesting value and general purpose

+;   registers of the selected task from the task stack

+;------------------------------------------------------------------------------

+portRESTORE_CONTEXT MACRO

+    MOVHI   hi1(pxCurrentTCB),r0,r1         ; get Stackpointer address

+    ld.w    lw1(pxCurrentTCB)[r1],sp

+    MOV     sp,r1

+    ld.w    0[r1],sp                        ; load stackpointer

+    MOV     sp,ep                           ; set stack pointer to element pointer

+    sld.w   0[ep],r1                        ; load usCriticalNesting value from stack

+    MOVHI   hi1(usCriticalNesting),r0,r2

+    st.w    r1,lw1(usCriticalNesting)[r2]

+    sld.w   4[ep],r1                        ; restore general purpose registers

+    sld.w   8[ep],r2

+#if configDATA_MODE == 1                    ; Using Tiny data model

+    sld.w   12[ep],r4

+    sld.w   16[ep],r5

+    sld.w   20[ep],r6

+    sld.w   24[ep],r7

+    sld.w   28[ep],r8

+    sld.w   32[ep],r9

+    sld.w   36[ep],r10

+    sld.w   40[ep],r11

+    sld.w   44[ep],r12

+    sld.w   48[ep],r13

+    sld.w   52[ep],r14

+    sld.w   56[ep],r15

+    sld.w   60[ep],r16

+    sld.w   64[ep],r17

+    sld.w   68[ep],r18

+    sld.w   72[ep],r19

+    dispose 76,{r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30}

+#else                                       ; Using Small/Large data model

+    sld.w   12[ep],r5

+    sld.w   16[ep],r6

+    sld.w   20[ep],r7

+    sld.w   24[ep],r8

+    sld.w   28[ep],r9

+    sld.w   32[ep],r10

+    sld.w   36[ep],r11

+    sld.w   40[ep],r12

+    sld.w   44[ep],r13

+    sld.w   48[ep],r14

+    sld.w   52[ep],r15

+    sld.w   56[ep],r16

+    sld.w   60[ep],r17

+    sld.w   64[ep],r18

+    sld.w   68[ep],r19

+    dispose 72,{r20,r21,r22,r23,r24,r26,r27,r28,r29,r30}

+#endif /* configDATA_MODE */

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Restore the context of the first task that is going to run.

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortStart

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+    RSEG CODE:CODE

+vPortStart:

+    portRESTORE_CONTEXT	                    ; Restore the context of whichever task the ...

+    ld.w    0[sp],lp

+    ldsr    lp,5                            ; restore PSW

+    DI

+    ld.w    4[sp],lp                        ; restore LP

+    ld.w    8[sp],lp                        ; restore LP

+    ADD     0x0C,sp                         ; set SP to right position

+    EI

+    jmp     [lp]

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Port Yield function to check for a Task switch in the cooperative and

+;   preemptive mode

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortYield

+;

+;   Output: NONE

+;------------------------------------------------------------------------------

+

+	RSEG CODE:CODE

+vPortYield:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+	ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Perform the necessary steps of the Tick Count Increment and Task Switch

+;   depending on the chosen kernel configuration

+;

+;   Input:  NONE

+;

+;   Call:   ISR

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+#if configUSE_PREEMPTION == 1               ; use preemptive kernel mode

+

+MD_INTTM0EQ0:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+    ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+;------------------------------------------------------------------------------

+#else                                       ; use cooperative kernel mode

+

+MD_INTTM0EQ0:

+    prepare {lp,ep},8,sp

+    sst.w   r1,4[ep]

+    sst.w   r5,0[ep]

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    sld.w   0[ep],r5

+    sld.w   4[ep],r1

+    dispose 8,{lp,ep}

+    RETI

+#endif /* configUSE_PREEMPTION */

+

+;------------------------------------------------------------------------------

+        COMMON INTVEC:CODE:ROOT(2)

+        ORG 640

+`??MD_INTTM0EQ0??INTVEC 640`:

+        JR MD_INTTM0EQ0

+

+        RSEG NEAR_ID:CONST:SORT:NOROOT(2)

+`?<Initializer for usCriticalNesting>`:

+        DW 10

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 40H

+`??vPortYield??INTVEC 40`:

+        JR vPortYield

+

+;------------------------------------------------------------------------------

+; set microcontroller security ID

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 70H

+`SECUID`:

+      DB CG_SECURITY0

+      DB CG_SECURITY1

+      DB CG_SECURITY2

+      DB CG_SECURITY3

+      DB CG_SECURITY4

+      DB CG_SECURITY5

+      DB CG_SECURITY6

+      DB CG_SECURITY7

+      DB CG_SECURITY8

+      DB CG_SECURITY9

+

+

+      END

+

diff --git a/FreeRTOS/Source/portable/IAR/V850ES/portasm_Fx3.s85 b/FreeRTOS/Source/portable/IAR/V850ES/portasm_Fx3.s85
new file mode 100644
index 0000000..7153400
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/portasm_Fx3.s85
@@ -0,0 +1,361 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+; Note: Select the correct include files for the device used by the application.

+#include "FreeRTOSConfig.h"

+;------------------------------------------------------------------------------

+

+; Functions used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    vTaskSwitchContext

+    EXTERN    vTaskIncrementTick

+

+; Variables used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    pxCurrentTCB

+    EXTERN    usCriticalNesting

+

+; Functions implemented in this file

+;------------------------------------------------------------------------------

+    PUBLIC    vPortYield

+    PUBLIC    vPortStart

+

+; Security ID definition

+;------------------------------------------------------------------------------

+#define	CG_SECURITY0	0FFH

+#define	CG_SECURITY1	0FFH

+#define	CG_SECURITY2	0FFH

+#define	CG_SECURITY3	0FFH

+#define	CG_SECURITY4	0FFH

+#define	CG_SECURITY5	0FFH

+#define	CG_SECURITY6	0FFH

+#define	CG_SECURITY7	0FFH

+#define	CG_SECURITY8	0FFH

+#define	CG_SECURITY9	0FFH

+

+; Option Byte definitions

+;------------------------------------------------------------------------------

+#define	CG_OPTION7A	0x00

+#define	CG_OPTION7B	0x04

+#define	OPT7C		0x00

+#define	OPT7D		0x00

+#define	OPT7E		0x00

+#define	OPT7F		0x00

+

+; Tick ISR Prototype

+;------------------------------------------------------------------------------

+        PUBWEAK `??MD_INTTM0EQ0??INTVEC 608`

+        PUBLIC MD_INTTM0EQ0

+

+MD_INTTM0EQ0        SYMBOL "MD_INTTM0EQ0"

+`??MD_INTTM0EQ0??INTVEC 608` SYMBOL "??INTVEC 608", MD_INTTM0EQ0

+

+;------------------------------------------------------------------------------

+;   portSAVE_CONTEXT MACRO

+;   Saves the context of the remaining general purpose registers

+;   and the usCriticalNesting Value of the active Task onto the task stack

+;   saves stack pointer to the TCB

+;------------------------------------------------------------------------------

+portSAVE_CONTEXT MACRO

+#if configDATA_MODE == 1                                        ; Using the Tiny data model

+    prepare {r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30},76,sp ; save general purpose registers

+    sst.w   r19,72[ep]

+    sst.w   r18,68[ep]

+    sst.w   r17,64[ep]

+    sst.w   r16,60[ep]

+    sst.w   r15,56[ep]

+    sst.w   r14,52[ep]

+    sst.w   r13,48[ep]

+    sst.w   r12,44[ep]

+    sst.w   r11,40[ep]

+    sst.w   r10,36[ep]

+    sst.w   r9,32[ep]

+    sst.w   r8,28[ep]

+    sst.w   r7,24[ep]

+    sst.w   r6,20[ep]

+    sst.w   r5,16[ep]

+    sst.w   r4,12[ep]

+#else                                                           ; Using the Small/Large data model

+    prepare {r20,r21,r22,r23,r24,r26,r27,r28,r29,r30},72,sp     ; save general purpose registers

+    sst.w   r19,68[ep]

+    sst.w   r18,64[ep]

+    sst.w   r17,60[ep]

+    sst.w   r16,56[ep]

+    sst.w   r15,52[ep]

+    sst.w   r14,48[ep]

+    sst.w   r13,44[ep]

+    sst.w   r12,40[ep]

+    sst.w   r11,36[ep]

+    sst.w   r10,32[ep]

+    sst.w   r9,28[ep]

+    sst.w   r8,24[ep]

+    sst.w   r7,20[ep]

+    sst.w   r6,16[ep]

+    sst.w   r5,12[ep]

+#endif /* configDATA_MODE */

+    sst.w   r2,8[ep]

+    sst.w   r1,4[ep]

+    MOVHI   hi1(usCriticalNesting),r0,r1                        ; save usCriticalNesting value to stack

+    ld.w    lw1(usCriticalNesting)[r1],r2

+    sst.w   r2,0[ep]

+    MOVHI   hi1(pxCurrentTCB),r0,r1                             ; save SP to top of current TCB

+    ld.w    lw1(pxCurrentTCB)[r1],r2

+    st.w    sp,0[r2]

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   portRESTORE_CONTEXT MACRO

+;   Gets stack pointer from the current TCB

+;   Restores the context of the usCriticalNesting value and general purpose

+;   registers of the selected task from the task stack

+;------------------------------------------------------------------------------

+portRESTORE_CONTEXT MACRO

+    MOVHI   hi1(pxCurrentTCB),r0,r1         ; get Stackpointer address

+    ld.w    lw1(pxCurrentTCB)[r1],sp

+    MOV     sp,r1

+    ld.w    0[r1],sp                        ; load stackpointer

+    MOV     sp,ep                           ; set stack pointer to element pointer

+    sld.w   0[ep],r1                        ; load usCriticalNesting value from stack

+    MOVHI   hi1(usCriticalNesting),r0,r2

+    st.w    r1,lw1(usCriticalNesting)[r2]

+    sld.w   4[ep],r1                        ; restore general purpose registers

+    sld.w   8[ep],r2

+#if configDATA_MODE == 1                    ; Using Tiny data model

+    sld.w   12[ep],r4

+    sld.w   16[ep],r5

+    sld.w   20[ep],r6

+    sld.w   24[ep],r7

+    sld.w   28[ep],r8

+    sld.w   32[ep],r9

+    sld.w   36[ep],r10

+    sld.w   40[ep],r11

+    sld.w   44[ep],r12

+    sld.w   48[ep],r13

+    sld.w   52[ep],r14

+    sld.w   56[ep],r15

+    sld.w   60[ep],r16

+    sld.w   64[ep],r17

+    sld.w   68[ep],r18

+    sld.w   72[ep],r19

+    dispose 76,{r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30}

+#else                                       ; Using Small/Large data model

+    sld.w   12[ep],r5

+    sld.w   16[ep],r6

+    sld.w   20[ep],r7

+    sld.w   24[ep],r8

+    sld.w   28[ep],r9

+    sld.w   32[ep],r10

+    sld.w   36[ep],r11

+    sld.w   40[ep],r12

+    sld.w   44[ep],r13

+    sld.w   48[ep],r14

+    sld.w   52[ep],r15

+    sld.w   56[ep],r16

+    sld.w   60[ep],r17

+    sld.w   64[ep],r18

+    sld.w   68[ep],r19

+    dispose 72,{r20,r21,r22,r23,r24,r26,r27,r28,r29,r30}

+#endif /* configDATA_MODE */

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Restore the context of the first task that is going to run.

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortStart

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+    RSEG CODE:CODE

+vPortStart:

+    portRESTORE_CONTEXT	                    ; Restore the context of whichever task the ...

+    ld.w    0[sp],lp

+    ldsr    lp,5                            ; restore PSW

+    DI

+    ld.w    4[sp],lp                        ; restore LP

+    ld.w    8[sp],lp                        ; restore LP

+    ADD     0x0C,sp                         ; set SP to right position

+    EI

+    jmp     [lp]

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Port Yield function to check for a Task switch in the cooperative and

+;   preemptive mode

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortYield

+;

+;   Output: NONE

+;------------------------------------------------------------------------------

+

+	RSEG CODE:CODE

+vPortYield:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+	ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Perform the necessary steps of the Tick Count Increment and Task Switch

+;   depending on the chosen kernel configuration

+;

+;   Input:  NONE

+;

+;   Call:   ISR

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+#if configUSE_PREEMPTION == 1               ; use preemptive kernel mode

+

+MD_INTTM0EQ0:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+    ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+;------------------------------------------------------------------------------

+#else                                       ; use cooperative kernel mode

+

+MD_INTTM0EQ0:

+    prepare {lp,ep},8,sp

+    sst.w   r1,4[ep]

+    sst.w   r5,0[ep]

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    sld.w   0[ep],r5

+    sld.w   4[ep],r1

+    dispose 8,{lp,ep}

+    RETI

+#endif /* configUSE_PREEMPTION */

+

+;------------------------------------------------------------------------------

+        COMMON INTVEC:CODE:ROOT(2)

+        ORG 608

+`??MD_INTTM0EQ0??INTVEC 608`:

+        JR MD_INTTM0EQ0

+

+        RSEG NEAR_ID:CONST:SORT:NOROOT(2)

+`?<Initializer for usCriticalNesting>`:

+        DW 10

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 40H

+`??vPortYield??INTVEC 40`:

+        JR vPortYield

+

+;------------------------------------------------------------------------------

+; set microcontroller security ID

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 70H

+`SECUID`:

+      DB CG_SECURITY0

+      DB CG_SECURITY1

+      DB CG_SECURITY2

+      DB CG_SECURITY3

+      DB CG_SECURITY4

+      DB CG_SECURITY5

+      DB CG_SECURITY6

+      DB CG_SECURITY7

+      DB CG_SECURITY8

+      DB CG_SECURITY9

+

+;------------------------------------------------------------------------------

+; set microcontroller option bytes

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 7AH

+`OPTBYTES`:

+      DB CG_OPTION7A

+      DB CG_OPTION7B

+      DB OPT7C

+      DB OPT7D

+      DB OPT7E

+      DB OPT7F

+

+      END
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/IAR/V850ES/portasm_Hx2.s85 b/FreeRTOS/Source/portable/IAR/V850ES/portasm_Hx2.s85
new file mode 100644
index 0000000..8b00794
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/portasm_Hx2.s85
@@ -0,0 +1,376 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+; Note: Select the correct include files for the device used by the application.

+#include "FreeRTOSConfig.h"

+;------------------------------------------------------------------------------

+

+; Functions used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    vTaskSwitchContext

+    EXTERN    vTaskIncrementTick

+

+; Variables used by scheduler

+;------------------------------------------------------------------------------

+    EXTERN    pxCurrentTCB

+    EXTERN    usCriticalNesting

+

+; Functions implemented in this file

+;------------------------------------------------------------------------------

+    PUBLIC    vPortYield

+    PUBLIC    vPortStart

+

+; Security ID definition

+;------------------------------------------------------------------------------

+#define	CG_SECURITY0	0FFH

+#define	CG_SECURITY1	0FFH

+#define	CG_SECURITY2	0FFH

+#define	CG_SECURITY3	0FFH

+#define	CG_SECURITY4	0FFH

+#define	CG_SECURITY5	0FFH

+#define	CG_SECURITY6	0FFH

+#define	CG_SECURITY7	0FFH

+#define	CG_SECURITY8	0FFH

+#define	CG_SECURITY9	0FFH

+

+; Tick ISR Prototype

+;------------------------------------------------------------------------------

+        PUBWEAK `??MD_INTTM0EQ0??INTVEC 544`

+        PUBLIC MD_INTTM0EQ0

+

+MD_INTTM0EQ0        SYMBOL "MD_INTTM0EQ0"

+`??MD_INTTM0EQ0??INTVEC 544` SYMBOL "??INTVEC 544", MD_INTTM0EQ0

+

+;------------------------------------------------------------------------------

+;   portSAVE_CONTEXT MACRO

+;   Saves the context of the remaining general purpose registers

+;   and the usCriticalNesting Value of the active Task onto the task stack

+;   saves stack pointer to the TCB

+;------------------------------------------------------------------------------

+portSAVE_CONTEXT MACRO

+#if configDATA_MODE == 1                                        ; Using the Tiny data model

+    prepare {r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30},76,sp ; save general purpose registers

+    sst.w   r19,72[ep]

+    sst.w   r18,68[ep]

+    sst.w   r17,64[ep]

+    sst.w   r16,60[ep]

+    sst.w   r15,56[ep]

+    sst.w   r14,52[ep]

+    sst.w   r13,48[ep]

+    sst.w   r12,44[ep]

+    sst.w   r11,40[ep]

+    sst.w   r10,36[ep]

+    sst.w   r9,32[ep]

+    sst.w   r8,28[ep]

+    sst.w   r7,24[ep]

+    sst.w   r6,20[ep]

+    sst.w   r5,16[ep]

+    sst.w   r4,12[ep]

+#else                                                           ; Using the Small/Large data model

+    prepare {r20,r21,r22,r23,r24,r26,r27,r28,r29,r30},72,sp     ; save general purpose registers

+    sst.w   r19,68[ep]

+    sst.w   r18,64[ep]

+    sst.w   r17,60[ep]

+    sst.w   r16,56[ep]

+    sst.w   r15,52[ep]

+    sst.w   r14,48[ep]

+    sst.w   r13,44[ep]

+    sst.w   r12,40[ep]

+    sst.w   r11,36[ep]

+    sst.w   r10,32[ep]

+    sst.w   r9,28[ep]

+    sst.w   r8,24[ep]

+    sst.w   r7,20[ep]

+    sst.w   r6,16[ep]

+    sst.w   r5,12[ep]

+#endif /* configDATA_MODE */

+    sst.w   r2,8[ep]

+    sst.w   r1,4[ep]

+    MOVHI   hi1(usCriticalNesting),r0,r1                        ; save usCriticalNesting value to stack

+    ld.w    lw1(usCriticalNesting)[r1],r2

+    sst.w   r2,0[ep]

+    MOVHI   hi1(pxCurrentTCB),r0,r1                             ; save SP to top of current TCB

+    ld.w    lw1(pxCurrentTCB)[r1],r2

+    st.w    sp,0[r2]

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   portRESTORE_CONTEXT MACRO

+;   Gets stack pointer from the current TCB

+;   Restores the context of the usCriticalNesting value and general purpose

+;   registers of the selected task from the task stack

+;------------------------------------------------------------------------------

+portRESTORE_CONTEXT MACRO

+    MOVHI   hi1(pxCurrentTCB),r0,r1         ; get Stackpointer address

+    ld.w    lw1(pxCurrentTCB)[r1],sp

+    MOV     sp,r1

+    ld.w    0[r1],sp                        ; load stackpointer

+    MOV     sp,ep                           ; set stack pointer to element pointer

+    sld.w   0[ep],r1                        ; load usCriticalNesting value from stack

+    MOVHI   hi1(usCriticalNesting),r0,r2

+    st.w    r1,lw1(usCriticalNesting)[r2]

+    sld.w   4[ep],r1                        ; restore general purpose registers

+    sld.w   8[ep],r2

+#if configDATA_MODE == 1                    ; Using Tiny data model

+    sld.w   12[ep],r4

+    sld.w   16[ep],r5

+    sld.w   20[ep],r6

+    sld.w   24[ep],r7

+    sld.w   28[ep],r8

+    sld.w   32[ep],r9

+    sld.w   36[ep],r10

+    sld.w   40[ep],r11

+    sld.w   44[ep],r12

+    sld.w   48[ep],r13

+    sld.w   52[ep],r14

+    sld.w   56[ep],r15

+    sld.w   60[ep],r16

+    sld.w   64[ep],r17

+    sld.w   68[ep],r18

+    sld.w   72[ep],r19

+    dispose 76,{r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30}

+#else                                       ; Using Small/Large data model

+    sld.w   12[ep],r5

+    sld.w   16[ep],r6

+    sld.w   20[ep],r7

+    sld.w   24[ep],r8

+    sld.w   28[ep],r9

+    sld.w   32[ep],r10

+    sld.w   36[ep],r11

+    sld.w   40[ep],r12

+    sld.w   44[ep],r13

+    sld.w   48[ep],r14

+    sld.w   52[ep],r15

+    sld.w   56[ep],r16

+    sld.w   60[ep],r17

+    sld.w   64[ep],r18

+    sld.w   68[ep],r19

+    dispose 72,{r20,r21,r22,r23,r24,r26,r27,r28,r29,r30}

+#endif /* configDATA_MODE */

+    ENDM

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Restore the context of the first task that is going to run.

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortStart

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+    RSEG CODE:CODE

+vPortStart:

+    portRESTORE_CONTEXT	                    ; Restore the context of whichever task the ...

+    ld.w    0[sp],lp

+    ldsr    lp,5                            ; restore PSW

+    DI

+    ld.w    4[sp],lp                        ; restore LP

+    ld.w    8[sp],lp                        ; restore LP

+    ADD     0x0C,sp                         ; set SP to right position

+    EI

+    jmp     [lp]

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Port Yield function to check for a Task switch in the cooperative and

+;   preemptive mode

+;

+;   Input:  NONE

+;

+;   Call:   CALL    vPortYield

+;

+;   Output: NONE

+;------------------------------------------------------------------------------

+

+	RSEG CODE:CODE

+vPortYield:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+	ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+

+;------------------------------------------------------------------------------

+

+;------------------------------------------------------------------------------

+;   Perform the necessary steps of the Tick Count Increment and Task Switch

+;   depending on the chosen kernel configuration

+;

+;   Input:  NONE

+;

+;   Call:   ISR

+;

+;   Output: NONE

+;------------------------------------------------------------------------------	

+#if configUSE_PREEMPTION == 1               ; use preemptive kernel mode

+

+MD_INTTM0EQ0:

+

+    add     -0x0C,sp                          ; prepare stack to save necessary values

+    st.w    lp,8[sp]                        ; store LP to stack

+    stsr    0,r31

+    st.w    lp,4[sp]                        ; store EIPC to stack

+    stsr    1,lp

+    st.w    lp,0[sp]                        ; store EIPSW to stack

+    portSAVE_CONTEXT		            ; Save the context of the current task.

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    jarl    vTaskSwitchContext,lp           ; Call the scheduler.

+    portRESTORE_CONTEXT		            ; Restore the context of whichever task the ...

+                		            ; ... scheduler decided should run.

+    ld.w    0[sp],lp                        ; restore EIPSW from stack

+    ldsr    lp,1

+    ld.w    4[sp],lp                        ; restore EIPC from stack

+    ldsr    lp,0

+    ld.w    8[sp],lp                        ; restore LP from stack

+    add     0x0C,sp                         ; set SP to right position

+

+    RETI

+;------------------------------------------------------------------------------

+#else                                       ; use cooperative kernel mode

+

+MD_INTTM0EQ0:

+    prepare {lp,ep},8,sp

+    sst.w   r1,4[ep]

+    sst.w   r5,0[ep]

+    jarl    vTaskIncrementTick,lp           ; Call the timer tick function.

+    sld.w   0[ep],r5

+    sld.w   4[ep],r1

+    dispose 8,{lp,ep}

+    RETI

+#endif /* configUSE_PREEMPTION */

+

+;------------------------------------------------------------------------------

+        COMMON INTVEC:CODE:ROOT(2)

+        ORG 544

+`??MD_INTTM0EQ0??INTVEC 544`:

+        JR MD_INTTM0EQ0

+

+        RSEG NEAR_ID:CONST:SORT:NOROOT(2)

+`?<Initializer for usCriticalNesting>`:

+        DW 10

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 40H

+`??vPortYield??INTVEC 40`:

+        JR vPortYield

+

+;------------------------------------------------------------------------------

+; set microcontroller security ID

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 70H

+`SECUID`:

+      DB CG_SECURITY0

+      DB CG_SECURITY1

+      DB CG_SECURITY2

+      DB CG_SECURITY3

+      DB CG_SECURITY4

+      DB CG_SECURITY5

+      DB CG_SECURITY6

+      DB CG_SECURITY7

+      DB CG_SECURITY8

+      DB CG_SECURITY9

+

+

+; set microcontroller Option bytes

+

+      COMMON INTVEC:CODE:ROOT(2)

+      ORG 122

+`OPTBYTES`:

+      DB 0xFD

+      DB 0xFF

+      DB 0xFF

+      DB 0xFF

+      DB 0xFF

+      DB 0xFF

+

+#if configOCD_USAGE == 1

+

+      COMMON   INTVEC:CODE:ROOT(4)

+      ORG      0x230

+      PUBLIC ROM_INT2

+ROM_INT2:

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+

+

+      COMMON   INTVEC:CODE:ROOT(4)

+      ORG      0x60

+      PUBLIC   ROM_INT

+ROM_INT:

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+      DB 0xff, 0xff, 0xff, 0xff

+

+#endif /* configOCD_USAGE */

+

+      END

+

diff --git a/FreeRTOS/Source/portable/IAR/V850ES/portmacro.h b/FreeRTOS/Source/portable/IAR/V850ES/portmacro.h
new file mode 100644
index 0000000..cbb52e9
--- /dev/null
+++ b/FreeRTOS/Source/portable/IAR/V850ES/portmacro.h
@@ -0,0 +1,170 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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  unsigned int

+#define portBASE_TYPE   int

+

+

+#if (configUSE_16_BIT_TICKS==1)

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS() __asm ( "DI" )

+#define portENABLE_INTERRUPTS()	 __asm ( "EI" )

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portBASE_TYPE ) 0 )

+

+#define portENTER_CRITICAL()														\

+{																					\

+extern volatile /*unsigned portSHORT*/ portSTACK_TYPE usCriticalNesting;			\

+																					\

+	portDISABLE_INTERRUPTS();														\

+																					\

+	/* Now interrupts are disabled ulCriticalNesting can be accessed */				\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */		\

+	/* times portENTER_CRITICAL() has been called. */								\

+	usCriticalNesting++;															\

+}

+

+#define portEXIT_CRITICAL()															\

+{																					\

+extern volatile /*unsigned portSHORT*/ portSTACK_TYPE usCriticalNesting;			\

+																					\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )						\

+	{																				\

+		/* Decrement the nesting count as we are leaving a critical section. */		\

+		usCriticalNesting--;														\

+																					\

+		/* If the nesting level has reached zero then interrupts should be */		\

+		/* re-enabled. */															\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )					\

+		{																			\

+			portENABLE_INTERRUPTS();												\

+		}																			\

+	}																				\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+extern void vPortYield( void );

+extern void vPortStart( void );

+extern void portSAVE_CONTEXT( void );

+extern void portRESTORE_CONTEXT( void );

+#define portYIELD()	__asm ( "trap 0" )

+#define portNOP()	__asm ( "NOP" )

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) if( xHigherPriorityTaskWoken ) vTaskSwitchContext()

+

+/*-----------------------------------------------------------*/

+

+/* Hardwware specifics. */

+#define portBYTE_ALIGNMENT	4

+#define portSTACK_GROWTH	( -1 )

+#define portTICK_RATE_MS	( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Keil/See-also-the-RVDS-directory.txt b/FreeRTOS/Source/portable/Keil/See-also-the-RVDS-directory.txt
new file mode 100644
index 0000000..bd7fab7
--- /dev/null
+++ b/FreeRTOS/Source/portable/Keil/See-also-the-RVDS-directory.txt
@@ -0,0 +1 @@
+Nothing to see here.
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/MPLAB/PIC18F/port.c b/FreeRTOS/Source/portable/MPLAB/PIC18F/port.c
new file mode 100644
index 0000000..016ce98
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC18F/port.c
@@ -0,0 +1,657 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* 

+Changes between V1.2.4 and V1.2.5

+

+	+ Introduced portGLOBAL_INTERRUPT_FLAG definition to test the global 

+	  interrupt flag setting.  Using the two bits defined within

+	  portINITAL_INTERRUPT_STATE was causing the w register to get clobbered

+	  before the test was performed.

+

+Changes from V1.2.5

+

+	+ Set the interrupt vector address to 0x08.  Previously it was at the

+	  incorrect address for compatibility mode of 0x18.

+

+Changes from V2.1.1

+

+	+ PCLATU and PCLATH are now saved as part of the context.  This allows

+	  function pointers to be used within tasks.  Thanks to Javier Espeche

+	  for the enhancement. 

+

+Changes from V2.3.1

+

+	+ TABLAT is now saved as part of the task context.

+	

+Changes from V3.2.0

+

+	+ TBLPTRU is now initialised to zero as the MPLAB compiler expects this

+	  value and does not write to the register.

+*/

+

+/* Scheduler include files. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* MPLAB library include file. */

+#include "timers.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the PIC port.

+ *----------------------------------------------------------*/

+

+/* Hardware setup for tick. */

+#define portTIMER_FOSC_SCALE			( ( unsigned long ) 4 )

+

+/* Initial interrupt enable state for newly created tasks.  This value is

+copied into INTCON when a task switches in for the first time. */

+#define portINITAL_INTERRUPT_STATE			0xc0

+

+/* Just the bit within INTCON for the global interrupt flag. */

+#define portGLOBAL_INTERRUPT_FLAG			0x80

+

+/* Constant used for context switch macro when we require the interrupt 

+enable state to be unchanged when the interrupted task is switched back in. */

+#define portINTERRUPTS_UNCHANGED			0x00

+

+/* Some memory areas get saved as part of the task context.  These memory

+area's get used by the compiler for temporary storage, especially when 

+performing mathematical operations, or when using 32bit data types.  This

+constant defines the size of memory area which must be saved. */

+#define portCOMPILER_MANAGED_MEMORY_SIZE	( ( unsigned char ) 0x13 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* IO port constants. */

+#define portBIT_SET		( ( unsigned char ) 1 )

+#define portBIT_CLEAR	( ( unsigned char ) 0 )

+

+/*

+ * The serial port ISR's are defined in serial.c, but are called from portable

+ * as they use the same vector as the tick ISR.

+ */

+void vSerialTxISR( void );

+void vSerialRxISR( void );

+

+/*

+ * Perform hardware setup to enable ticks.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * ISR to maintain the tick, and perform tick context switches if the

+ * preemptive scheduler is being used.

+ */

+static void prvTickISR( void );

+

+/*

+ * ISR placed on the low priority vector.  This calls the appropriate ISR for

+ * the actual interrupt.

+ */

+static void prvLowInterrupt( void );

+

+/* 

+ * Macro that pushes all the registers that make up the context of a task onto

+ * the stack, then saves the new top of stack into the TCB.

+ * 

+ * If this is called from an ISR then the interrupt enable bits must have been 

+ * set for the ISR to ever get called.  Therefore we want to save the INTCON

+ * register with the enable bits forced to be set - and ucForcedInterruptFlags 

+ * must contain these bit settings.  This means the interrupts will again be

+ * enabled when the interrupted task is switched back in.

+ *

+ * If this is called from a manual context switch (i.e. from a call to yield),

+ * then we want to save the INTCON so it is restored with its current state,

+ * and ucForcedInterruptFlags must be 0.  This allows a yield from within

+ * a critical section.

+ *

+ * The compiler uses some locations at the bottom of the memory for temporary

+ * storage during math and other computations.  This is especially true if

+ * 32bit data types are utilised (as they are by the scheduler).  The .tmpdata

+ * and MATH_DATA sections have to be stored in there entirety as part of a task

+ * context.  This macro stores from data address 0x00 to 

+ * portCOMPILER_MANAGED_MEMORY_SIZE.  This is sufficient for the demo 

+ * applications but you should check the map file for your project to ensure 

+ * this is sufficient for your needs.  It is not clear whether this size is 

+ * fixed for all compilations or has the potential to be program specific.

+ */

+#define	portSAVE_CONTEXT( ucForcedInterruptFlags )								\

+{																				\

+	_asm																		\

+		/* Save the status and WREG registers first, as these will get modified	\

+		by the operations below. */												\

+		MOVFF	WREG, PREINC1													\

+		MOVFF   STATUS, PREINC1													\

+		/* Save the INTCON register with the appropriate bits forced if			\

+		necessary - as described above. */										\

+		MOVFF	INTCON, WREG													\

+		IORLW	ucForcedInterruptFlags											\

+		MOVFF	WREG, PREINC1													\

+	_endasm																		\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	_asm																		\

+		/* Store the necessary registers to the stack. */						\

+		MOVFF	BSR, PREINC1													\

+		MOVFF	FSR2L, PREINC1													\

+		MOVFF	FSR2H, PREINC1													\

+		MOVFF	FSR0L, PREINC1													\

+		MOVFF	FSR0H, PREINC1													\

+		MOVFF	TABLAT, PREINC1													\

+		MOVFF	TBLPTRU, PREINC1												\

+		MOVFF	TBLPTRH, PREINC1												\

+		MOVFF	TBLPTRL, PREINC1												\

+		MOVFF	PRODH, PREINC1													\

+		MOVFF	PRODL, PREINC1													\

+		MOVFF	PCLATU, PREINC1													\

+		MOVFF	PCLATH, PREINC1													\

+		/* Store the .tempdata and MATH_DATA areas as described above. */		\

+		CLRF	FSR0L, 0														\

+		CLRF	FSR0H, 0														\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	POSTINC0, PREINC1												\

+		MOVFF	INDF0, PREINC1													\

+		MOVFF	FSR0L, PREINC1													\

+		MOVFF	FSR0H, PREINC1													\

+		/* Store the hardware stack pointer in a temp register before we		\

+		modify it. */															\

+		MOVFF	STKPTR, FSR0L													\

+	_endasm																		\

+																				\

+		/* Store each address from the hardware stack. */						\

+		while( STKPTR > ( unsigned char ) 0 )								\

+		{																		\

+			_asm																\

+				MOVFF	TOSL, PREINC1											\

+				MOVFF	TOSH, PREINC1											\

+				MOVFF	TOSU, PREINC1											\

+				POP																\

+			_endasm																\

+		}																		\

+																				\

+	_asm																		\

+		/* Store the number of addresses on the hardware stack (from the		\

+		temporary register). */													\

+		MOVFF	FSR0L, PREINC1													\

+		MOVF	PREINC1, 1, 0													\

+	_endasm																		\

+																				\

+	/* Save the new top of the software stack in the TCB. */					\

+	_asm																		\

+		MOVFF	pxCurrentTCB, FSR0L												\

+		MOVFF	pxCurrentTCB + 1, FSR0H											\

+		MOVFF	FSR1L, POSTINC0													\

+		MOVFF	FSR1H, POSTINC0													\

+	_endasm																		\

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * This is the reverse of portSAVE_CONTEXT.  See portSAVE_CONTEXT for more

+ * details.

+ */

+#define portRESTORE_CONTEXT()													\

+{																				\

+	_asm																		\

+		/* Set FSR0 to point to pxCurrentTCB->pxTopOfStack. */					\

+		MOVFF	pxCurrentTCB, FSR0L												\

+		MOVFF	pxCurrentTCB + 1, FSR0H											\

+																				\

+		/* De-reference FSR0 to set the address it holds into FSR1.				\

+		(i.e. *( pxCurrentTCB->pxTopOfStack ) ). */								\

+		MOVFF	POSTINC0, FSR1L													\

+		MOVFF	POSTINC0, FSR1H													\

+																				\

+		/* How many return addresses are there on the hardware stack?  Discard	\

+		the first byte as we are pointing to the next free space. */			\

+		MOVFF	POSTDEC1, FSR0L													\

+		MOVFF	POSTDEC1, FSR0L													\

+	_endasm																		\

+																				\

+	/* Fill the hardware stack from our software stack. */						\

+	STKPTR = 0;																	\

+																				\

+	while( STKPTR < FSR0L )														\

+	{																			\

+		_asm																	\

+			PUSH																\

+			MOVF	POSTDEC1, 0, 0												\

+			MOVWF	TOSU, 0														\

+			MOVF	POSTDEC1, 0, 0												\

+			MOVWF	TOSH, 0														\

+			MOVF	POSTDEC1, 0, 0												\

+			MOVWF	TOSL, 0														\

+		_endasm																	\

+	}																			\

+																				\

+	_asm																		\

+		/* Restore the .tmpdata and MATH_DATA memory. */						\

+		MOVFF	POSTDEC1, FSR0H													\

+		MOVFF	POSTDEC1, FSR0L													\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, POSTDEC0												\

+		MOVFF	POSTDEC1, INDF0													\

+		/* Restore the other registers forming the tasks context. */			\

+		MOVFF	POSTDEC1, PCLATH												\

+		MOVFF	POSTDEC1, PCLATU												\

+		MOVFF	POSTDEC1, PRODL													\

+		MOVFF	POSTDEC1, PRODH													\

+		MOVFF	POSTDEC1, TBLPTRL												\

+		MOVFF	POSTDEC1, TBLPTRH												\

+		MOVFF	POSTDEC1, TBLPTRU												\

+		MOVFF	POSTDEC1, TABLAT												\

+		MOVFF	POSTDEC1, FSR0H													\

+		MOVFF	POSTDEC1, FSR0L													\

+		MOVFF	POSTDEC1, FSR2H													\

+		MOVFF	POSTDEC1, FSR2L													\

+		MOVFF	POSTDEC1, BSR													\

+		/* The next byte is the INTCON register.  Read this into WREG as some	\

+		manipulation is required. */											\

+		MOVFF	POSTDEC1, WREG													\

+	_endasm																		\

+																				\

+	/* From the INTCON register, only the interrupt enable bits form part		\

+	of the tasks context.  It is perfectly legitimate for another task to		\

+	have modified any other bits.  We therefore only restore the top two bits.	\

+	*/																			\

+	if( WREG & portGLOBAL_INTERRUPT_FLAG )										\

+	{																			\

+		_asm 																	\

+			MOVFF	POSTDEC1, STATUS											\

+			MOVFF	POSTDEC1, WREG												\

+			/* Return enabling interrupts. */									\

+			RETFIE	0															\

+		_endasm																	\

+	}																			\

+	else																		\

+	{																			\

+		_asm 																	\

+			MOVFF	POSTDEC1, STATUS											\

+			MOVFF	POSTDEC1, WREG												\

+			/* Return without effecting interrupts.  The context may have		\

+			been saved from a critical region. */								\

+			RETURN	0															\

+		_endasm																	\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long ulAddress;

+unsigned char ucBlock;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x11;

+	pxTopOfStack++;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack++;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack++;

+

+

+	/* Simulate how the stack would look after a call to vPortYield() generated

+	by the compiler. 

+

+	First store the function parameters.  This is where the task will expect to

+	find them when it starts running. */

+	ulAddress = ( unsigned long ) pvParameters;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress & ( unsigned long ) 0x00ff );

+	pxTopOfStack++;

+

+	ulAddress >>= 8;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress & ( unsigned long ) 0x00ff );

+	pxTopOfStack++;

+

+	/* Next we just leave a space.  When a context is saved the stack pointer

+	is incremented before it is used so as not to corrupt whatever the stack

+	pointer is actually pointing to.  This is especially necessary during 

+	function epilogue code generated by the compiler. */

+	*pxTopOfStack = 0x44;

+	pxTopOfStack++;

+

+	/* Next are all the registers that form part of the task context. */

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x66; /* WREG. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xcc; /* Status. */

+	pxTopOfStack++;

+

+	/* INTCON is saved with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITAL_INTERRUPT_STATE; /* INTCON */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11; /* BSR. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22; /* FSR2L. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x33; /* FSR2H. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x44; /* FSR0L. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x55; /* FSR0H. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x66; /* TABLAT. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00; /* TBLPTRU. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x88; /* TBLPTRUH. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x99; /* TBLPTRUL. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaa; /* PRODH. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xbb; /* PRODL. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00; /* PCLATU. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00; /* PCLATH. */

+	pxTopOfStack++;

+

+	/* Next the .tmpdata and MATH_DATA sections. */

+	for( ucBlock = 0; ucBlock <= portCOMPILER_MANAGED_MEMORY_SIZE; ucBlock++ )

+	{

+		*pxTopOfStack = ( portSTACK_TYPE ) ucBlock;

+		*pxTopOfStack++;

+	}

+

+	/* Store the top of the global data section. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portCOMPILER_MANAGED_MEMORY_SIZE; /* Low. */

+	pxTopOfStack++;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00; /* High. */

+	pxTopOfStack++;

+

+	/* The only function return address so far is the address of the 

+	task. */

+	ulAddress = ( unsigned long ) pxCode;

+

+	/* TOS low. */

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress & ( unsigned long ) 0x00ff );

+	pxTopOfStack++;

+	ulAddress >>= 8;

+

+	/* TOS high. */

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress & ( unsigned long ) 0x00ff );

+	pxTopOfStack++;

+	ulAddress >>= 8;

+

+	/* TOS even higher. */

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress & ( unsigned long ) 0x00ff );

+	pxTopOfStack++;

+

+	/* Store the number of return addresses on the hardware stack - so far only

+	the address of the task entry point. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 1;

+	pxTopOfStack++;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup a timer for the tick ISR is using the preemptive scheduler. */

+	prvSetupTimerInterrupt(); 

+

+	/* Restore the context of the first task to run. */

+	portRESTORE_CONTEXT();

+

+	/* Should not get here.  Use the function name to stop compiler warnings. */

+	( void ) prvLowInterrupt;

+	( void ) prvTickISR;

+

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the scheduler for the PIC port will get stopped

+	once running.  If required disable the tick interrupt here, then return 

+	to xPortStartScheduler(). */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch.  This is similar to the tick context switch,

+ * but does not increment the tick count.  It must be identical to the

+ * tick context switch in how it stores the stack of a task.

+ */

+void vPortYield( void )

+{

+	/* This can get called with interrupts either enabled or disabled.  We

+	will save the INTCON register with the interrupt enable bits unmodified. */

+	portSAVE_CONTEXT( portINTERRUPTS_UNCHANGED );

+

+	/* Switch to the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+

+	/* Start executing the task we have just switched to. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Vector for ISR.  Nothing here must alter any registers!

+ */

+#pragma code high_vector=0x08

+static void prvLowInterrupt( void )

+{

+	/* Was the interrupt the tick? */

+	if( PIR1bits.CCP1IF )

+	{		

+		_asm

+			goto prvTickISR

+		_endasm

+	}

+

+	/* Was the interrupt a byte being received? */

+	if( PIR1bits.RCIF )

+	{

+		_asm

+			goto vSerialRxISR

+		_endasm

+	}

+

+	/* Was the interrupt the Tx register becoming empty? */

+	if( PIR1bits.TXIF )

+	{

+		if( PIE1bits.TXIE )

+		{

+			_asm

+				goto vSerialTxISR

+			_endasm

+		}

+	}

+}

+#pragma code

+

+/*-----------------------------------------------------------*/

+

+/*

+ * ISR for the tick.

+ * This increments the tick count and, if using the preemptive scheduler, 

+ * performs a context switch.  This must be identical to the manual 

+ * context switch in how it stores the context of a task. 

+ */

+static void prvTickISR( void )

+{

+	/* Interrupts must have been enabled for the ISR to fire, so we have to 

+	save the context with interrupts enabled. */

+	portSAVE_CONTEXT( portGLOBAL_INTERRUPT_FLAG );

+	PIR1bits.CCP1IF = 0;

+

+	/* Maintain the tick count. */

+	vTaskIncrementTick();

+

+	#if configUSE_PREEMPTION == 1

+	{

+		/* Switch to the highest priority task that is ready to run. */

+		vTaskSwitchContext();

+	}

+	#endif

+

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup a timer for a regular tick.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulConstCompareValue = ( ( configCPU_CLOCK_HZ / portTIMER_FOSC_SCALE ) / configTICK_RATE_HZ );

+unsigned long ulCompareValue;

+unsigned char ucByte;

+

+	/* Interrupts are disabled when this function is called.

+

+	Setup CCP1 to provide the tick interrupt using a compare match on timer

+	1.

+

+	Clear the time count then setup timer. */

+	TMR1H = ( unsigned char ) 0x00;

+	TMR1L = ( unsigned char ) 0x00;

+

+	/* Set the compare match value. */

+	ulCompareValue = ulConstCompareValue;

+	CCPR1L = ( unsigned char ) ( ulCompareValue & ( unsigned long ) 0xff );

+	ulCompareValue >>= ( unsigned long ) 8;

+	CCPR1H = ( unsigned char ) ( ulCompareValue & ( unsigned long ) 0xff );	

+

+	CCP1CONbits.CCP1M0 = portBIT_SET;	/*< Compare match mode. */

+	CCP1CONbits.CCP1M1 = portBIT_SET;	/*< Compare match mode. */

+	CCP1CONbits.CCP1M2 = portBIT_CLEAR;	/*< Compare match mode. */

+	CCP1CONbits.CCP1M3 = portBIT_SET;	/*< Compare match mode. */

+	PIE1bits.CCP1IE = portBIT_SET;		/*< Interrupt enable. */

+

+	/* We are only going to use the global interrupt bit, so set the peripheral

+	bit to true. */

+	INTCONbits.GIEL = portBIT_SET;

+

+	/* Provided library function for setting up the timer that will produce the

+	tick. */

+	OpenTimer1( T1_16BIT_RW & T1_SOURCE_INT & T1_PS_1_1 & T1_CCP1_T3_CCP2 );

+}

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC18F/portmacro.h b/FreeRTOS/Source/portable/MPLAB/PIC18F/portmacro.h
new file mode 100644
index 0000000..c747b80
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC18F/portmacro.h
@@ -0,0 +1,147 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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		int

+#define portSTACK_TYPE	unsigned char

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			1

+#define portGLOBAL_INT_ENABLE_BIT	0x80

+#define portSTACK_GROWTH			1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Critical section management. */

+#define portDISABLE_INTERRUPTS()	INTCONbits.GIEH = 0;

+#define portENABLE_INTERRUPTS()		INTCONbits.GIEH = 1;

+

+/* Push the INTCON register onto the stack, then disable interrupts. */

+#define portENTER_CRITICAL()		POSTINC1 = INTCON;				\

+									INTCONbits.GIEH = 0;

+

+/* Retrieve the INTCON register from the stack, and enable interrupts

+if they were saved as being enabled.  Don't modify any other bits

+within the INTCON register as these may have lagitimately have been

+modified within the critical region. */

+#define portEXIT_CRITICAL()			_asm									\

+										MOVF	POSTDEC1, 1, 0				\

+									_endasm									\

+									if( INDF1 & portGLOBAL_INT_ENABLE_BIT )	\

+									{										\

+										portENABLE_INTERRUPTS();			\

+									}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+extern void vPortYield( void );

+#define portYIELD()				vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+/* Required by the kernel aware debugger. */

+#ifdef __DEBUG

+	#define portREMOVE_STATIC_QUALIFIER

+#endif

+

+

+#define portNOP()				_asm	\

+									NOP \

+								_endasm

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC18F/stdio.h b/FreeRTOS/Source/portable/MPLAB/PIC18F/stdio.h
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC18F/stdio.h
diff --git a/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/port.c b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/port.c
new file mode 100644
index 0000000..e2c7081
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/port.c
@@ -0,0 +1,329 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+	Changes from V4.2.1

+

+	+ Introduced the configKERNEL_INTERRUPT_PRIORITY definition.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the PIC24 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler include files. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Hardware specifics. */

+#define portBIT_SET 1

+#define portTIMER_PRESCALE 8

+#define portINITIAL_SR	0

+

+/* Defined for backward compatability with project created prior to 

+FreeRTOS.org V4.3.0. */

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 1

+#endif

+

+/* The program counter is only 23 bits. */

+#define portUNUSED_PR_BITS	0x7f

+

+/* Records the nesting depth of calls to portENTER_CRITICAL(). */

+unsigned portBASE_TYPE uxCriticalNesting = 0xef;

+

+#if configKERNEL_INTERRUPT_PRIORITY != 1

+	#error If configKERNEL_INTERRUPT_PRIORITY is not 1 then the #32 in the following macros needs changing to equal the portINTERRUPT_BITS value, which is ( configKERNEL_INTERRUPT_PRIORITY << 5 )

+#endif

+

+#ifdef MPLAB_PIC24_PORT

+

+	#define portRESTORE_CONTEXT()																						\

+		asm volatile(	"MOV	_pxCurrentTCB, W0		\n"	/* Restore the stack pointer for the task. */				\

+						"MOV	[W0], W15				\n"																\

+						"POP	W0						\n"	/* Restore the critical nesting counter for the task. */	\

+						"MOV	W0, _uxCriticalNesting	\n"																\

+						"POP	PSVPAG					\n"																\

+						"POP	CORCON					\n"																\

+						"POP	TBLPAG					\n"																\

+						"POP	RCOUNT					\n"	/* Restore the registers from the stack. */					\

+						"POP	W14						\n"																\

+						"POP.D	W12						\n"																\

+						"POP.D	W10						\n"																\

+						"POP.D	W8						\n"																\

+						"POP.D	W6						\n"																\

+						"POP.D	W4						\n"																\

+						"POP.D	W2						\n"																\

+						"POP.D	W0						\n"																\

+						"POP	SR						  " );

+

+#endif /* MPLAB_PIC24_PORT */

+

+#ifdef MPLAB_DSPIC_PORT

+

+	#define portRESTORE_CONTEXT()																						\

+		asm volatile(	"MOV	_pxCurrentTCB, W0		\n"	/* Restore the stack pointer for the task. */				\

+						"MOV	[W0], W15				\n"																\

+						"POP	W0						\n"	/* Restore the critical nesting counter for the task. */	\

+						"MOV	W0, _uxCriticalNesting	\n"																\

+						"POP	PSVPAG					\n"																\

+						"POP	CORCON					\n"																\

+						"POP	DOENDH					\n"																\

+						"POP	DOENDL					\n"																\

+						"POP	DOSTARTH				\n"																\

+						"POP	DOSTARTL				\n"																\

+						"POP	DCOUNT					\n"																\

+						"POP	ACCBU					\n"																\

+						"POP	ACCBH					\n"																\

+						"POP	ACCBL					\n"																\

+						"POP	ACCAU					\n"																\

+						"POP	ACCAH					\n"																\

+						"POP	ACCAL					\n"																\

+						"POP	TBLPAG					\n"																\

+						"POP	RCOUNT					\n"	/* Restore the registers from the stack. */					\

+						"POP	W14						\n"																\

+						"POP.D	W12						\n"																\

+						"POP.D	W10						\n"																\

+						"POP.D	W8						\n"																\

+						"POP.D	W6						\n"																\

+						"POP.D	W4						\n"																\

+						"POP.D	W2						\n"																\

+						"POP.D	W0						\n"																\

+						"POP	SR						  " );

+

+#endif /* MPLAB_DSPIC_PORT */

+

+/*

+ * Setup the timer used to generate the tick interrupt.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned short usCode;

+portBASE_TYPE i;

+

+const portSTACK_TYPE xInitialStack[] = 

+{

+	0x1111,	/* W1 */

+	0x2222, /* W2 */

+	0x3333, /* W3 */

+	0x4444, /* W4 */

+	0x5555, /* W5 */

+	0x6666, /* W6 */

+	0x7777, /* W7 */

+	0x8888, /* W8 */

+	0x9999, /* W9 */

+	0xaaaa, /* W10 */

+	0xbbbb, /* W11 */

+	0xcccc, /* W12 */

+	0xdddd, /* W13 */

+	0xeeee, /* W14 */

+	0xcdce, /* RCOUNT */

+	0xabac, /* TBLPAG */

+

+	/* dsPIC specific registers. */

+	#ifdef MPLAB_DSPIC_PORT

+		0x0202, /* ACCAL */

+		0x0303, /* ACCAH */

+		0x0404, /* ACCAU */

+		0x0505, /* ACCBL */

+		0x0606, /* ACCBH */

+		0x0707, /* ACCBU */

+		0x0808, /* DCOUNT */

+		0x090a, /* DOSTARTL */

+		0x1010, /* DOSTARTH */

+		0x1110, /* DOENDL */

+		0x1212, /* DOENDH */

+	#endif

+};

+

+	/* Setup the stack as if a yield had occurred.

+

+	Save the low bytes of the program counter. */

+	usCode = ( unsigned short ) pxCode;

+	*pxTopOfStack = ( portSTACK_TYPE ) usCode;

+	pxTopOfStack++;

+

+	/* Save the high byte of the program counter.  This will always be zero

+	here as it is passed in a 16bit pointer.  If the address is greater than

+	16 bits then the pointer will point to a jump table. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0;

+	pxTopOfStack++;

+

+	/* Status register with interrupts enabled. */

+	*pxTopOfStack = portINITIAL_SR;

+	pxTopOfStack++;

+

+	/* Parameters are passed in W0. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack++;

+

+	for( i = 0; i < ( sizeof( xInitialStack ) / sizeof( portSTACK_TYPE ) ); i++ )

+	{

+		*pxTopOfStack = xInitialStack[ i ];

+		pxTopOfStack++;

+	}

+

+	*pxTopOfStack = CORCON;

+	pxTopOfStack++;

+	*pxTopOfStack = PSVPAG;

+	pxTopOfStack++;

+

+	/* Finally the critical nesting depth. */

+	*pxTopOfStack = 0x00;

+	pxTopOfStack++;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup a timer for the tick ISR. */

+	prvSetupTimerInterrupt(); 

+

+	/* Restore the context of the first task to run. */

+	portRESTORE_CONTEXT();

+

+	/* Simulate the end of the yield function. */

+	asm volatile ( "return" );

+

+	/* Should not reach here. */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the scheduler for the PIC port will get stopped

+	once running.  If required disable the tick interrupt here, then return 

+	to xPortStartScheduler(). */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup a timer for a regular tick.

+ */

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulCompareMatch = ( ( configCPU_CLOCK_HZ / portTIMER_PRESCALE ) / configTICK_RATE_HZ ) - 1;

+

+	/* Prescale of 8. */

+	T1CON = 0;

+	TMR1 = 0;

+

+	PR1 = ( unsigned short ) ulCompareMatch;

+

+	/* Setup timer 1 interrupt priority. */

+	IPC0bits.T1IP = configKERNEL_INTERRUPT_PRIORITY;

+

+	/* Clear the interrupt as a starting condition. */

+	IFS0bits.T1IF = 0;

+

+	/* Enable the interrupt. */

+	IEC0bits.T1IE = 1;

+

+	/* Setup the prescale value. */

+	T1CONbits.TCKPS0 = 1;

+	T1CONbits.TCKPS1 = 0;

+

+	/* Start the timer. */

+	T1CONbits.TON = 1;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void __attribute__((__interrupt__, auto_psv)) _T1Interrupt( void )

+{

+	/* Clear the timer interrupt. */

+	IFS0bits.T1IF = 0;

+

+	vTaskIncrementTick();

+

+	#if configUSE_PREEMPTION == 1

+		portYIELD();

+	#endif

+}

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_PIC24.S b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_PIC24.S
new file mode 100644
index 0000000..bbc82df
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_PIC24.S
@@ -0,0 +1,117 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+        .global _vPortYield

+		.extern _vTaskSwitchContext

+		.extern uxCriticalNesting

+

+_vPortYield:

+

+		PUSH	SR						/* Save the SR used by the task.... */

+		PUSH	W0						/* ....then disable interrupts. */

+		MOV		#32, W0

+		MOV		W0, SR

+		PUSH	W1						/* Save registers to the stack. */

+		PUSH.D	W2

+		PUSH.D	W4

+		PUSH.D	W6

+		PUSH.D 	W8

+		PUSH.D 	W10

+		PUSH.D	W12

+		PUSH	W14

+		PUSH	RCOUNT

+		PUSH	TBLPAG

+																						

+		PUSH	CORCON

+		PUSH	PSVPAG

+		MOV		_uxCriticalNesting, W0		/* Save the critical nesting counter for the task. */

+		PUSH	W0

+		MOV		_pxCurrentTCB, W0			/* Save the new top of stack into the TCB. */

+		MOV		W15, [W0]

+

+		call 	_vTaskSwitchContext

+

+		MOV		_pxCurrentTCB, W0			/* Restore the stack pointer for the task. */

+		MOV		[W0], W15

+		POP		W0							/* Restore the critical nesting counter for the task. */

+		MOV		W0, _uxCriticalNesting

+		POP		PSVPAG

+		POP		CORCON

+		POP		TBLPAG

+		POP		RCOUNT						/* Restore the registers from the stack. */

+		POP		W14

+		POP.D	W12

+		POP.D	W10

+		POP.D	W8

+		POP.D	W6

+		POP.D	W4

+		POP.D	W2

+		POP.D	W0

+		POP		SR

+

+        return

+

+        .end

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_dsPIC.S b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_dsPIC.S
new file mode 100644
index 0000000..0b6c019
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portasm_dsPIC.S
@@ -0,0 +1,140 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+        .global _vPortYield

+		.extern _vTaskSwitchContext

+		.extern uxCriticalNesting

+

+_vPortYield:

+

+		PUSH	SR						/* Save the SR used by the task.... */

+		PUSH	W0						/* ....then disable interrupts. */

+		MOV		#32, W0

+		MOV		W0, SR

+		PUSH	W1						/* Save registers to the stack. */

+		PUSH.D	W2

+		PUSH.D	W4

+		PUSH.D	W6

+		PUSH.D 	W8

+		PUSH.D 	W10

+		PUSH.D	W12

+		PUSH	W14

+		PUSH	RCOUNT

+		PUSH	TBLPAG

+		PUSH	ACCAL

+		PUSH	ACCAH

+		PUSH	ACCAU

+		PUSH	ACCBL

+		PUSH	ACCBH

+		PUSH	ACCBU

+		PUSH	DCOUNT

+		PUSH	DOSTARTL

+		PUSH	DOSTARTH

+		PUSH	DOENDL

+		PUSH	DOENDH

+		

+																						

+		PUSH	CORCON

+		PUSH	PSVPAG

+		MOV		_uxCriticalNesting, W0		/* Save the critical nesting counter for the task. */

+		PUSH	W0

+		MOV		_pxCurrentTCB, W0			/* Save the new top of stack into the TCB. */

+		MOV		W15, [W0]

+

+		call 	_vTaskSwitchContext

+

+		MOV		_pxCurrentTCB, W0			/* Restore the stack pointer for the task. */

+		MOV		[W0], W15

+		POP		W0							/* Restore the critical nesting counter for the task. */

+		MOV		W0, _uxCriticalNesting

+		POP		PSVPAG

+		POP		CORCON

+		POP		DOENDH

+		POP		DOENDL

+		POP		DOSTARTH

+		POP		DOSTARTL

+		POP		DCOUNT

+		POP		ACCBU

+		POP		ACCBH

+		POP		ACCBL

+		POP		ACCAU

+		POP		ACCAH

+		POP		ACCAL

+		POP		TBLPAG

+		POP		RCOUNT						/* Restore the registers from the stack. */

+		POP		W14

+		POP.D	W12

+		POP.D	W10

+		POP.D	W8

+		POP.D	W6

+		POP.D	W4

+		POP.D	W2

+		POP.D	W0

+		POP		SR

+

+        return

+

+        .end

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portmacro.h b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portmacro.h
new file mode 100644
index 0000000..0d1f4eb
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portmacro.h
@@ -0,0 +1,145 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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	unsigned short

+#define portBASE_TYPE	short

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Critical section management. */

+#define portINTERRUPT_BITS			( ( unsigned portSHORT ) configKERNEL_INTERRUPT_PRIORITY << ( unsigned portSHORT ) 5 )

+

+#define portDISABLE_INTERRUPTS()	SR |= portINTERRUPT_BITS                    

+#define portENABLE_INTERRUPTS()		SR &= ~portINTERRUPT_BITS

+

+/* Note that exiting a critical sectino will set the IPL bits to 0, nomatter

+what their value was prior to entering the critical section. */

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+extern void vPortYield( void );

+#define portYIELD()				asm volatile ( "CALL _vPortYield			\n"		\

+												"NOP					  " );

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+/* Required by the kernel aware debugger. */

+#ifdef __DEBUG

+	#define portREMOVE_STATIC_QUALIFIER

+#endif

+

+#define portNOP()				asm volatile ( "NOP" )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC32MX/ISR_Support.h b/FreeRTOS/Source/portable/MPLAB/PIC32MX/ISR_Support.h
new file mode 100644
index 0000000..46a2610
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC32MX/ISR_Support.h
@@ -0,0 +1,230 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOSConfig.h"

+

+#define portCONTEXT_SIZE 132

+#define portEPC_STACK_LOCATION	124

+#define portSTATUS_STACK_LOCATION 128

+

+/******************************************************************/ 	

+.macro	portSAVE_CONTEXT

+

+	/* Make room for the context. First save the current status so we can 

+	manipulate it, and the cause and EPC registers so we capture their 

+	original values in case of interrupt nesting. */

+	mfc0		k0, _CP0_CAUSE

+	addiu		sp,	sp, -portCONTEXT_SIZE

+	mfc0		k1, _CP0_STATUS

+

+	/* Also save s6 and s5 so we can use them during this interrupt.  Any

+	nesting interrupts should maintain the values of these registers

+	across the ISR. */

+	sw			s6, 44(sp)

+	sw			s5, 40(sp)

+	sw			k1, portSTATUS_STACK_LOCATION(sp)

+

+	/* Enable interrupts above the current priority. */

+	srl			k0, k0, 0xa

+	ins 		k1, k0, 10, 6

+	ins			k1, zero, 1, 4

+

+	/* s5 is used as the frame pointer. */

+	add			s5, zero, sp

+

+	/* Check the nesting count value. */

+	la			k0, uxInterruptNesting

+	lw			s6, (k0)

+

+	/* If the nesting count is 0 then swap to the the system stack, otherwise

+	the system stack is already being used. */

+	bne			s6, zero, .+20

+	nop

+

+	/* Swap to the system stack. */

+	la			sp, xISRStackTop

+	lw			sp, (sp)

+

+	/* Increment and save the nesting count. */

+	addiu		s6, s6, 1

+	sw			s6, 0(k0)

+

+	/* s6 holds the EPC value, this is saved after interrupts are re-enabled. */

+	mfc0 		s6, _CP0_EPC

+

+	/* Re-enable interrupts. */

+	mtc0		k1, _CP0_STATUS

+

+	/* Save the context into the space just created.  s6 is saved again

+	here as it now contains the EPC value.  No other s registers need be

+	saved. */

+	sw			ra,	120(s5)

+	sw			s8, 116(s5)

+	sw			t9, 112(s5)

+	sw			t8,	108(s5)

+	sw			t7,	104(s5)

+	sw			t6, 100(s5)

+	sw			t5, 96(s5)

+	sw			t4, 92(s5)

+	sw			t3, 88(s5)

+	sw			t2, 84(s5)

+	sw			t1, 80(s5)

+	sw			t0, 76(s5)

+	sw			a3, 72(s5)

+	sw			a2, 68(s5)

+	sw			a1, 64(s5)

+	sw			a0, 60(s5)

+	sw			v1, 56(s5)

+	sw			v0, 52(s5)

+	sw			s6, portEPC_STACK_LOCATION(s5)

+	sw			$1, 16(s5)

+

+	/* s6 is used as a scratch register. */

+	mfhi		s6

+	sw			s6, 12(s5)

+	mflo		s6

+	sw			s6, 8(s5)

+

+	/* Update the task stack pointer value if nesting is zero. */

+	la			s6, uxInterruptNesting

+	lw			s6, (s6)

+	addiu		s6, s6, -1

+	bne			s6, zero, .+20

+	nop

+

+	/* Save the stack pointer. */

+	la			s6, uxSavedTaskStackPointer

+	sw			s5, (s6)

+

+	.endm

+	

+/******************************************************************/	

+.macro	portRESTORE_CONTEXT

+

+	/* Restore the stack pointer from the TCB.  This is only done if the

+	nesting count is 1. */

+	la			s6, uxInterruptNesting

+	lw			s6, (s6)

+	addiu		s6, s6, -1

+	bne			s6, zero, .+20

+	nop

+	la			s6, uxSavedTaskStackPointer

+	lw			s5, (s6)

+	

+	/* Restore the context. */

+	lw			s6, 8(s5)

+	mtlo		s6

+	lw			s6, 12(s5)

+	mthi		s6

+	lw			$1, 16(s5)

+	/* s6 is loaded as it was used as a scratch register and therefore saved

+	as part of the interrupt context. */

+	lw			s6, 44(s5)

+	lw			v0, 52(s5)

+	lw			v1, 56(s5)

+	lw			a0, 60(s5)

+	lw			a1, 64(s5)

+	lw			a2, 68(s5)

+	lw			a3, 72(s5)

+	lw			t0, 76(s5)

+	lw			t1, 80(s5)

+	lw			t2, 84(s5)

+	lw			t3, 88(s5)

+	lw			t4, 92(s5)

+	lw			t5, 96(s5)

+	lw			t6, 100(s5)

+	lw			t7, 104(s5)

+	lw			t8, 108(s5)

+	lw			t9, 112(s5)

+	lw			s8, 116(s5)

+	lw			ra, 120(s5)

+

+	/* Protect access to the k registers, and others. */

+	di

+

+	/* Decrement the nesting count. */

+	la			k0, uxInterruptNesting

+	lw			k1, (k0)

+	addiu		k1, k1, -1

+	sw			k1, 0(k0)

+

+	lw			k0, portSTATUS_STACK_LOCATION(s5)

+	lw			k1, portEPC_STACK_LOCATION(s5)

+

+	/* Leave the stack how we found it.  First load sp from s5, then restore

+	s5 from the stack. */

+	add			sp, zero, s5

+	lw			s5, 40(sp)

+	addiu		sp,	sp,	portCONTEXT_SIZE

+

+	mtc0		k0, _CP0_STATUS

+	mtc0 		k1, _CP0_EPC

+	ehb

+	eret 

+	nop

+

+	.endm

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC32MX/port.c b/FreeRTOS/Source/portable/MPLAB/PIC32MX/port.c
new file mode 100644
index 0000000..7c22b49
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC32MX/port.c
@@ -0,0 +1,243 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the PIC32MX port.

+  *----------------------------------------------------------*/

+

+/* Scheduler include files. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Hardware specifics. */

+#define portTIMER_PRESCALE 8

+

+/* Bits within various registers. */

+#define portIE_BIT					( 0x00000001 )

+#define portEXL_BIT					( 0x00000002 )

+

+/* The EXL bit is set to ensure interrupts do not occur while the context of

+the first task is being restored. */

+#define portINITIAL_SR				( portIE_BIT | portEXL_BIT )

+

+/* Records the interrupt nesting depth.  This starts at one as it will be

+decremented to 0 when the first task starts. */

+volatile unsigned portBASE_TYPE uxInterruptNesting = 0x01;

+

+/* Stores the task stack pointer when a switch is made to use the system stack. */

+unsigned portBASE_TYPE uxSavedTaskStackPointer = 0;

+

+/* The stack used by interrupt service routines that cause a context switch. */

+portSTACK_TYPE xISRStack[ configISR_STACK_SIZE ] = { 0 };

+

+/* The top of stack value ensures there is enough space to store 6 registers on 

+the callers stack, as some functions seem to want to do this. */

+const portSTACK_TYPE * const xISRStackTop = &( xISRStack[ configISR_STACK_SIZE - 7 ] );

+

+/* 

+ * Place the prototype here to ensure the interrupt vector is correctly installed. 

+ * Note that because the interrupt is written in assembly, the IPL setting in the

+ * following line of code has no effect.  The interrupt priority is set by the

+ * call to ConfigIntTimer1() in prvSetupTimerInterrupt(). 

+ */

+extern void __attribute__( (interrupt(ipl1), vector(_TIMER_1_VECTOR))) vT1InterruptHandler( void );

+

+/*

+ * The software interrupt handler that performs the yield.  Note that, because

+ * the interrupt is written in assembly, the IPL setting in the following line of

+ * code has no effect.  The interrupt priority is set by the call to 

+ * mConfigIntCoreSW0() in xPortStartScheduler(). 

+ */

+void __attribute__( (interrupt(ipl1), vector(_CORE_SOFTWARE_0_VECTOR))) vPortYieldISR( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Ensure byte alignment is maintained when leaving this function. */

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) 0xDEADBEEF;

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) 0x12345678;	/* Word to which the stack pointer will be left pointing after context restore. */

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) _CP0_GET_CAUSE();

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) portINITIAL_SR; /* CP0_STATUS */

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) pxCode; 		/* CP0_EPC */

+	pxTopOfStack--;

+

+	*pxTopOfStack = (portSTACK_TYPE) NULL;  		/* ra */

+	pxTopOfStack -= 15;

+

+	*pxTopOfStack = (portSTACK_TYPE) pvParameters; /* Parameters to pass in */

+	pxTopOfStack -= 14;

+

+	*pxTopOfStack = (portSTACK_TYPE) 0x00000000; 	/* critical nesting level - no longer used. */

+	pxTopOfStack--;

+	

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup a timer for a regular tick.

+ */

+void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulCompareMatch = ( (configPERIPHERAL_CLOCK_HZ / portTIMER_PRESCALE) / configTICK_RATE_HZ ) - 1;

+

+	OpenTimer1( ( T1_ON | T1_PS_1_8 | T1_SOURCE_INT ), ulCompareMatch );

+	ConfigIntTimer1( T1_INT_ON | configKERNEL_INTERRUPT_PRIORITY );

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler(void)

+{

+	/* It is unlikely that the scheduler for the PIC port will get stopped

+	once running.  If required disable the tick interrupt here, then return 

+	to xPortStartScheduler(). */

+	for( ;; );

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vPortStartFirstTask( void );

+extern void *pxCurrentTCB;

+

+	/* Setup the software interrupt. */

+	mConfigIntCoreSW0( CSW_INT_ON | configKERNEL_INTERRUPT_PRIORITY | CSW_INT_SUB_PRIOR_0 );

+

+	/* Setup the timer to generate the tick.  Interrupts will have been 

+	disabled by the time we get here. */

+	prvSetupTimerInterrupt();

+

+	/* Kick off the highest priority task that has been created so far. 

+	Its stack location is loaded into uxSavedTaskStackPointer. */

+	uxSavedTaskStackPointer = *( unsigned portBASE_TYPE * ) pxCurrentTCB;

+	vPortStartFirstTask();

+

+	/* Should never get here as the tasks will now be executing. */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortIncrementTick( void )

+{

+unsigned portBASE_TYPE uxSavedStatus;

+

+	uxSavedStatus = uxPortSetInterruptMaskFromISR();

+		vTaskIncrementTick();

+	vPortClearInterruptMaskFromISR( uxSavedStatus );

+	

+	/* If we are using the preemptive scheduler then we might want to select

+	a different task to execute. */

+	#if configUSE_PREEMPTION == 1

+		SetCoreSW0();

+	#endif /* configUSE_PREEMPTION */

+

+	/* Clear timer 0 interrupt. */

+	mT1ClearIntFlag();

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR( void )

+{

+unsigned portBASE_TYPE uxSavedStatusRegister;

+

+	asm volatile ( "di" );

+	uxSavedStatusRegister = _CP0_GET_STATUS() | 0x01;

+	/* This clears the IPL bits, then sets them to 

+	configMAX_SYSCALL_INTERRUPT_PRIORITY.  This function should not be called

+	from an interrupt that has a priority above 

+	configMAX_SYSCALL_INTERRUPT_PRIORITY so, when used correctly, the action

+	can only result in the IPL being unchanged or raised, and therefore never

+	lowered. */

+	_CP0_SET_STATUS( ( ( uxSavedStatusRegister & ( ~portALL_IPL_BITS ) ) ) | ( configMAX_SYSCALL_INTERRUPT_PRIORITY << portIPL_SHIFT ) );

+

+	return uxSavedStatusRegister;

+}

+/*-----------------------------------------------------------*/

+

+void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE uxSavedStatusRegister )

+{

+	_CP0_SET_STATUS( uxSavedStatusRegister );

+}

+/*-----------------------------------------------------------*/

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC32MX/port_asm.S b/FreeRTOS/Source/portable/MPLAB/PIC32MX/port_asm.S
new file mode 100644
index 0000000..8d4a4ea
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC32MX/port_asm.S
@@ -0,0 +1,306 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+ 

+#include <p32xxxx.h>

+#include <sys/asm.h>

+#include "ISR_Support.h"

+ 

+

+	.set	nomips16

+ 	.set 	noreorder

+ 	

+ 	.extern pxCurrentTCB

+ 	.extern vTaskSwitchContext

+ 	.extern vPortIncrementTick

+	.extern xISRStackTop

+ 	

+ 	.global vPortStartFirstTask

+	.global vPortYieldISR

+	.global vT1InterruptHandler

+

+

+/******************************************************************/

+

+ 	.set		noreorder

+	.set 		noat

+ 	.ent		vT1InterruptHandler

+	

+vT1InterruptHandler:

+

+	portSAVE_CONTEXT

+

+	jal 		vPortIncrementTick

+	nop

+

+	portRESTORE_CONTEXT

+

+	.end vT1InterruptHandler

+

+/******************************************************************/

+

+ 	.set		noreorder

+	.set 		noat

+ 	.ent		xPortStartScheduler

+

+vPortStartFirstTask:

+

+	/* Simply restore the context of the highest priority task that has been

+	created so far. */

+	portRESTORE_CONTEXT

+

+	.end xPortStartScheduler

+

+

+

+/*******************************************************************/

+

+ 	.set		noreorder

+	.set 		noat

+ 	.ent		vPortYieldISR

+

+vPortYieldISR:

+

+	/* Make room for the context. First save the current status so we can 

+	manipulate it, and the cause and EPC registers so we capture their 

+	original values in case of interrupt nesting. */

+	mfc0		k0, _CP0_CAUSE

+	addiu		sp,	sp, -portCONTEXT_SIZE

+	mfc0		k1, _CP0_STATUS

+

+	/* Also save s6 and s5 so we can use them during this interrupt.  Any

+	nesting interrupts should maintain the values of these registers

+	across the ISR. */

+	sw			s6, 44(sp)

+	sw			s5, 40(sp)

+	sw			k1, portSTATUS_STACK_LOCATION(sp)

+

+	/* Enable interrupts above the current priority. */

+	srl			k0, k0, 0xa

+	ins 		k1, k0, 10, 6

+	ins			k1, zero, 1, 4

+

+	/* s5 is used as the frame pointer. */

+	add			s5, zero, sp

+

+	/* Swap to the system stack.  This is not conditional on the nesting

+	count as this interrupt is always the lowest priority and therefore

+	the nesting is always 0. */

+	la			sp, xISRStackTop

+	lw			sp, (sp)

+

+	/* Set the nesting count. */

+	la			k0, uxInterruptNesting

+	addiu		s6, zero, 1

+	sw			s6, 0(k0)

+

+	/* s6 holds the EPC value, this is saved with the rest of the context

+	after interrupts are enabled. */

+	mfc0 		s6, _CP0_EPC

+

+	/* Re-enable interrupts. */

+	mtc0		k1, _CP0_STATUS

+

+	/* Save the context into the space just created.  s6 is saved again

+	here as it now contains the EPC value. */

+	sw			ra,	120(s5)

+	sw			s8, 116(s5)

+	sw			t9, 112(s5)

+	sw			t8,	108(s5)

+	sw			t7,	104(s5)

+	sw			t6, 100(s5)

+	sw			t5, 96(s5)

+	sw			t4, 92(s5)

+	sw			t3, 88(s5)

+	sw			t2, 84(s5)

+	sw			t1, 80(s5)

+	sw			t0, 76(s5)

+	sw			a3, 72(s5)

+	sw			a2, 68(s5)

+	sw			a1, 64(s5)

+	sw			a0, 60(s5)

+	sw			v1, 56(s5)

+	sw			v0, 52(s5)

+	sw			s7, 48(s5)

+	sw			s6, portEPC_STACK_LOCATION(s5)

+	/* s5 and s6 has already been saved. */

+	sw			s4,	36(s5)

+	sw			s3, 32(s5)

+	sw			s2, 28(s5)

+	sw			s1, 24(s5)

+	sw			s0, 20(s5)

+	sw			$1, 16(s5)

+

+	/* s7 is used as a scratch register as this should always be saved across

+	nesting interrupts. */

+	mfhi		s7

+	sw			s7, 12(s5)

+	mflo		s7

+	sw			s7, 8(s5)

+

+	/* Save the stack pointer to the task. */

+	la			s7, pxCurrentTCB

+	lw			s7, (s7)

+	sw			s5, (s7)

+

+	/* Set the interrupt mask to the max priority that can use the API.  The

+	yield handler will only be called at configKERNEL_INTERRUPT_PRIORITY which

+	is below configMAX_SYSCALL_INTERRUPT_PRIORITY - so this can only ever

+	raise the IPL value and never lower it. */

+	di

+	mfc0		s7, _CP0_STATUS

+	ins 		s7, $0, 10, 6

+	ori			s6, s7, ( configMAX_SYSCALL_INTERRUPT_PRIORITY << 10 ) | 1

+

+	/* This mtc0 re-enables interrupts, but only above 

+	configMAX_SYSCALL_INTERRUPT_PRIORITY. */

+	mtc0		s6, _CP0_STATUS

+

+	/* Clear the software interrupt in the core. */

+	mfc0		s6, _CP0_CAUSE

+	addiu       s4,zero,-257

+	and			s6, s6, s4

+	mtc0		s6, _CP0_CAUSE

+

+	/* Clear the interrupt in the interrupt controller. */

+	la			s6, IFS0CLR

+	addiu		s4, zero, 2

+	sw			s4, (s6)

+

+	jal			vTaskSwitchContext

+	nop

+

+	/* Clear the interrupt mask again.  The saved status value is still in s7. */

+	mtc0		s7, _CP0_STATUS

+

+	/* Restore the stack pointer from the TCB. */

+	la			s0, pxCurrentTCB

+	lw			s0, (s0)

+	lw			s5, (s0)

+

+	/* Restore the rest of the context. */

+	lw			s0, 8(s5)

+	mtlo		s0

+	lw			s0, 12(s5)

+	mthi		s0

+	lw			$1, 16(s5)

+	lw			s0, 20(s5)

+	lw			s1, 24(s5)

+	lw			s2, 28(s5)

+	lw			s3, 32(s5)

+	lw			s4, 36(s5)

+	/* s5 is loaded later. */

+	lw			s6, 44(s5)

+	lw			s7, 48(s5)

+	lw			v0, 52(s5)

+	lw			v1, 56(s5)

+	lw			a0, 60(s5)

+	lw			a1, 64(s5)

+	lw			a2, 68(s5)

+	lw			a3, 72(s5)

+	lw			t0, 76(s5)

+	lw			t1, 80(s5)

+	lw			t2, 84(s5)

+	lw			t3, 88(s5)

+	lw			t4, 92(s5)

+	lw			t5, 96(s5)

+	lw			t6, 100(s5)

+	lw			t7, 104(s5)

+	lw			t8, 108(s5)

+	lw			t9, 112(s5)

+	lw			s8, 116(s5)

+	lw			ra, 120(s5)

+

+	/* Protect access to the k registers, and others. */

+	di

+

+	/* Set nesting back to zero.  As the lowest priority interrupt this

+	interrupt cannot have nested. */

+	la			k0, uxInterruptNesting

+	sw			zero, 0(k0)

+

+	/* Switch back to use the real stack pointer. */

+	add			sp, zero, s5

+

+	/* Restore the real s5 value. */

+	lw			s5, 40(sp)

+

+	/* Pop the status and epc values. */

+	lw			k1, portSTATUS_STACK_LOCATION(sp)

+	lw			k0, portEPC_STACK_LOCATION(sp)

+

+	/* Remove stack frame. */

+	addiu		sp,	sp,	portCONTEXT_SIZE

+

+	mtc0		k1, _CP0_STATUS	

+	mtc0 		k0, _CP0_EPC

+	ehb

+	eret 

+	nop

+

+	.end		vPortYieldISR

+

+

+

diff --git a/FreeRTOS/Source/portable/MPLAB/PIC32MX/portmacro.h b/FreeRTOS/Source/portable/MPLAB/PIC32MX/portmacro.h
new file mode 100644
index 0000000..bb7212c
--- /dev/null
+++ b/FreeRTOS/Source/portable/MPLAB/PIC32MX/portmacro.h
@@ -0,0 +1,193 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/* System include files */

+#include <plib.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	unsigned long

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned long portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			8

+#define portSTACK_GROWTH			-1

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/

+

+/* Critical section management. */

+#define portIPL_SHIFT				( 10UL )

+#define portALL_IPL_BITS			( 0x3fUL << portIPL_SHIFT )

+#define portSW0_BIT					( 0x01 << 8 )

+

+/* This clears the IPL bits, then sets them to 

+configMAX_SYSCALL_INTERRUPT_PRIORITY.  This function should not be called

+from an interrupt, so therefore will not be called with an IPL setting

+above configMAX_SYSCALL_INTERRUPT_PRIORITY.  Therefore, when used correctly, the 

+instructions in this macro can only result in the IPL being raised, and 

+therefore never lowered. */

+#define portDISABLE_INTERRUPTS()										\

+{																		\

+unsigned long ulStatus;													\

+																		\

+	/* Mask interrupts at and below the kernel interrupt priority. */	\

+	ulStatus = _CP0_GET_STATUS();										\

+	ulStatus &= ~portALL_IPL_BITS;										\

+	_CP0_SET_STATUS( ( ulStatus | ( configMAX_SYSCALL_INTERRUPT_PRIORITY << portIPL_SHIFT ) ) ); \

+}

+

+#define portENABLE_INTERRUPTS()											\

+{																		\

+unsigned long ulStatus;													\

+																		\

+	/* Unmask all interrupts. */										\

+	ulStatus = _CP0_GET_STATUS();										\

+	ulStatus &= ~portALL_IPL_BITS;										\

+	_CP0_SET_STATUS( ulStatus );										\

+}

+

+

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portCRITICAL_NESTING_IN_TCB	1

+#define portENTER_CRITICAL()		vTaskEnterCritical()

+#define portEXIT_CRITICAL()			vTaskExitCritical()

+

+extern unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR();

+extern void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE );

+#define portSET_INTERRUPT_MASK_FROM_ISR() uxPortSetInterruptMaskFromISR()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusRegister ) vPortClearInterruptMaskFromISR( uxSavedStatusRegister )

+

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+#define portYIELD()								\

+{												\

+unsigned long ulStatus;							\

+												\

+	/* Trigger software interrupt. */			\

+	ulStatus = _CP0_GET_CAUSE();				\

+	ulStatus |= portSW0_BIT;					\

+	_CP0_SET_CAUSE( ulStatus );					\

+}

+

+

+#define portNOP()	asm volatile ( 	"nop" )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters ) __attribute__((noreturn))

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+/*-----------------------------------------------------------*/

+

+#define portEND_SWITCHING_ISR( xSwitchRequired )	if( xSwitchRequired )	\

+													{						\

+														portYIELD();		\

+													}

+

+/* Required by the kernel aware debugger. */

+#ifdef __DEBUG

+	#define portREMOVE_STATIC_QUALIFIER

+#endif

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/MSVC-MingW/port.c b/FreeRTOS/Source/portable/MSVC-MingW/port.c
new file mode 100644
index 0000000..6ff3a75
--- /dev/null
+++ b/FreeRTOS/Source/portable/MSVC-MingW/port.c
@@ -0,0 +1,510 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2011 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+#include <stdio.h>

+

+#define portMAX_INTERRUPTS				( ( unsigned long ) sizeof( unsigned long ) * 8UL ) /* The number of bits in an unsigned long. */

+#define portNO_CRITICAL_NESTING 		( ( unsigned long ) 0 )

+

+/*

+ * Created as a high priority thread, this function uses a timer to simulate

+ * a tick interrupt being generated on an embedded target.  In this Windows

+ * environment the timer does not achieve anything approaching real time 

+ * performance though.

+ */

+static DWORD WINAPI prvSimulatedPeripheralTimer( LPVOID lpParameter );

+

+/* 

+ * Process all the simulated interrupts - each represented by a bit in 

+ * ulPendingInterrupts variable.

+ */

+static void prvProcessSimulatedInterrupts( void );

+

+/*

+ * Interrupt handlers used by the kernel itself.  These are executed from the

+ * simulated interrupt handler thread.

+ */

+static unsigned long prvProcessYieldInterrupt( void );

+static unsigned long prvProcessTickInterrupt( void );

+

+/*-----------------------------------------------------------*/

+

+/* The WIN32 simulator runs each task in a thread.  The context switching is

+managed by the threads, so the task stack does not have to be managed directly,

+although the task stack is still used to hold an xThreadState structure this is

+the only thing it will ever hold.  The structure indirectly maps the task handle 

+to a thread handle. */

+typedef struct

+{

+	/* Handle of the thread that executes the task. */

+	void *pvThread;

+

+} xThreadState;

+

+/* Simulated interrupts waiting to be processed.  This is a bit mask where each

+bit represents one interrupt, so a maximum of 32 interrupts can be simulated. */

+static volatile unsigned long ulPendingInterrupts = 0UL;

+

+/* An event used to inform the simulated interrupt processing thread (a high 

+priority thread that simulated interrupt processing) that an interrupt is

+pending. */

+static void *pvInterruptEvent = NULL;

+

+/* Mutex used to protect all the simulated interrupt variables that are accessed 

+by multiple threads. */

+static void *pvInterruptEventMutex = NULL;

+

+/* The critical nesting count for the currently executing task.  This is 

+initialised to a non-zero value so interrupts do not become enabled during 

+the initialisation phase.  As each task has its own critical nesting value 

+ulCriticalNesting will get set to zero when the first task runs.  This 

+initialisation is probably not critical in this simulated environment as the

+simulated interrupt handlers do not get created until the FreeRTOS scheduler is 

+started anyway. */

+static unsigned long ulCriticalNesting = 9999UL;

+

+/* Handlers for all the simulated software interrupts.  The first two positions

+are used for the Yield and Tick interrupts so are handled slightly differently,

+all the other interrupts can be user defined. */

+static unsigned long (*ulIsrHandler[ portMAX_INTERRUPTS ])( void ) = { 0 };

+

+/* Pointer to the TCB of the currently executing task. */

+extern void *pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+static DWORD WINAPI prvSimulatedPeripheralTimer( LPVOID lpParameter )

+{

+portTickType xMinimumWindowsBlockTime = ( portTickType ) 20;

+

+	/* Just to prevent compiler warnings. */

+	( void ) lpParameter;

+

+	for(;;)

+	{

+		/* Wait until the timer expires and we can access the simulated interrupt 

+		variables.  *NOTE* this is not a 'real time' way of generating tick 

+		events as the next wake time should be relative to the previous wake 

+		time, not the time that Sleep() is called.  It is done this way to 

+		prevent overruns in this very non real time simulated/emulated 

+		environment. */

+		if( portTICK_RATE_MS < xMinimumWindowsBlockTime )

+		{

+			Sleep( xMinimumWindowsBlockTime );

+		}

+		else

+		{

+			Sleep( portTICK_RATE_MS );

+		}

+

+		WaitForSingleObject( pvInterruptEventMutex, INFINITE );

+

+		/* The timer has expired, generate the simulated tick event. */

+		ulPendingInterrupts |= ( 1 << portINTERRUPT_TICK );

+

+		/* The interrupt is now pending - notify the simulated interrupt 

+		handler thread. */

+		SetEvent( pvInterruptEvent );

+

+		/* Give back the mutex so the simulated interrupt handler unblocks 

+		and can	access the interrupt handler variables. */

+		ReleaseMutex( pvInterruptEventMutex );

+	}

+

+	#ifdef __GNUC__

+		/* Should never reach here - MingW complains if you leave this line out,

+		MSVC complains if you put it in. */

+		return 0;

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+xThreadState *pxThreadState = NULL;

+

+	/* In this simulated case a stack is not initialised, but instead a thread

+	is created that will execute the task being created.  The thread handles

+	the context switching itself.  The xThreadState object is placed onto

+	the stack that was created for the task - so the stack buffer is still

+	used, just not in the conventional way.  It will not be used for anything

+	other than holding this structure. */

+	pxThreadState = ( xThreadState * ) ( pxTopOfStack - sizeof( xThreadState ) );

+

+	/* Create the thread itself. */

+	pxThreadState->pvThread = CreateThread( NULL, 0, ( LPTHREAD_START_ROUTINE ) pxCode, pvParameters, CREATE_SUSPENDED, NULL );

+	SetThreadAffinityMask( pxThreadState->pvThread, 0x01 );

+	SetThreadPriorityBoost( pxThreadState->pvThread, TRUE );

+	SetThreadPriority( pxThreadState->pvThread, THREAD_PRIORITY_IDLE );

+	

+	return ( portSTACK_TYPE * ) pxThreadState;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+void *pvHandle;

+long lSuccess = pdPASS;

+xThreadState *pxThreadState;

+

+	/* Install the interrupt handlers used by the scheduler itself. */

+	vPortSetInterruptHandler( portINTERRUPT_YIELD, prvProcessYieldInterrupt );

+	vPortSetInterruptHandler( portINTERRUPT_TICK, prvProcessTickInterrupt );

+

+	/* Create the events and mutexes that are used to synchronise all the

+	threads. */

+	pvInterruptEventMutex = CreateMutex( NULL, FALSE, NULL );

+	pvInterruptEvent = CreateEvent( NULL, FALSE, FALSE, NULL );

+

+	if( ( pvInterruptEventMutex == NULL ) || ( pvInterruptEvent == NULL ) )

+	{

+		lSuccess = pdFAIL;

+	}

+

+	/* Set the priority of this thread such that it is above the priority of 

+	the threads that run tasks.  This higher priority is required to ensure

+	simulated interrupts take priority over tasks. */

+	pvHandle = GetCurrentThread();

+	if( pvHandle == NULL )

+	{

+		lSuccess = pdFAIL;

+	}

+	

+	if( lSuccess == pdPASS )

+	{

+		if( SetThreadPriority( pvHandle, THREAD_PRIORITY_NORMAL ) == 0 )

+		{

+			lSuccess = pdFAIL;

+		}

+		SetThreadPriorityBoost( pvHandle, TRUE );

+		SetThreadAffinityMask( pvHandle, 0x01 );

+	}

+

+	if( lSuccess == pdPASS )

+	{

+		/* Start the thread that simulates the timer peripheral to generate

+		tick interrupts.  The priority is set below that of the simulated 

+		interrupt handler so the interrupt event mutex is used for the

+		handshake / overrun protection. */

+		pvHandle = CreateThread( NULL, 0, prvSimulatedPeripheralTimer, NULL, 0, NULL );

+		if( pvHandle != NULL )

+		{

+			SetThreadPriority( pvHandle, THREAD_PRIORITY_BELOW_NORMAL );

+			SetThreadPriorityBoost( pvHandle, TRUE );

+			SetThreadAffinityMask( pvHandle, 0x01 );

+		}

+		

+		/* Start the highest priority task by obtaining its associated thread 

+		state structure, in which is stored the thread handle. */

+		pxThreadState = ( xThreadState * ) *( ( unsigned long * ) pxCurrentTCB );

+		ulCriticalNesting = portNO_CRITICAL_NESTING;

+

+		/* Bump up the priority of the thread that is going to run, in the

+		hope that this will asist in getting the Windows thread scheduler to

+		behave as an embedded engineer might expect. */

+		ResumeThread( pxThreadState->pvThread );

+

+		/* Handle all simulated interrupts - including yield requests and 

+		simulated ticks. */

+		prvProcessSimulatedInterrupts();

+	}	

+	

+	/* Would not expect to return from prvProcessSimulatedInterrupts(), so should 

+	not get here. */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+static unsigned long prvProcessYieldInterrupt( void )

+{

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+static unsigned long prvProcessTickInterrupt( void )

+{

+unsigned long ulSwitchRequired;

+

+	/* Process the tick itself. */

+	vTaskIncrementTick();

+	#if( configUSE_PREEMPTION != 0 )

+	{

+		/* A context switch is only automatically performed from the tick

+		interrupt if the pre-emptive scheduler is being used. */

+		ulSwitchRequired = pdTRUE;

+	}

+	#else

+	{

+		ulSwitchRequired = pdFALSE;

+	}

+	#endif

+

+	return ulSwitchRequired;

+}

+/*-----------------------------------------------------------*/

+

+static void prvProcessSimulatedInterrupts( void )

+{

+unsigned long ulSwitchRequired, i;

+xThreadState *pxThreadState;

+void *pvObjectList[ 2 ];

+

+	/* Going to block on the mutex that ensured exclusive access to the simulated 

+	interrupt objects, and the event that signals that a simulated interrupt

+	should be processed. */

+	pvObjectList[ 0 ] = pvInterruptEventMutex;

+	pvObjectList[ 1 ] = pvInterruptEvent;

+

+	for(;;)

+	{

+		WaitForMultipleObjects( sizeof( pvObjectList ) / sizeof( void * ), pvObjectList, TRUE, INFINITE );

+

+		/* Used to indicate whether the simulated interrupt processing has

+		necessitated a context switch to another task/thread. */

+		ulSwitchRequired = pdFALSE;

+

+		/* For each interrupt we are interested in processing, each of which is

+		represented by a bit in the 32bit ulPendingInterrupts variable. */

+		for( i = 0; i < portMAX_INTERRUPTS; i++ )

+		{

+			/* Is the simulated interrupt pending? */

+			if( ulPendingInterrupts & ( 1UL << i ) )

+			{

+				/* Is a handler installed? */

+				if( ulIsrHandler[ i ] != NULL )

+				{

+					/* Run the actual handler. */

+					if( ulIsrHandler[ i ]() != pdFALSE )

+					{

+						ulSwitchRequired |= ( 1 << i );

+					}

+				}

+

+				/* Clear the interrupt pending bit. */

+				ulPendingInterrupts &= ~( 1UL << i );

+			}

+		}

+

+		if( ulSwitchRequired != pdFALSE )

+		{

+			void *pvOldCurrentTCB;

+

+			pvOldCurrentTCB = pxCurrentTCB;

+

+			/* Select the next task to run. */

+			vTaskSwitchContext();

+

+			/* If the task selected to enter the running state is not the task

+			that is already in the running state. */

+			if( pvOldCurrentTCB != pxCurrentTCB )

+			{

+				/* Suspend the old thread. */

+				pxThreadState = ( xThreadState *) *( ( unsigned long * ) pvOldCurrentTCB );

+				SuspendThread( pxThreadState->pvThread );

+

+				/* Obtain the state of the task now selected to enter the 

+				Running state. */

+				pxThreadState = ( xThreadState * ) ( *( unsigned long *) pxCurrentTCB );

+				ResumeThread( pxThreadState->pvThread );

+			}

+		}

+

+		ReleaseMutex( pvInterruptEventMutex );

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortDeleteThread( void *pvTaskToDelete )

+{

+xThreadState *pxThreadState;

+

+	WaitForSingleObject( pvInterruptEventMutex, INFINITE );

+

+	/* Find the handle of the thread being deleted. */

+	pxThreadState = ( xThreadState * ) ( *( unsigned long *) pvTaskToDelete );

+	TerminateThread( pxThreadState->pvThread, 0 );

+

+	ReleaseMutex( pvInterruptEventMutex );

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* This function IS NOT TESTED! */

+	TerminateProcess( GetCurrentProcess(), 0 );

+}

+/*-----------------------------------------------------------*/

+

+void vPortGenerateSimulatedInterrupt( unsigned long ulInterruptNumber )

+{

+xThreadState *pxThreadState;

+

+	if( ( ulInterruptNumber < portMAX_INTERRUPTS ) && ( pvInterruptEventMutex != NULL ) )

+	{

+		/* Yield interrupts are processed even when critical nesting is non-zero. */

+		WaitForSingleObject( pvInterruptEventMutex, INFINITE );

+		ulPendingInterrupts |= ( 1 << ulInterruptNumber );

+

+		/* The simulated interrupt is now held pending, but don't actually process it

+		yet if this call is within a critical section.  It is possible for this to

+		be in a critical section as calls to wait for mutexes are accumulative. */

+		if( ulCriticalNesting == 0 )

+		{

+			/* The event handler needs to know to signal the interrupt acknowledge event

+			the next time this task runs. */

+			pxThreadState = ( xThreadState * ) *( ( unsigned long * ) pxCurrentTCB );

+			SetEvent( pvInterruptEvent );			

+		}

+

+		ReleaseMutex( pvInterruptEventMutex );

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortSetInterruptHandler( unsigned long ulInterruptNumber, unsigned long (*pvHandler)( void ) )

+{

+	if( ulInterruptNumber < portMAX_INTERRUPTS )

+	{

+		if( pvInterruptEventMutex != NULL )

+		{

+			WaitForSingleObject( pvInterruptEventMutex, INFINITE );

+			ulIsrHandler[ ulInterruptNumber ] = pvHandler;

+			ReleaseMutex( pvInterruptEventMutex );

+		}

+		else

+		{

+			ulIsrHandler[ ulInterruptNumber ] = pvHandler;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	if( xTaskGetSchedulerState() != taskSCHEDULER_NOT_STARTED )

+	{

+		/* The interrupt event mutex is held for the entire critical section,

+		effectively disabling (simulated) interrupts. */

+		WaitForSingleObject( pvInterruptEventMutex, INFINITE );

+		ulCriticalNesting++;

+	}

+	else

+	{

+		ulCriticalNesting++;

+	}	

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+xThreadState *pxThreadState;

+long lMutexNeedsReleasing;

+

+	/* The interrupt event mutex should already be held by this thread as it was

+	obtained on entry to the critical section. */

+

+	lMutexNeedsReleasing = pdTRUE;

+

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		if( ulCriticalNesting == ( portNO_CRITICAL_NESTING + 1 ) )

+		{

+			ulCriticalNesting--;

+

+			/* Were any interrupts set to pending while interrupts were 

+			(simulated) disabled? */

+			if( ulPendingInterrupts != 0UL )

+			{

+				SetEvent( pvInterruptEvent );

+

+				/* The event handler needs to know to signal the interrupt 

+				acknowledge event the next time this task runs. */

+				pxThreadState = ( xThreadState * ) *( ( unsigned long * ) pxCurrentTCB );

+

+				/* Mutex will be released now, so does not require releasing

+				on function exit. */

+				lMutexNeedsReleasing = pdFALSE;

+				ReleaseMutex( pvInterruptEventMutex );

+			}

+		}

+		else

+		{

+			/* Tick interrupts will still not be processed as the critical

+			nesting depth will not be zero. */

+			ulCriticalNesting--;

+		}

+	}

+

+	if( lMutexNeedsReleasing == pdTRUE )

+	{

+		ReleaseMutex( pvInterruptEventMutex );

+	}

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/MSVC-MingW/portmacro.h b/FreeRTOS/Source/portable/MSVC-MingW/portmacro.h
new file mode 100644
index 0000000..484aac5
--- /dev/null
+++ b/FreeRTOS/Source/portable/MSVC-MingW/portmacro.h
@@ -0,0 +1,137 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2011 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include <Windows.h>

+

+/******************************************************************************

+	Defines

+******************************************************************************/

+/* Type definitions. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+    typedef unsigned portSHORT portTickType;

+    #define portMAX_DELAY ( portTickType ) 0xffff

+#else

+    typedef unsigned portLONG portTickType;

+    #define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )	

+#define portBYTE_ALIGNMENT			4

+

+#define portYIELD()					vPortGenerateSimulatedInterrupt( portINTERRUPT_YIELD )

+

+void vPortDeleteThread( void *pvThreadToDelete );

+#define portCLEAN_UP_TCB( pxTCB )	vPortDeleteThread( pxTCB )

+#define portDISABLE_INTERRUPTS()

+#define portENABLE_INTERRUPTS()

+

+/* Critical section handling. */

+void vPortEnterCritical( void );

+void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void * pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void * pvParameters )

+

+

+#define portINTERRUPT_YIELD				( 0UL )

+#define portINTERRUPT_TICK				( 1UL )

+

+/* 

+ * Raise a simulated interrupt represented by the bit mask in ulInterruptMask.

+ * Each bit can be used to represent an individual interrupt - with the first

+ * two bits being used for the Yield and Tick interrupts respectively.

+*/

+void vPortGenerateSimulatedInterrupt( unsigned long ulInterruptNumber );

+

+/*

+ * Install an interrupt handler to be called by the simulated interrupt handler 

+ * thread.  The interrupt number must be above any used by the kernel itself

+ * (at the time of writing the kernel was using interrupt numbers 0, 1, and 2

+ * as defined above).  The number must also be lower than 32. 

+ *

+ * Interrupt handler functions must return a non-zero value if executing the

+ * handler resulted in a task switch being required. 

+ */

+void vPortSetInterruptHandler( unsigned long ulInterruptNumber, unsigned long (*pvHandler)( void ) );

+

+#endif

diff --git a/FreeRTOS/Source/portable/MemMang/heap_1.c b/FreeRTOS/Source/portable/MemMang/heap_1.c
new file mode 100644
index 0000000..fa45fc3
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_1.c
@@ -0,0 +1,168 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*

+ * The simplest possible implementation of pvPortMalloc().  Note that this

+ * implementation does NOT allow allocated memory to be freed again.

+ *

+ * See heap_2.c, heap_3.c and heap_4.c for alternative implementations, and the 

+ * memory management pages of http://www.FreeRTOS.org for more information.

+ */

+#include <stdlib.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* Allocate the memory for the heap.  The struct is used to force byte

+alignment without using any non-portable code. */

+static union xRTOS_HEAP

+{

+	#if portBYTE_ALIGNMENT == 8

+		volatile portDOUBLE dDummy;

+	#else

+		volatile unsigned long ulDummy;

+	#endif	

+	unsigned char ucHeap[ configTOTAL_HEAP_SIZE ];

+} xHeap;

+

+static size_t xNextFreeByte = ( size_t ) 0;

+/*-----------------------------------------------------------*/

+

+void *pvPortMalloc( size_t xWantedSize )

+{

+void *pvReturn = NULL; 

+

+	/* Ensure that blocks are always aligned to the required number of bytes. */

+	#if portBYTE_ALIGNMENT != 1

+		if( xWantedSize & portBYTE_ALIGNMENT_MASK )

+		{

+			/* Byte alignment required. */

+			xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );

+		}

+	#endif

+

+	vTaskSuspendAll();

+	{

+		/* Check there is enough room left for the allocation. */

+		if( ( ( xNextFreeByte + xWantedSize ) < configTOTAL_HEAP_SIZE ) &&

+			( ( xNextFreeByte + xWantedSize ) > xNextFreeByte )	)/* Check for overflow. */

+		{

+			/* Return the next free byte then increment the index past this

+			block. */

+			pvReturn = &( xHeap.ucHeap[ xNextFreeByte ] );

+			xNextFreeByte += xWantedSize;			

+		}	

+	}

+	xTaskResumeAll();

+	

+	#if( configUSE_MALLOC_FAILED_HOOK == 1 )

+	{

+		if( pvReturn == NULL )

+		{

+			extern void vApplicationMallocFailedHook( void );

+			vApplicationMallocFailedHook();

+		}

+	}

+	#endif	

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vPortFree( void *pv )

+{

+	/* Memory cannot be freed using this scheme.  See heap_2.c, heap_3.c and

+	heap_4.c for alternative implementations, and the memory management pages of 

+	http://www.FreeRTOS.org for more information. */

+	( void ) pv;

+	

+	/* Force an assert as it is invalid to call this function. */

+	configASSERT( pv == NULL );

+}

+/*-----------------------------------------------------------*/

+

+void vPortInitialiseBlocks( void )

+{

+	/* Only required when static memory is not cleared. */

+	xNextFreeByte = ( size_t ) 0;

+}

+/*-----------------------------------------------------------*/

+

+size_t xPortGetFreeHeapSize( void )

+{

+	return ( configTOTAL_HEAP_SIZE - xNextFreeByte );

+}

+

+

+

diff --git a/FreeRTOS/Source/portable/MemMang/heap_2.c b/FreeRTOS/Source/portable/MemMang/heap_2.c
new file mode 100644
index 0000000..21578d9
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_2.c
@@ -0,0 +1,292 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * A sample implementation of pvPortMalloc() and vPortFree() that permits

+ * allocated blocks to be freed, but does not combine adjacent free blocks

+ * into a single larger block (and so will fragment memory).  See heap_4.c for 

+ * an aquivalent that does combine adjacent blocks into single larger blocks.

+ *

+ * See heap_1.c, heap_3.c and heap_4.c for alternative implementations, and the 

+ * memory management pages of http://www.FreeRTOS.org for more information.

+ */

+#include <stdlib.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* Allocate the memory for the heap.  The struct is used to force byte

+alignment without using any non-portable code. */

+static union xRTOS_HEAP

+{

+	#if portBYTE_ALIGNMENT == 8

+		volatile portDOUBLE dDummy;

+	#else

+		volatile unsigned long ulDummy;

+	#endif

+	unsigned char ucHeap[ configTOTAL_HEAP_SIZE ];

+} xHeap;

+

+/* Define the linked list structure.  This is used to link free blocks in order

+of their size. */

+typedef struct A_BLOCK_LINK

+{

+	struct A_BLOCK_LINK *pxNextFreeBlock;	/*<< The next free block in the list. */

+	size_t xBlockSize;						/*<< The size of the free block. */

+} xBlockLink;

+

+

+static const unsigned short  heapSTRUCT_SIZE	= ( sizeof( xBlockLink ) + portBYTE_ALIGNMENT - ( sizeof( xBlockLink ) % portBYTE_ALIGNMENT ) );

+#define heapMINIMUM_BLOCK_SIZE	( ( size_t ) ( heapSTRUCT_SIZE * 2 ) )

+

+/* Create a couple of list links to mark the start and end of the list. */

+static xBlockLink xStart, xEnd;

+

+/* Keeps track of the number of free bytes remaining, but says nothing about

+fragmentation. */

+static size_t xFreeBytesRemaining = configTOTAL_HEAP_SIZE;

+

+/* STATIC FUNCTIONS ARE DEFINED AS MACROS TO MINIMIZE THE FUNCTION CALL DEPTH. */

+

+/*

+ * Insert a block into the list of free blocks - which is ordered by size of

+ * the block.  Small blocks at the start of the list and large blocks at the end

+ * of the list.

+ */

+#define prvInsertBlockIntoFreeList( pxBlockToInsert )								\

+{																					\

+xBlockLink *pxIterator;																\

+size_t xBlockSize;																	\

+																					\

+	xBlockSize = pxBlockToInsert->xBlockSize;										\

+																					\

+	/* Iterate through the list until a block is found that has a larger size */	\

+	/* than the block we are inserting. */											\

+	for( pxIterator = &xStart; pxIterator->pxNextFreeBlock->xBlockSize < xBlockSize; pxIterator = pxIterator->pxNextFreeBlock )	\

+	{																				\

+		/* There is nothing to do here - just iterate to the correct position. */	\

+	}																				\

+																					\

+	/* Update the list to include the block being inserted in the correct */		\

+	/* position. */																	\

+	pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock;					\

+	pxIterator->pxNextFreeBlock = pxBlockToInsert;									\

+}

+/*-----------------------------------------------------------*/

+

+#define prvHeapInit()																\

+{																					\

+xBlockLink *pxFirstFreeBlock;														\

+																					\

+	/* xStart is used to hold a pointer to the first item in the list of free */	\

+	/* blocks.  The void cast is used to prevent compiler warnings. */				\

+	xStart.pxNextFreeBlock = ( void * ) xHeap.ucHeap;								\

+	xStart.xBlockSize = ( size_t ) 0;												\

+																					\

+	/* xEnd is used to mark the end of the list of free blocks. */					\

+	xEnd.xBlockSize = configTOTAL_HEAP_SIZE;										\

+	xEnd.pxNextFreeBlock = NULL;													\

+																					\

+	/* To start with there is a single free block that is sized to take up the		\

+	entire heap space. */															\

+	pxFirstFreeBlock = ( void * ) xHeap.ucHeap;										\

+	pxFirstFreeBlock->xBlockSize = configTOTAL_HEAP_SIZE;							\

+	pxFirstFreeBlock->pxNextFreeBlock = &xEnd;										\

+}

+/*-----------------------------------------------------------*/

+

+void *pvPortMalloc( size_t xWantedSize )

+{

+xBlockLink *pxBlock, *pxPreviousBlock, *pxNewBlockLink;

+static portBASE_TYPE xHeapHasBeenInitialised = pdFALSE;

+void *pvReturn = NULL;

+

+	vTaskSuspendAll();

+	{

+		/* If this is the first call to malloc then the heap will require

+		initialisation to setup the list of free blocks. */

+		if( xHeapHasBeenInitialised == pdFALSE )

+		{

+			prvHeapInit();

+			xHeapHasBeenInitialised = pdTRUE;

+		}

+

+		/* The wanted size is increased so it can contain a xBlockLink

+		structure in addition to the requested amount of bytes. */

+		if( xWantedSize > 0 )

+		{

+			xWantedSize += heapSTRUCT_SIZE;

+

+			/* Ensure that blocks are always aligned to the required number of bytes. */

+			if( xWantedSize & portBYTE_ALIGNMENT_MASK )

+			{

+				/* Byte alignment required. */

+				xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );

+			}

+		}

+

+		if( ( xWantedSize > 0 ) && ( xWantedSize < configTOTAL_HEAP_SIZE ) )

+		{

+			/* Blocks are stored in byte order - traverse the list from the start

+			(smallest) block until one of adequate size is found. */

+			pxPreviousBlock = &xStart;

+			pxBlock = xStart.pxNextFreeBlock;

+			while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) )

+			{

+				pxPreviousBlock = pxBlock;

+				pxBlock = pxBlock->pxNextFreeBlock;

+			}

+

+			/* If we found the end marker then a block of adequate size was not found. */

+			if( pxBlock != &xEnd )

+			{

+				/* Return the memory space - jumping over the xBlockLink structure

+				at its start. */

+				pvReturn = ( void * ) ( ( ( unsigned char * ) pxPreviousBlock->pxNextFreeBlock ) + heapSTRUCT_SIZE );

+

+				/* This block is being returned for use so must be taken out of the

+				list of free blocks. */

+				pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock;

+

+				/* If the block is larger than required it can be split into two. */

+				if( ( pxBlock->xBlockSize - xWantedSize ) > heapMINIMUM_BLOCK_SIZE )

+				{

+					/* This block is to be split into two.  Create a new block

+					following the number of bytes requested. The void cast is

+					used to prevent byte alignment warnings from the compiler. */

+					pxNewBlockLink = ( void * ) ( ( ( unsigned char * ) pxBlock ) + xWantedSize );

+

+					/* Calculate the sizes of two blocks split from the single

+					block. */

+					pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;

+					pxBlock->xBlockSize = xWantedSize;

+

+					/* Insert the new block into the list of free blocks. */

+					prvInsertBlockIntoFreeList( ( pxNewBlockLink ) );

+				}

+				

+				xFreeBytesRemaining -= pxBlock->xBlockSize;

+			}

+		}

+	}

+	xTaskResumeAll();

+

+	#if( configUSE_MALLOC_FAILED_HOOK == 1 )

+	{

+		if( pvReturn == NULL )

+		{

+			extern void vApplicationMallocFailedHook( void );

+			vApplicationMallocFailedHook();

+		}

+	}

+	#endif

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vPortFree( void *pv )

+{

+unsigned char *puc = ( unsigned char * ) pv;

+xBlockLink *pxLink;

+

+	if( pv != NULL )

+	{

+		/* The memory being freed will have an xBlockLink structure immediately

+		before it. */

+		puc -= heapSTRUCT_SIZE;

+

+		/* This casting is to keep the compiler from issuing warnings. */

+		pxLink = ( void * ) puc;

+

+		vTaskSuspendAll();

+		{

+			/* Add this block to the list of free blocks. */

+			prvInsertBlockIntoFreeList( ( ( xBlockLink * ) pxLink ) );

+			xFreeBytesRemaining += pxLink->xBlockSize;

+		}

+		xTaskResumeAll();

+	}

+}

+/*-----------------------------------------------------------*/

+

+size_t xPortGetFreeHeapSize( void )

+{

+	return xFreeBytesRemaining;

+}

+/*-----------------------------------------------------------*/

+

+void vPortInitialiseBlocks( void )

+{

+	/* This just exists to keep the linker quiet. */

+}

diff --git a/FreeRTOS/Source/portable/MemMang/heap_3.c b/FreeRTOS/Source/portable/MemMang/heap_3.c
new file mode 100644
index 0000000..636dac0
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_3.c
@@ -0,0 +1,130 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*

+ * Implementation of pvPortMalloc() and vPortFree() that relies on the

+ * compilers own malloc() and free() implementations.

+ *

+ * This file can only be used if the linker is configured to to generate

+ * a heap memory area.

+ *

+ * See heap_1.c, heap_2.c and heap_4.c for alternative implementations, and the 

+ * memory management pages of http://www.FreeRTOS.org for more information.

+ */

+

+#include <stdlib.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/*-----------------------------------------------------------*/

+

+void *pvPortMalloc( size_t xWantedSize )

+{

+void *pvReturn;

+

+	vTaskSuspendAll();

+	{

+		pvReturn = malloc( xWantedSize );

+	}

+	xTaskResumeAll();

+

+	#if( configUSE_MALLOC_FAILED_HOOK == 1 )

+	{

+		if( pvReturn == NULL )

+		{

+			extern void vApplicationMallocFailedHook( void );

+			vApplicationMallocFailedHook();

+		}

+	}

+	#endif

+	

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vPortFree( void *pv )

+{

+	if( pv )

+	{

+		vTaskSuspendAll();

+		{

+			free( pv );

+		}

+		xTaskResumeAll();

+	}

+}

+

+

+

diff --git a/FreeRTOS/Source/portable/MemMang/heap_4.c b/FreeRTOS/Source/portable/MemMang/heap_4.c
new file mode 100644
index 0000000..3210b3c
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_4.c
@@ -0,0 +1,357 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+

+    http://www.FreeRTOS.org - Documentation, training, latest information,

+    license and contact details.

+

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell

+    the code with commercial support, indemnification, and middleware, under

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+ * A sample implementation of pvPortMalloc() and vPortFree() that combines 

+ * (coalescences) adjacent memory blocks as they are freed, and in so doing 

+ * limits memory fragmentation.

+ *

+ * See heap_1.c, heap_2.c and heap_3.c for alternative implementations, and the 

+ * memory management pages of http://www.FreeRTOS.org for more information.

+ */

+#include <stdlib.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* Block sizes must not get too small. */

+#define heapMINIMUM_BLOCK_SIZE	( ( size_t ) ( heapSTRUCT_SIZE * 2 ) )

+

+/* Allocate the memory for the heap.  The struct is used to force byte

+alignment without using any non-portable code. */

+static union xRTOS_HEAP

+{

+	#if portBYTE_ALIGNMENT == 8

+		volatile portDOUBLE dDummy;

+	#else

+		volatile unsigned long ulDummy;

+	#endif

+	unsigned char ucHeap[ configTOTAL_HEAP_SIZE ];

+} xHeap;

+

+/* Define the linked list structure.  This is used to link free blocks in order

+of their memory address. */

+typedef struct A_BLOCK_LINK

+{

+	struct A_BLOCK_LINK *pxNextFreeBlock;	/*<< The next free block in the list. */

+	size_t xBlockSize;						/*<< The size of the free block. */

+} xBlockLink;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Inserts a block of memory that is being freed into the correct position in 

+ * the list of free memory blocks.  The block being freed will be merged with

+ * the block in front it and/or the block behind it if the memory blocks are

+ * adjacent to each other.

+ */

+static void prvInsertBlockIntoFreeList( xBlockLink *pxBlockToInsert );

+

+/*

+ * Called automatically to setup the required heap structures the first time

+ * pvPortMalloc() is called.

+ */

+static void prvHeapInit( void );

+

+/*-----------------------------------------------------------*/

+

+/* The size of the structure placed at the beginning of each allocated memory

+block must by correctly byte aligned. */

+static const unsigned short heapSTRUCT_SIZE	= ( sizeof( xBlockLink ) + portBYTE_ALIGNMENT - ( sizeof( xBlockLink ) % portBYTE_ALIGNMENT ) );

+

+/* Ensure the pxEnd pointer will end up on the correct byte alignment. */

+static const size_t xTotalHeapSize = ( ( size_t ) configTOTAL_HEAP_SIZE ) & ( ( size_t ) ~portBYTE_ALIGNMENT_MASK );

+

+/* Create a couple of list links to mark the start and end of the list. */

+static xBlockLink xStart, *pxEnd = NULL;

+

+/* Keeps track of the number of free bytes remaining, but says nothing about

+fragmentation. */

+static size_t xFreeBytesRemaining = ( ( size_t ) configTOTAL_HEAP_SIZE ) & ( ( size_t ) ~portBYTE_ALIGNMENT_MASK );

+

+/* STATIC FUNCTIONS ARE DEFINED AS MACROS TO MINIMIZE THE FUNCTION CALL DEPTH. */

+

+/*-----------------------------------------------------------*/

+

+void *pvPortMalloc( size_t xWantedSize )

+{

+xBlockLink *pxBlock, *pxPreviousBlock, *pxNewBlockLink;

+void *pvReturn = NULL;

+

+	vTaskSuspendAll();

+	{

+		/* If this is the first call to malloc then the heap will require

+		initialisation to setup the list of free blocks. */

+		if( pxEnd == NULL )

+		{

+			prvHeapInit();

+		}

+

+		/* The wanted size is increased so it can contain a xBlockLink

+		structure in addition to the requested amount of bytes. */

+		if( xWantedSize > 0 )

+		{

+			xWantedSize += heapSTRUCT_SIZE;

+

+			/* Ensure that blocks are always aligned to the required number of 

+			bytes. */

+			if( xWantedSize & portBYTE_ALIGNMENT_MASK )

+			{

+				/* Byte alignment required. */

+				xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );

+			}

+		}

+

+		if( ( xWantedSize > 0 ) && ( xWantedSize < xTotalHeapSize ) )

+		{

+			/* Traverse the list from the start	(lowest address) block until one

+			of adequate size is found. */

+			pxPreviousBlock = &xStart;

+			pxBlock = xStart.pxNextFreeBlock;

+			while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) )

+			{

+				pxPreviousBlock = pxBlock;

+				pxBlock = pxBlock->pxNextFreeBlock;

+			}

+

+			/* If the end marker was reached then a block of adequate size was

+			not found. */

+			if( pxBlock != pxEnd )

+			{

+				/* Return the memory space - jumping over the xBlockLink structure

+				at its start. */

+				pvReturn = ( void * ) ( ( ( unsigned char * ) pxPreviousBlock->pxNextFreeBlock ) + heapSTRUCT_SIZE );

+

+				/* This block is being returned for use so must be taken out of

+				the	list of free blocks. */

+				pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock;

+

+				/* If the block is larger than required it can be split into two. */

+				if( ( pxBlock->xBlockSize - xWantedSize ) > heapMINIMUM_BLOCK_SIZE )

+				{

+					/* This block is to be split into two.  Create a new block

+					following the number of bytes requested. The void cast is

+					used to prevent byte alignment warnings from the compiler. */

+					pxNewBlockLink = ( void * ) ( ( ( unsigned char * ) pxBlock ) + xWantedSize );

+

+					/* Calculate the sizes of two blocks split from the single

+					block. */

+					pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;

+					pxBlock->xBlockSize = xWantedSize;

+

+					/* Insert the new block into the list of free blocks. */

+					prvInsertBlockIntoFreeList( ( pxNewBlockLink ) );

+				}

+

+				xFreeBytesRemaining -= pxBlock->xBlockSize;

+			}

+		}

+	}

+	xTaskResumeAll();

+

+	#if( configUSE_MALLOC_FAILED_HOOK == 1 )

+	{

+		if( pvReturn == NULL )

+		{

+			extern void vApplicationMallocFailedHook( void );

+			vApplicationMallocFailedHook();

+		}

+	}

+	#endif

+

+	return pvReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vPortFree( void *pv )

+{

+unsigned char *puc = ( unsigned char * ) pv;

+xBlockLink *pxLink;

+

+	if( pv != NULL )

+	{

+		/* The memory being freed will have an xBlockLink structure immediately

+		before it. */

+		puc -= heapSTRUCT_SIZE;

+

+		/* This casting is to keep the compiler from issuing warnings. */

+		pxLink = ( void * ) puc;

+

+		vTaskSuspendAll();

+		{

+			/* Add this block to the list of free blocks. */

+			xFreeBytesRemaining += pxLink->xBlockSize;

+			prvInsertBlockIntoFreeList( ( ( xBlockLink * ) pxLink ) );			

+		}

+		xTaskResumeAll();

+	}

+}

+/*-----------------------------------------------------------*/

+

+size_t xPortGetFreeHeapSize( void )

+{

+	return xFreeBytesRemaining;

+}

+/*-----------------------------------------------------------*/

+

+void vPortInitialiseBlocks( void )

+{

+	/* This just exists to keep the linker quiet. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvHeapInit( void )

+{

+xBlockLink *pxFirstFreeBlock;

+unsigned char *pucHeapEnd;

+

+	/* Ensure the start of the heap is aligned. */

+	configASSERT( ( ( ( unsigned long ) xHeap.ucHeap ) & ( ( unsigned long ) portBYTE_ALIGNMENT_MASK ) ) == 0UL );

+

+	/* xStart is used to hold a pointer to the first item in the list of free

+	blocks.  The void cast is used to prevent compiler warnings. */

+	xStart.pxNextFreeBlock = ( void * ) xHeap.ucHeap;

+	xStart.xBlockSize = ( size_t ) 0;

+

+	/* pxEnd is used to mark the end of the list of free blocks and is inserted

+	at the end of the heap space. */

+	pucHeapEnd = xHeap.ucHeap + xTotalHeapSize;

+	pucHeapEnd -= heapSTRUCT_SIZE;

+	pxEnd = ( void * ) pucHeapEnd;

+	configASSERT( ( ( ( unsigned long ) pxEnd ) & ( ( unsigned long ) portBYTE_ALIGNMENT_MASK ) ) == 0UL );

+	pxEnd->xBlockSize = 0;

+	pxEnd->pxNextFreeBlock = NULL;

+

+	/* To start with there is a single free block that is sized to take up the

+	entire heap space, minus the space taken by pxEnd. */

+	pxFirstFreeBlock = ( void * ) xHeap.ucHeap;

+	pxFirstFreeBlock->xBlockSize = xTotalHeapSize - heapSTRUCT_SIZE;

+	pxFirstFreeBlock->pxNextFreeBlock = pxEnd;

+

+	/* The heap now contains pxEnd. */

+	xFreeBytesRemaining -= heapSTRUCT_SIZE;

+}

+/*-----------------------------------------------------------*/

+

+static void prvInsertBlockIntoFreeList( xBlockLink *pxBlockToInsert )

+{

+xBlockLink *pxIterator;

+unsigned char *puc;

+

+	/* Iterate through the list until a block is found that has a higher address

+	than the block being inserted. */

+	for( pxIterator = &xStart; pxIterator->pxNextFreeBlock < pxBlockToInsert; pxIterator = pxIterator->pxNextFreeBlock )

+	{

+		/* Nothing to do here, just iterate to the right position. */

+	}

+

+	/* Do the block being inserted, and the block it is being inserted after

+	make a contiguous block of memory? */	

+	puc = ( unsigned char * ) pxIterator;

+	if( ( puc + pxIterator->xBlockSize ) == ( unsigned char * ) pxBlockToInsert )

+	{

+		pxIterator->xBlockSize += pxBlockToInsert->xBlockSize;

+		pxBlockToInsert = pxIterator;

+	}

+

+	/* Do the block being inserted, and the block it is being inserted before

+	make a contiguous block of memory? */

+	puc = ( unsigned char * ) pxBlockToInsert;

+	if( ( puc + pxBlockToInsert->xBlockSize ) == ( unsigned char * ) pxIterator->pxNextFreeBlock )

+	{

+		if( pxIterator->pxNextFreeBlock != pxEnd )

+		{

+			/* Form one big block from the two blocks. */

+			pxBlockToInsert->xBlockSize += pxIterator->pxNextFreeBlock->xBlockSize;

+			pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock->pxNextFreeBlock;

+		}

+		else

+		{

+			pxBlockToInsert->pxNextFreeBlock = pxEnd;

+		}

+	}

+	else

+	{

+		pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock;		

+	}

+

+	/* If the block being inserted plugged a gab, so was merged with the block

+	before and the block after, then it's pxNextFreeBlock pointer will have

+	already been set, and should not be set here as that would make it point

+	to itself. */

+	if( pxIterator != pxBlockToInsert )

+	{

+		pxIterator->pxNextFreeBlock = pxBlockToInsert;

+	}

+}

+

diff --git a/FreeRTOS/Source/portable/MemMang/heap_error.c b/FreeRTOS/Source/portable/MemMang/heap_error.c
new file mode 100644
index 0000000..b0cf17a
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_error.c
@@ -0,0 +1,34 @@
+#include <stdlib.h>
+
+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining
+all the API functions to use the MPU wrappers.  That should only be done when
+task.h is included from an application file. */
+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE
+
+#include "FreeRTOS.h"
+#include "task.h"
+
+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE
+
+
+void *pvPortMalloc( size_t xWantedSize )
+{	
+	#if( configUSE_MALLOC_FAILED_HOOK == 1 )
+	{
+        extern void vApplicationMallocFailedHook( void );
+        vApplicationMallocFailedHook();
+	}
+	#endif
+
+	configASSERT( NULL );
+
+	return NULL;
+}
+/*-----------------------------------------------------------*/
+
+void vPortFree( void *pv )
+{	
+	/* Force an assert as it is invalid to call this function. */
+	configASSERT( pv == NULL );
+}
+
diff --git a/FreeRTOS/Source/portable/MemMang/heap_posix.c b/FreeRTOS/Source/portable/MemMang/heap_posix.c
new file mode 100644
index 0000000..c800f9f
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/heap_posix.c
@@ -0,0 +1,26 @@
+#include <stdlib.h>
+
+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining
+all the API functions to use the MPU wrappers.  That should only be done when
+task.h is included from an application file. */
+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE
+
+#include "FreeRTOS.h"
+#include "task.h"
+
+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE
+
+
+void *pvPortMalloc( size_t xWantedSize )
+{	
+	return malloc(xWantedSize);
+}
+/*-----------------------------------------------------------*/
+
+void vPortFree( void *pv )
+{	
+	/* Force an assert as it is invalid to call this function. */
+	configASSERT( pv == NULL );
+    free(pv);
+}
+
diff --git a/FreeRTOS/Source/portable/MemMang/static-allocator.c b/FreeRTOS/Source/portable/MemMang/static-allocator.c
new file mode 100644
index 0000000..224ec6b
--- /dev/null
+++ b/FreeRTOS/Source/portable/MemMang/static-allocator.c
@@ -0,0 +1,151 @@
+
+#include "FreeRTOS.h"
+#include "static-allocator.h"
+#include <stdlib.h>
+#include <stdio.h>
+#include "task.h"
+
+typedef struct priv_static_pool_s {
+    uint8_t*  backing_store;
+    uint32_t* flags;
+    int       item_size;
+    int       num_items;
+} priv_static_pool_t;
+
+#ifdef PORTABLE_ARCH_ARM_CM3
+__attribute__( ( always_inline ) ) static inline uint8_t __CLZ(uint32_t value)
+{
+    uint8_t result;
+    __asm__ volatile ("clz %0, %1" : "=r" (result) : "r" (value) );
+    return(result);
+}
+#else
+__attribute__( ( always_inline ) ) static inline uint8_t __CLZ(uint32_t value)
+{
+    uint8_t result = 0;
+    uint32_t mask = 0x1<<31;
+    int i;
+
+    for (i = 0; i < 32; i++)
+    {
+        if ((mask & value) != 0)
+        {
+            break;
+        }
+        result++;
+        mask >>= 1;
+    }
+    return result;
+}
+#endif
+
+#ifdef PORTABLE_ARCH_ARM_CM3
+__attribute__((naked)) static void atomicClearFlag( uint32_t* address, int bitNumber )
+{
+   __asm__ volatile (
+       "1:                         \n\t"
+       "   ldrex   r2, [%0]        \n\t"
+       "   bic     r2, %1          \n\t"
+       "   strex   r3, r2, [%0]    \n\t"
+       "   cmp     r3,#0           \n\t"
+       "   bne     1b              \n\t"
+       "   bx      lr              \n\t"
+       : //Output Argument
+       :"r"(address),"r"(bitNumber)        //Input Arguments
+       :"cc", "r2", "r3");
+}
+#else
+static void atomicClearFlag( uint32_t* address, int bitNumber )
+{
+    *address &= ~(bitNumber);
+}
+#endif
+
+#ifdef PORTABLE_ARCH_ARM_CM3
+__attribute__((naked)) static void  atomicSetFlag( uint32_t* address, int bitNumber )
+{
+   __asm__ volatile (
+       "1:                         \n\t"
+       "   ldrex   r2, [%0]        \n\t"
+       "   orr     r2, %1          \n\t"
+       "   strex   r3, r2, [%0]    \n\t"
+       "   cmp     r3,#0           \n\t"
+       "   bne     1b              \n\t"
+       "   bx      lr              \n\t"
+       :
+       :"r"(address),"r"(bitNumber)
+       :"cc", "r2", "r3");
+}
+#else
+static void  atomicSetFlag( uint32_t* address, int bitNumber )
+{
+    *address |= (bitNumber);
+}
+#endif
+
+#define NUM_ITEMS_TO_NUM_FLAGS(items) (((items)+31)/32)
+
+void poolInit( static_pool_t* inPool, int inItemSize, int inNumItems, void* inBackingStore, void* inFlags)
+{
+    priv_static_pool_t* aPool = (priv_static_pool_t*) inPool;
+    int i;
+    aPool->item_size = inItemSize;
+    aPool->num_items = inNumItems;
+    aPool->backing_store = inBackingStore;
+    aPool->flags = inFlags;
+    for(i = 0; i < NUM_ITEMS_TO_NUM_FLAGS(inNumItems); i++)
+    {
+        aPool->flags[i] = ~((uint32_t)0x0ul);
+    }
+    if (inNumItems % 32)
+    {
+        //mark all flags as already taken that don't represent an item.
+        aPool->flags[i-1] = aPool->flags[i-1] << (32 - (inNumItems % 32));
+    }
+}
+
+void *poolAllocateBuffer( static_pool_t* inPool )
+{
+    vTaskSuspendAll();
+
+    priv_static_pool_t* aPool = (priv_static_pool_t*) inPool;
+    void *retval = NULL;
+    int flagIndex;
+    for(flagIndex = 0; flagIndex < NUM_ITEMS_TO_NUM_FLAGS(aPool->num_items); flagIndex++)
+    {
+        int8_t leadingZeros = __CLZ(aPool->flags[flagIndex]);
+        if(leadingZeros != 32)
+        {
+            int8_t bitIndex = 31-leadingZeros;
+            int8_t itemIndex = 32*flagIndex+(31-bitIndex);
+            atomicClearFlag(&aPool->flags[flagIndex], 1 << bitIndex);
+            retval = &aPool->backing_store[aPool->item_size*itemIndex];
+            break;
+        }
+    }
+
+    xTaskResumeAll();
+
+    return retval;
+}
+
+void poolFreeBuffer( static_pool_t* inPool, void* inPointer)
+{
+    vTaskSuspendAll();
+
+    priv_static_pool_t* aPool = (priv_static_pool_t*) inPool;
+
+    int itemIndex = ((intptr_t)inPointer - (intptr_t)inPool->backing_store)/inPool->item_size;
+    int flagIndex = itemIndex / 32;
+    int bitIndex = 31-(itemIndex % 32);
+    if(flagIndex >= NUM_ITEMS_TO_NUM_FLAGS(aPool->num_items))
+    {
+        printf("ERROR freeing pool %p, Pointer %p doesnt belong here\n", inPool, inPointer);
+        while(1)
+            ;
+    }
+
+    atomicSetFlag(&aPool->flags[flagIndex], 1 << bitIndex);
+
+    xTaskResumeAll();
+}
diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/port.c b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/port.c
new file mode 100644
index 0000000..106112e
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/port.c
@@ -0,0 +1,276 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Tern EE 186

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include <embedded.h>

+#include <ae.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/* The timer increments every four clocks, hence the divide by 4. */

+#define portTIMER_COMPARE ( unsigned short ) ( ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) / ( unsigned long ) 4 )

+

+/* From the RDC data sheet. */

+#define portENABLE_TIMER_AND_INTERRUPT ( unsigned short ) 0xe001

+

+/* Interrupt control. */

+#define portEIO_REGISTER 0xff22

+#define portCLEAR_INTERRUPT 0x0008

+

+/* Setup the hardware to generate the required tick frequency. */

+static void prvSetupTimerInterrupt( void );

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/* The timer initialisation functions leave interrupts enabled,

+which is not what we want.  This ISR is installed temporarily in case

+the timer fires before we get a change to disable interrupts again. */

+static void __interrupt __far prvDummyISR( void );

+

+/*-----------------------------------------------------------*/

+/* See header file for description. */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE DS_Reg = 0;

+

+	/* Place a few bytes of known values on the bottom of the stack.

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x1111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x2222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x3333;

+	pxTopOfStack--;

+

+	/* We are going to start the scheduler using a return from interrupt

+	instruction to load the program counter, so first there would be the

+	function call with parameters preamble. */

+	

+	*pxTopOfStack = FP_SEG( pvParameters );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pvParameters );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* Next the status register and interrupt return address. */

+	*pxTopOfStack = portINITIAL_SW;

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* The remaining registers would be pushed on the stack by our context

+	switch function.  These are loaded with values simply to make debugging

+	easier. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xAAAA;	/* AX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xCCCC;	/* CX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xEEEE;	/* ES */

+	pxTopOfStack--;

+

+	/* We need the true data segment. */

+	__asm{	MOV DS_Reg, DS };

+

+	*pxTopOfStack = DS_Reg;						/* DS */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0123;	/* SI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BP */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* This is called with interrupts already disabled. */

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	/* Setup the tick interrupt. */

+	prvSetupTimerInterrupt();

+

+	/* Kick off the scheduler by setting up the context of the first task. */

+	portFIRST_CONTEXT();

+

+	/* Should not get here! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvDummyISR( void )

+{

+	/* The timer initialisation functions leave interrupts enabled,

+	which is not what we want.  This ISR is installed temporarily in case

+	the timer fires before we get a change to disable interrupts again. */

+	outport( portEIO_REGISTER, portCLEAR_INTERRUPT );

+}

+/*-----------------------------------------------------------*/

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portSWITCH_CONTEXT();

+

+		/* Reset interrupt. */

+		outport( portEIO_REGISTER, portCLEAR_INTERRUPT );

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		/* Reset interrupt. */

+		outport( portEIO_REGISTER, portCLEAR_INTERRUPT );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portSWITCH_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned short usTimerACompare = portTIMER_COMPARE, usTimerAMode = portENABLE_TIMER_AND_INTERRUPT;

+const unsigned short usT2_IRQ = 0x13;

+

+	/* Configure the timer, the dummy handler is used here as the init

+	function leaves interrupts enabled. */

+	t2_init( usTimerAMode, usTimerACompare, prvDummyISR );

+

+	/* Disable interrupts again before installing the real handlers. */

+	portDISABLE_INTERRUPTS();

+

+	#if( configUSE_PREEMPTION == 1 )

+		/* Tick service routine used by the scheduler when preemptive scheduling is

+		being used. */

+		setvect( usT2_IRQ, prvPreemptiveTick );

+	#else

+		/* Tick service routine used by the scheduler when cooperative scheduling is

+		being used. */

+		setvect( usT2_IRQ, prvNonPreemptiveTick );

+	#endif

+}

+

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portasm.h b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portasm.h
new file mode 100644
index 0000000..5f9a79d
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portasm.h
@@ -0,0 +1,115 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/*

+ * Saves the stack pointer for one task into its TCB, calls

+ * vTaskSwitchContext() to update the TCB being used, then restores the stack

+ * from the new TCB read to run the task.

+ */

+void portSWITCH_CONTEXT( void );

+

+/*

+ * Load the stack pointer from the TCB of the task which is going to be first

+ * to execute.  Then force an IRET so the registers and IP are popped off the

+ * stack.

+ */

+void portFIRST_CONTEXT( void );

+

+#define portSWITCH_CONTEXT()										 \

+						asm { mov	ax, seg pxCurrentTCB		} \

+							asm { mov	ds, ax						}  \

+							asm { les	bx, pxCurrentTCB			}	/* Save the stack pointer into the TCB. */    \

+							asm { mov	es:0x2[ bx ], ss			}   \

+							asm { mov	es:[ bx ], sp				}   \

+							asm { call  far ptr vTaskSwitchContext	}	/* Perform the switch. */   \

+							asm { mov	ax, seg pxCurrentTCB		}	/* Restore the stack pointer from the TCB. */  \

+							asm { mov	ds, ax						}   \

+							asm { les	bx, dword ptr pxCurrentTCB	}   \

+							asm { mov	ss, es:[ bx + 2 ]			}      \

+							asm { mov	sp, es:[ bx ]				}

+

+#define portFIRST_CONTEXT()												\

+							asm { mov	ax, seg pxCurrentTCB		}	\

+							asm { mov	ds, ax						}	\

+							asm { les	bx, dword ptr pxCurrentTCB	}	\

+							asm { mov	ss, es:[ bx + 2 ]			}	\

+							asm { mov	sp, es:[ bx ]				}	\

+							asm { pop	bp							}	\

+							asm { pop	di							}	\

+							asm { pop	si							}	\

+							asm { pop	ds							}	\

+							asm { pop	es							}	\

+							asm { pop	dx							}	\

+							asm { pop	cx							}	\

+							asm { pop	bx							}	\

+							asm { pop	ax							}	\

+							asm { iret								}

+

+

diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portmacro.h b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portmacro.h
new file mode 100644
index 0000000..f4b7aee
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/large_untested/portmacro.h
@@ -0,0 +1,140 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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		long

+#define portLONG		long

+#define portSHORT		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENTER_CRITICAL()			__asm{ pushf }  \

+										__asm{ cli 	 }	\

+

+#define portEXIT_CRITICAL()				__asm{ popf }

+

+#define portDISABLE_INTERRUPTS()		__asm{ cli }

+

+#define portENABLE_INTERRUPTS()			__asm{ sti }

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portNOP()						__asm{ nop }

+#define portSTACK_GROWTH				( -1 )

+#define portSWITCH_INT_NUMBER 			0x80

+#define portYIELD()						__asm{ int portSWITCH_INT_NUMBER } 

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT				2

+#define portINITIAL_SW					( ( portSTACK_TYPE ) 0x0202 )	/* Start the tasks with interrupts enabled. */

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )				inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )	outp( xAddr, ucValue )

+#define portINPUT_WORD( xAddr )				inpw( xAddr )

+#define portOUTPUT_WORD( xAddr, usValue )	outpw( xAddr, usValue )

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+#define portTASK_FUNCTION( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/port.c b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/port.c
new file mode 100644
index 0000000..88f79a2
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/port.c
@@ -0,0 +1,256 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Tern EE 186

+ * port.

+ *----------------------------------------------------------*/

+

+/* Library includes. */

+#include <embedded.h>

+#include <ae.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/* The timer increments every four clocks, hence the divide by 4. */

+#define portPRESCALE_VALUE ( 16 )

+#define portTIMER_COMPARE ( configCPU_CLOCK_HZ  / ( configTICK_RATE_HZ * 4UL ) )

+

+/* From the RDC data sheet. */

+#define portENABLE_TIMER_AND_INTERRUPT 	( unsigned short ) 0xe00b

+#define portENABLE_TIMER				( unsigned short ) 0xC001

+

+/* Interrupt control. */

+#define portEIO_REGISTER 0xff22

+#define portCLEAR_INTERRUPT 0x0008

+

+/* Setup the hardware to generate the required tick frequency. */

+static void prvSetupTimerInterrupt( void );

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/*-----------------------------------------------------------*/

+/* See header file for description. */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE DS_Reg = 0;

+

+	/* We need the true data segment. */

+	__asm{	MOV DS_Reg, DS };

+

+	/* Place a few bytes of known values on the bottom of the stack.

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x1111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x2222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x3333;

+	pxTopOfStack--;

+

+	/* We are going to start the scheduler using a return from interrupt

+	instruction to load the program counter, so first there would be the

+	function call with parameters preamble. */

+	

+	*pxTopOfStack = FP_OFF( pvParameters );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* Next the status register and interrupt return address. */

+	*pxTopOfStack = portINITIAL_SW;

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* The remaining registers would be pushed on the stack by our context

+	switch function.  These are loaded with values simply to make debugging

+	easier. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xAAAA;	/* AX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xCCCC;	/* CX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xEEEE;	/* ES */

+	pxTopOfStack--;

+

+	*pxTopOfStack = DS_Reg;						/* DS */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0123;	/* SI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BP */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* This is called with interrupts already disabled. */

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	/* Setup the tick interrupt. */

+	prvSetupTimerInterrupt();

+

+	/* Kick off the scheduler by setting up the context of the first task. */

+	portFIRST_CONTEXT();

+

+	/* Should not get here! */

+	return pdFALSE;

+}

+/*-----------------------------------------------------------*/

+

+/* The ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if( configUSE_PREEMPTION == 1 )

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portEND_SWITCHING_ISR();

+

+		/* Reset interrupt. */

+		outport( portEIO_REGISTER, portCLEAR_INTERRUPT );

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		/* Reset interrupt. */

+		outport( portEIO_REGISTER, portCLEAR_INTERRUPT );

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portEND_SWITCHING_ISR();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+const unsigned long ulCompareValue = portTIMER_COMPARE;

+unsigned short usTimerCompare;

+

+	usTimerCompare = ( unsigned short ) ( ulCompareValue >> 4 );

+    t2_init( portENABLE_TIMER, portPRESCALE_VALUE, NULL );

+

+	#if( configUSE_PREEMPTION == 1 )

+		/* Tick service routine used by the scheduler when preemptive scheduling is

+		being used. */

+		t1_init( portENABLE_TIMER_AND_INTERRUPT, usTimerCompare, usTimerCompare, prvPreemptiveTick );

+	#else

+		/* Tick service routine used by the scheduler when cooperative scheduling is

+		being used. */

+		t1_init( portENABLE_TIMER_AND_INTERRUPT, usTimerCompare, usTimerCompare, prvNonPreemptiveTick );

+	#endif

+}

+

+

+

+

+

+

+

diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portasm.h b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portasm.h
new file mode 100644
index 0000000..cec0ab1
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portasm.h
@@ -0,0 +1,111 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORT_ASM_H

+#define PORT_ASM_H

+

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/*

+ * Saves the stack pointer for one task into its TCB, calls

+ * vTaskSwitchContext() to update the TCB being used, then restores the stack

+ * from the new TCB read to run the task.

+ */

+void portEND_SWITCHING_ISR( void );

+

+/*

+ * Load the stack pointer from the TCB of the task which is going to be first

+ * to execute.  Then force an IRET so the registers and IP are popped off the

+ * stack.

+ */

+void portFIRST_CONTEXT( void );

+

+#define portEND_SWITCHING_ISR()											\

+							asm { mov	bx, [pxCurrentTCB]			}   \

+                            asm { mov	word ptr [bx], sp			}	\

+							asm { call  far ptr vTaskSwitchContext	}	\

+							asm { mov	bx, [pxCurrentTCB]			}	\

+							asm { mov	sp, [bx]					}

+

+#define portFIRST_CONTEXT()											\

+							asm { mov	bx, [pxCurrentTCB]			}	\

+							asm { mov	sp, [bx]					}	\

+							asm { pop	bp							}	\

+							asm { pop	di							}	\

+							asm { pop	si							}	\

+   							asm { pop	ds							}	\

+   							asm { pop	es							}	\

+							asm { pop	dx							}	\

+							asm { pop	cx							}	\

+							asm { pop	bx							}	\

+							asm { pop	ax							}	\

+							asm { iret								}

+

+

+#endif

+

diff --git a/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portmacro.h b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portmacro.h
new file mode 100644
index 0000000..963e618
--- /dev/null
+++ b/FreeRTOS/Source/portable/Paradigm/Tern_EE/small/portmacro.h
@@ -0,0 +1,141 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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		long

+#define portLONG		long

+#define portSHORT		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+typedef void ( __interrupt __far *pxISR )();

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section handling. */

+#define portENTER_CRITICAL()			__asm{ pushf }  \

+										__asm{ cli 	 }	\

+

+#define portEXIT_CRITICAL()				__asm{ popf }

+

+#define portDISABLE_INTERRUPTS()		__asm{ cli }

+

+#define portENABLE_INTERRUPTS()			__asm{ sti }

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portNOP()						__asm{ nop }

+#define portSTACK_GROWTH				( -1 )

+#define portSWITCH_INT_NUMBER 			0x80

+#define portYIELD()						__asm{ int portSWITCH_INT_NUMBER } 

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT				2

+#define portINITIAL_SW					( ( portSTACK_TYPE ) 0x0202 )	/* Start the tasks with interrupts enabled. */

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )				inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )	outp( xAddr, ucValue )

+#define portINPUT_WORD( xAddr )				inpw( xAddr )

+#define portOUTPUT_WORD( xAddr, usValue )	outpw( xAddr, usValue )

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+#define portTASK_FUNCTION( vTaskFunction, vParameters ) void vTaskFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/port.c b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/port.c
new file mode 100644
index 0000000..b2716b0
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/port.c
@@ -0,0 +1,330 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+/* Standard includes. */

+#include <stdlib.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup the initial task context. */

+#define portINITIAL_SPSR				( ( portSTACK_TYPE ) 0x1f ) /* System mode, ARM mode, interrupts enabled. */

+#define portTHUMB_MODE_BIT				( ( portSTACK_TYPE ) 0x20 )

+#define portINSTRUCTION_SIZE			( ( portSTACK_TYPE ) 4 )

+#define portNO_CRITICAL_SECTION_NESTING	( ( portSTACK_TYPE ) 0 )

+

+/* Constants required to setup the tick ISR. */

+#define portENABLE_TIMER			( ( unsigned portCHAR ) 0x01 )

+#define portPRESCALE_VALUE			0x00

+#define portINTERRUPT_ON_MATCH		( ( unsigned portLONG ) 0x01 )

+#define portRESET_COUNT_ON_MATCH	( ( unsigned portLONG ) 0x02 )

+

+/* Constants required to setup the VIC for the tick ISR. */

+#define portTIMER_VIC_CHANNEL		( ( unsigned portLONG ) 0x0004 )

+#define portTIMER_VIC_CHANNEL_BIT	( ( unsigned portLONG ) 0x0010 )

+#define portTIMER_VIC_ENABLE		( ( unsigned portLONG ) 0x0020 )

+

+/* Constants required to handle interrupts. */

+#define portTIMER_MATCH_ISR_BIT		( ( unsigned portCHAR ) 0x01 )

+#define portCLEAR_VIC_INTERRUPT		( ( unsigned portLONG ) 0 )

+

+/*-----------------------------------------------------------*/

+

+/* The code generated by the Keil compiler does not maintain separate

+stack and frame pointers. The portENTER_CRITICAL macro cannot therefore

+use the stack as per other ports.  Instead a variable is used to keep

+track of the critical section nesting.  This variable has to be stored

+as part of the task context and must be initialised to a non zero value. */

+

+#define portNO_CRITICAL_NESTING		( ( unsigned portLONG ) 0 )

+volatile unsigned portLONG ulCriticalNesting = 9999UL;

+

+/*-----------------------------------------------------------*/

+

+/* Setup the timer to generate the tick interrupts. */

+static void prvSetupTimerInterrupt( void );

+

+/* 

+ * The scheduler can only be started from ARM mode, so 

+ * vPortStartFirstSTask() is defined in portISR.c. 

+ */

+extern __asm void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE *pxOriginalTOS;

+

+	/* Setup the initial stack of the task.  The stack is set exactly as 

+	expected by the portRESTORE_CONTEXT() macro.

+

+	Remember where the top of the (simulated) stack is before we place 

+	anything on it. */

+	pxOriginalTOS = pxTopOfStack;

+	

+	/* To ensure asserts in tasks.c don't fail, although in this case the assert

+	is not really required. */

+	pxTopOfStack--;

+

+	/* First on the stack is the return address - which in this case is the

+	start of the task.  The offset is added to make the return address appear

+	as it would within an IRQ ISR. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode + portINSTRUCTION_SIZE;		

+	pxTopOfStack--;

+

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaaaaaa;	/* R14 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pxOriginalTOS; /* Stack used when task starts goes in R13. */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x12121212;	/* R12 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11111111;	/* R11 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x10101010;	/* R10 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x09090909;	/* R9 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x08080808;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x07070707;	/* R7 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x06060606;	/* R6 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x05050505;	/* R5 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x04040404;	/* R4 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x03030303;	/* R3 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x02020202;	/* R2 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x01010101;	/* R1 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R0 */

+	pxTopOfStack--;

+

+	/* The last thing onto the stack is the status register, which is set for

+	system mode, with interrupts enabled. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portINITIAL_SPSR;

+

+	if( ( ( unsigned long ) pxCode & 0x01UL ) != 0x00UL )

+	{

+		/* We want the task to start in thumb mode. */

+		*pxTopOfStack |= portTHUMB_MODE_BIT;

+	}

+

+	pxTopOfStack--;

+

+	/* The code generated by the Keil compiler does not maintain separate

+	stack and frame pointers. The portENTER_CRITICAL macro cannot therefore

+	use the stack as per other ports.  Instead a variable is used to keep

+	track of the critical section nesting.  This variable has to be stored

+	as part of the task context and is initially set to zero. */

+	*pxTopOfStack = portNO_CRITICAL_SECTION_NESTING;

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Start the timer that generates the tick ISR. */

+	prvSetupTimerInterrupt();

+

+	/* Start the first task.  This is done from portISR.c as ARM mode must be

+	used. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the ARM port will require this function as there

+	is nothing to return to.  If this is required - stop the tick ISR then

+	return back to main. */

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 0

+

+	/* 

+	 * The cooperative scheduler requires a normal IRQ service routine to 

+	 * simply increment the system tick. 

+	 */

+	void vNonPreemptiveTick( void ) __irq;

+	void vNonPreemptiveTick( void ) __irq

+	{

+		/* Increment the tick count - this may make a delaying task ready

+		to run - but a context switch is not performed. */		

+		vTaskIncrementTick();

+

+		T0IR = portTIMER_MATCH_ISR_BIT;				/* Clear the timer event */

+		VICVectAddr = portCLEAR_VIC_INTERRUPT;		/* Acknowledge the Interrupt */

+	}

+

+ #else

+

+	/*

+	 **************************************************************************

+	 * The preemptive scheduler ISR is written in assembler and can be found   

+	 * in the portASM.s file. This will only get used if portUSE_PREEMPTION

+	 * is set to 1 in portmacro.h

+	 ************************************************************************** 

+	 */

+

+	  void vPreemptiveTick( void );

+

+#endif

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+unsigned portLONG ulCompareMatch;

+

+	/* A 1ms tick does not require the use of the timer prescale.  This is

+	defaulted to zero but can be used if necessary. */

+	T0PR = portPRESCALE_VALUE;

+

+	/* Calculate the match value required for our wanted tick rate. */

+	ulCompareMatch = configCPU_CLOCK_HZ / configTICK_RATE_HZ;

+

+	/* Protect against divide by zero.  Using an if() statement still results

+	in a warning - hence the #if. */

+	#if portPRESCALE_VALUE != 0

+	{

+		ulCompareMatch /= ( portPRESCALE_VALUE + 1 );

+	}

+	#endif

+

+	T0MR0 = ulCompareMatch;

+

+	/* Generate tick with timer 0 compare match. */

+	T0MCR = portRESET_COUNT_ON_MATCH | portINTERRUPT_ON_MATCH;

+

+	/* Setup the VIC for the timer. */

+	VICIntSelect &= ~( portTIMER_VIC_CHANNEL_BIT );

+	VICIntEnable |= portTIMER_VIC_CHANNEL_BIT;

+	

+	/* The ISR installed depends on whether the preemptive or cooperative

+	scheduler is being used. */

+	#if configUSE_PREEMPTION == 1

+	{	

+		VICVectAddr0 = ( unsigned portLONG ) vPreemptiveTick;

+	}

+	#else

+	{

+		VICVectAddr0 = ( unsigned portLONG ) vNonPreemptiveTick;

+	}

+	#endif

+

+	VICVectCntl0 = portTIMER_VIC_CHANNEL | portTIMER_VIC_ENABLE;

+

+	/* Start the timer - interrupts are disabled when this function is called

+	so it is okay to do this here. */

+	T0TCR = portENABLE_TIMER;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	/* Disable interrupts as per portDISABLE_INTERRUPTS(); 							*/

+	__disable_irq();

+

+	/* Now interrupts are disabled ulCriticalNesting can be accessed 

+	directly.  Increment ulCriticalNesting to keep a count of how many times

+	portENTER_CRITICAL() has been called. */

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	if( ulCriticalNesting > portNO_CRITICAL_NESTING )

+	{

+		/* Decrement the nesting count as we are leaving a critical section. */

+		ulCriticalNesting--;

+

+		/* If the nesting level has reached zero then interrupts should be

+		re-enabled. */

+		if( ulCriticalNesting == portNO_CRITICAL_NESTING )

+		{

+			/* Enable interrupts as per portEXIT_CRITICAL(). */

+			__enable_irq();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portASM.s b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portASM.s
new file mode 100644
index 0000000..2f0376c
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portASM.s
@@ -0,0 +1,148 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	INCLUDE portmacro.inc

+

+	IMPORT	vTaskSwitchContext

+	IMPORT	vTaskIncrementTick

+

+	EXPORT	vPortYieldProcessor

+	EXPORT	vPortStartFirstTask

+	EXPORT	vPreemptiveTick

+	EXPORT	vPortYield

+

+

+VICVECTADDR	EQU	0xFFFFF030

+T0IR		EQU	0xE0004000

+T0MATCHBIT	EQU	0x00000001

+

+	ARM

+	AREA	PORT_ASM, CODE, READONLY

+

+

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Starting the first task is done by just restoring the context 

+; setup by pxPortInitialiseStack

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+vPortStartFirstTask

+

+	PRESERVE8

+

+	portRESTORE_CONTEXT

+

+vPortYield

+

+	PRESERVE8

+

+	SVC 0

+	bx lr

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Interrupt service routine for the SWI interrupt.  The vector table is

+; configured in the startup.s file.

+;

+; vPortYieldProcessor() is used to manually force a context switch.  The

+; SWI interrupt is generated by a call to taskYIELD() or portYIELD().

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+

+vPortYieldProcessor

+

+	PRESERVE8

+

+	; Within an IRQ ISR the link register has an offset from the true return 

+	; address, but an SWI ISR does not.  Add the offset manually so the same 

+	; ISR return code can be used in both cases.

+	ADD	LR, LR, #4

+

+	; Perform the context switch.

+	portSAVE_CONTEXT					; Save current task context				

+	LDR R0, =vTaskSwitchContext			; Get the address of the context switch function

+	MOV LR, PC							; Store the return address

+	BX	R0								; Call the contedxt switch function

+	portRESTORE_CONTEXT					; restore the context of the selected task	

+

+

+

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

+; Interrupt service routine for preemptive scheduler tick timer

+; Only used if portUSE_PREEMPTION is set to 1 in portmacro.h

+;

+; Uses timer 0 of LPC21XX Family

+;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;	

+

+vPreemptiveTick

+

+	PRESERVE8

+

+	portSAVE_CONTEXT					; Save the context of the current task.	

+

+	LDR R0, =vTaskIncrementTick			; Increment the tick count.  

+	MOV LR, PC							; This may make a delayed task ready

+	BX R0								; to run.

+	

+	LDR R0, =vTaskSwitchContext			; Find the highest priority task that 

+	MOV LR, PC							; is ready to run.

+	BX R0

+	

+	MOV R0, #T0MATCHBIT					; Clear the timer event

+	LDR R1, =T0IR

+	STR R0, [R1] 

+

+	LDR	R0, =VICVECTADDR				; Acknowledge the interrupt	

+	STR	R0,[R0]

+

+	portRESTORE_CONTEXT					; Restore the context of the highest 

+										; priority task that is ready to run.

+	END

+

diff --git a/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.h b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.h
new file mode 100644
index 0000000..ff099de
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.h
@@ -0,0 +1,180 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	portLONG

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+

+/*-----------------------------------------------------------

+ * ISR entry and exit macros.  These are only required if a task switch

+ * is required from an ISR.

+ *----------------------------------------------------------*/

+

+/* If a switch is required then we just need to call */	

+/* vTaskSwitchContext() as the context has already been */

+/* saved. */

+

+#define portEXIT_SWITCHING_ISR(SwitchRequired)				 \

+{															 \

+extern void vTaskSwitchContext(void);						 \

+															 \

+		if(SwitchRequired)									 \

+		{													 \

+			vTaskSwitchContext();							 \

+		}													 \

+}															 \

+

+extern void vPortYield( void );

+#define portYIELD() vPortYield()

+

+

+/* Critical section management. */

+

+/*

+ ****************************************************************** 

+ * We don't need to worry about whether we're in ARM or

+ * THUMB mode with the Keil Real View compiler when enabling 

+ * or disabling interrupts as the compiler's intrinsic functions 

+ * take care of that for us.

+ *******************************************************************

+ */

+#define portDISABLE_INTERRUPTS()	__disable_irq()					

+#define portENABLE_INTERRUPTS()		__enable_irq()

+

+

+/*-----------------------------------------------------------

+ * Critical section control

+ *

+ * The code generated by the Keil compiler does not maintain separate

+ * stack and frame pointers. The portENTER_CRITICAL macro cannot therefore

+ * use the stack as per other ports.  Instead a variable is used to keep

+ * track of the critical section nesting.  This necessitates the use of a 

+ * function in place of the macro.

+ *----------------------------------------------------------*/

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portENTER_CRITICAL()		vPortEnterCritical();

+#define portEXIT_CRITICAL()			vPortExitCritical();

+/*-----------------------------------------------------------*/	

+

+/* Compiler specifics. */

+#define inline

+#define register

+#define portNOP()	__asm{ NOP }

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters )	void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters )	void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.inc b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.inc
new file mode 100644
index 0000000..2f9e681
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.inc
@@ -0,0 +1,117 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	IMPORT  ulCriticalNesting		;

+	IMPORT	pxCurrentTCB			;

+

+

+	MACRO

+	portRESTORE_CONTEXT

+

+

+	LDR		R0, =pxCurrentTCB		; Set the LR to the task stack.  The location was...

+	LDR		R0, [R0]				; ... stored in pxCurrentTCB

+	LDR		LR, [R0]

+

+	LDR		R0, =ulCriticalNesting	; The critical nesting depth is the first item on... 

+	LDMFD	LR!, {R1}				; ...the stack.  Load it into the ulCriticalNesting var.

+	STR		R1, [R0]				;

+

+	LDMFD	LR!, {R0}				; Get the SPSR from the stack.

+	MSR		SPSR_cxsf, R0			;

+

+	LDMFD	LR, {R0-R14}^			; Restore all system mode registers for the task.

+	NOP								;

+

+	LDR		LR, [LR, #+60]			; Restore the return address

+

+									; And return - correcting the offset in the LR to obtain ...

+	SUBS	PC, LR, #4				; ...the correct address.

+

+	MEND

+

+; /**********************************************************************/

+

+	MACRO

+	portSAVE_CONTEXT

+

+

+	STMDB 	SP!, {R0}				; Store R0 first as we need to use it.

+

+	STMDB	SP,{SP}^				; Set R0 to point to the task stack pointer.

+	NOP								;

+	SUB		SP, SP, #4				;

+	LDMIA	SP!,{R0}				;

+

+	STMDB	R0!, {LR}				; Push the return address onto the stack.

+	MOV		LR, R0					; Now we have saved LR we can use it instead of R0.

+	LDMIA	SP!, {R0}				; Pop R0 so we can save it onto the system mode stack.

+

+	STMDB	LR,{R0-LR}^				; Push all the system mode registers onto the task stack.

+	NOP								;

+	SUB		LR, LR, #60				;

+

+	MRS		R0, SPSR				; Push the SPSR onto the task stack.

+	STMDB	LR!, {R0}				;

+

+	LDR		R0, =ulCriticalNesting	;

+	LDR		R0, [R0]				;

+	STMDB	LR!, {R0}				;

+

+	LDR		R0, =pxCurrentTCB		; Store the new top of stack for the task.

+	LDR		R1, [R0]				; 		 

+	STR		LR, [R1]				;

+	

+	MEND

+	

+	END

diff --git a/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c b/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c
new file mode 100644
index 0000000..d109cec
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c
@@ -0,0 +1,313 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM3 port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#ifndef configKERNEL_INTERRUPT_PRIORITY

+	#define configKERNEL_INTERRUPT_PRIORITY 255

+#endif

+

+#if configMAX_SYSCALL_INTERRUPT_PRIORITY == 0

+	#error configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/* 

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void );

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void );

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+void vPortStartFirstTask( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+__asm void vPortSVCHandler( void )

+{

+	PRESERVE8

+

+	ldr	r3, =pxCurrentTCB		/* Restore the context. */

+	ldr r1, [r3]				/* Use pxCurrentTCBConst to get the pxCurrentTCB address. */

+	ldr r0, [r1]				/* The first item in pxCurrentTCB is the task top of stack. */

+	ldmia r0!, {r4-r11}		/* Pop the registers that are not automatically saved on exception entry and the critical nesting count. */

+	msr psp, r0					/* Restore the task stack pointer. */

+	mov r0, #0

+	msr	basepri, r0

+	orr r14, #0xd				

+	bx r14						

+}

+/*-----------------------------------------------------------*/

+

+__asm void vPortStartFirstTask( void )

+{

+	PRESERVE8

+

+	/* Use the NVIC offset register to locate the stack. */

+	ldr r0, =0xE000ED08

+	ldr r0, [r0]

+	ldr r0, [r0]

+	/* Set the msp back to the start of the stack. */

+	msr msp, r0

+	/* Globally enable interrupts. */

+	cpsie i

+	/* Call SVC to start the first task. */

+	svc 0

+	nop

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV, CallSV and SysTick the same priroity as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM3 port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+__asm void xPortPendSVHandler( void )

+{

+	extern uxCriticalNesting;

+	extern pxCurrentTCB;

+	extern vTaskSwitchContext;

+

+	PRESERVE8

+

+	mrs r0, psp						 

+

+	ldr	r3, =pxCurrentTCB		 	 /* Get the location of the current TCB. */

+	ldr	r2, [r3]						

+

+	stmdb r0!, {r4-r11}				 /* Save the remaining registers. */

+	str r0, [r2]					 /* Save the new top of stack into the first member of the TCB. */

+

+	stmdb sp!, {r3, r14}		

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0		 

+	bl vTaskSwitchContext

+	mov r0, #0

+	msr basepri, r0

+	ldmia sp!, {r3, r14}			

+

+	ldr r1, [r3]					 

+	ldr r0, [r1]					 /* The first item in pxCurrentTCB is the task top of stack. */

+	ldmia r0!, {r4-r11}			 /* Pop the registers and the critical nesting count. */

+	msr psp, r0						 

+	bx r14

+	nop

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;	

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

+__asm void vPortSetInterruptMask( void )

+{

+	PRESERVE8

+

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0

+	bx r14

+}

+

+/*-----------------------------------------------------------*/

+

+__asm void vPortClearInterruptMask( void )

+{

+	PRESERVE8

+

+	/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+	http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+	mov r0, #0

+	msr basepri, r0

+	bx r14

+}

diff --git a/FreeRTOS/Source/portable/RVDS/ARM_CM3/portmacro.h b/FreeRTOS/Source/portable/RVDS/ARM_CM3/portmacro.h
new file mode 100644
index 0000000..0b60eb2
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM_CM3/portmacro.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYield( void );

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+extern void vPortSetInterruptMask( void );

+extern void vPortClearInterruptMask( void );

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()				vPortSetInterruptMask()

+#define portENABLE_INTERRUPTS()					vPortClearInterruptMask()

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;vPortSetInterruptMask()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	vPortClearInterruptMask();(void)x

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/RVDS/ARM_CM4F/port.c b/FreeRTOS/Source/portable/RVDS/ARM_CM4F/port.c
new file mode 100644
index 0000000..a8fdad6
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM_CM4F/port.c
@@ -0,0 +1,377 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM4F port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+#ifndef __TARGET_FPU_VFP 

+	#error This port can only be used when the project options are configured to enable hardware floating point support.

+#endif

+

+#if configMAX_SYSCALL_INTERRUPT_PRIORITY == 0

+	#error configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.  See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html

+#endif

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long *) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long *) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long *) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long *) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to manipulate the VFP. */

+#define portFPCCR					( ( volatile unsigned long * ) 0xe000ef34 ) /* Floating point context control register. */

+#define portASPEN_AND_LSPEN_BITS	( 0x3UL << 30UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+#define portINITIAL_EXEC_RETURN		( 0xfffffffd )

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned portBASE_TYPE uxCriticalNesting = 0xaaaaaaaa;

+

+/* 

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void xPortPendSVHandler( void );

+void xPortSysTickHandler( void );

+void vPortSVCHandler( void );

+

+/*

+ * Start first task is a separate function so it can be tested in isolation.

+ */

+static void prvStartFirstTask( void );

+

+/*

+ * Functions defined in portasm.s to enable the VFP.

+ */

+static void prvEnableVFP( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+	

+	/* Offset added to account for the way the MCU uses the stack on entry/exit

+	of interrupts, and to ensure alignment. */

+	pxTopOfStack--;

+		

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+	

+	/* Save code space by skipping register initialisation. */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+

+	/* A save method is being used that requires each task to maintain its

+	own exec return value. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_EXEC_RETURN;

+

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+	

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+__asm void vPortSVCHandler( void )

+{

+	PRESERVE8

+

+	/* Get the location of the current TCB. */

+	ldr	r3, =pxCurrentTCB

+	ldr r1, [r3]

+	ldr r0, [r1]

+	/* Pop the core registers. */

+	ldmia r0!, {r4-r11, r14}

+	msr psp, r0

+	mov r0, #0

+	msr	basepri, r0	

+	bx r14

+}

+/*-----------------------------------------------------------*/

+

+__asm void prvStartFirstTask( void )

+{

+	PRESERVE8

+

+	/* Use the NVIC offset register to locate the stack. */

+	ldr r0, =0xE000ED08

+	ldr r0, [r0]

+	ldr r0, [r0]

+	/* Set the msp back to the start of the stack. */

+	msr msp, r0

+	/* Globally enable interrupts. */

+	cpsie i

+	/* Call SVC to start the first task. */

+	svc 0

+	nop

+}

+/*-----------------------------------------------------------*/

+

+__asm void prvEnableVFP( void )

+{

+	PRESERVE8

+	

+	/* The FPU enable bits are in the CPACR. */

+	ldr.w r0, =0xE000ED88

+	ldr	r1, [r0]

+	

+	/* Enable CP10 and CP11 coprocessors, then save back. */

+	orr	r1, r1, #( 0xf << 20 )

+	str r1, [r0]

+	bx	r14	

+	nop

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Make PendSV, CallSV and SysTick the same priroity as the kernel. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+	

+	/* Initialise the critical nesting count ready for the first task. */

+	uxCriticalNesting = 0;

+

+	/* Ensure the VFP is enabled - it should be anyway. */

+	prvEnableVFP();

+	

+	/* Lazy save always. */

+	*( portFPCCR ) |= portASPEN_AND_LSPEN_BITS;

+	

+	/* Start the first task. */

+	prvStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM4F port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	uxCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	uxCriticalNesting--;

+	if( uxCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+__asm void xPortPendSVHandler( void )

+{

+	extern uxCriticalNesting;

+	extern pxCurrentTCB;

+	extern vTaskSwitchContext;

+

+	PRESERVE8

+

+	mrs r0, psp						

+	

+	/* Get the location of the current TCB. */

+	ldr	r3, =pxCurrentTCB			

+	ldr	r2, [r3]						

+

+	/* Is the task using the FPU context?  If so, push high vfp registers. */

+	tst r14, #0x10

+	it eq

+	vstmdbeq r0!, {s16-s31}

+

+	/* Save the core registers. */

+	stmdb r0!, {r4-r11, r14}				

+	

+	/* Save the new top of stack into the first member of the TCB. */

+	str r0, [r2]

+	

+	stmdb sp!, {r3, r14}

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0

+	bl vTaskSwitchContext			

+	mov r0, #0

+	msr basepri, r0

+	ldmia sp!, {r3, r14}

+

+	/* The first item in pxCurrentTCB is the task top of stack. */

+	ldr r1, [r3]	

+	ldr r0, [r1]

+	

+	/* Pop the core registers. */

+	ldmia r0!, {r4-r11, r14}

+

+	/* Is the task using the FPU context?  If so, pop the high vfp registers 

+	too. */

+	tst r14, #0x10

+	it eq

+	vldmiaeq r0!, {s16-s31}

+	

+	msr psp, r0						

+	bx r14		

+	nop					

+}

+/*-----------------------------------------------------------*/

+

+void xPortSysTickHandler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;	

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

+__asm void vPortSetInterruptMask( void )

+{

+	PRESERVE8

+

+	mov r0, #configMAX_SYSCALL_INTERRUPT_PRIORITY

+	msr basepri, r0

+	bx r14

+}

+

+/*-----------------------------------------------------------*/

+

+__asm void vPortClearInterruptMask( void )

+{

+	PRESERVE8

+

+	/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+	http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+	mov r0, #0

+	msr basepri, r0

+	bx r14

+}

diff --git a/FreeRTOS/Source/portable/RVDS/ARM_CM4F/portmacro.h b/FreeRTOS/Source/portable/RVDS/ARM_CM4F/portmacro.h
new file mode 100644
index 0000000..e3b86b0
--- /dev/null
+++ b/FreeRTOS/Source/portable/RVDS/ARM_CM4F/portmacro.h
@@ -0,0 +1,153 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYield( void );

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+extern void vPortSetInterruptMask( void );

+extern void vPortClearInterruptMask( void );

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()				vPortSetInterruptMask()

+#define portENABLE_INTERRUPTS()					vPortClearInterruptMask()

+#define portENTER_CRITICAL()					vPortEnterCritical()

+#define portEXIT_CRITICAL()						vPortExitCritical()

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;vPortSetInterruptMask()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	vPortClearInterruptMask();(void)x

+

+/* There are an uneven number of items on the initial stack, so 

+portALIGNMENT_ASSERT_pxCurrentTCB() will trigger false positive asserts. */

+#define portALIGNMENT_ASSERT_pxCurrentTCB ( void )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX200/port.c b/FreeRTOS/Source/portable/Renesas/RX200/port.c
new file mode 100644
index 0000000..8494130
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX200/port.c
@@ -0,0 +1,361 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the SH2A port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "string.h"

+

+/* Hardware specifics. */

+#include "iodefine.h"

+

+/*-----------------------------------------------------------*/

+

+/* Tasks should start with interrupts enabled and in Supervisor mode, therefore 

+PSW is set with U and I set, and PM and IPL clear. */

+#define portINITIAL_PSW     ( ( portSTACK_TYPE ) 0x00030000 )

+

+/*-----------------------------------------------------------*/

+

+/* The following lines are to ensure vSoftwareInterruptEntry can be referenced,

+ and therefore installed in the vector table, when the FreeRTOS code is built

+as a library. */

+extern portBASE_TYPE vSoftwareInterruptEntry;

+const portBASE_TYPE * p_vSoftwareInterruptEntry = &vSoftwareInterruptEntry;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Function to start the first task executing - written in asm code as direct

+ * access to registers is required. 

+ */

+static void prvStartFirstTask( void );

+

+/*

+ * Software interrupt handler.  Performs the actual context switch (saving and

+ * restoring of registers).  Written in asm code as direct register access is

+ * required.

+ */

+static void prvYieldHandler( void );

+

+/*

+ * The entry point for the software interrupt handler.  This is the function

+ * that calls the inline asm function prvYieldHandler().  It is installed in 

+ * the vector table, but the code that installs it is in prvYieldHandler rather

+ * than using a #pragma.

+ */

+void vSoftwareInterruptISR( void );

+

+/*-----------------------------------------------------------*/

+

+/* This is accessed by the inline assembler functions so is file scope for

+convenience. */

+extern void *pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* R0 is not included as it is the stack pointer. */

+	

+	*pxTopOfStack = 0x00;

+	pxTopOfStack--;

+    *pxTopOfStack = 0x00;

+	pxTopOfStack--;

+ 	*pxTopOfStack = portINITIAL_PSW;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	

+	/* When debugging it can be useful if every register is set to a known

+	value.  Otherwise code space can be saved by just setting the registers

+	that need to be set. */

+	#ifdef USE_FULL_REGISTER_INITIALISATION

+	{

+		pxTopOfStack--;

+		*pxTopOfStack = 0xffffffff;	/* r15. */

+		pxTopOfStack--;

+		*pxTopOfStack = 0xeeeeeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xdddddddd;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xcccccccc;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xbbbbbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xaaaaaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x99999999;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x88888888;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x77777777;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x66666666;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x55555555;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x44444444;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x33333333;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x22222222;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		pxTopOfStack -= 15;

+	}

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R1 */

+	pxTopOfStack--;				

+	*pxTopOfStack = 0x12345678; /* Accumulator. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x87654321; /* Accumulator. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vApplicationSetupTimerInterrupt( void );

+

+	/* Use pxCurrentTCB just so it does not get optimised away. */

+	if( pxCurrentTCB != NULL )

+	{

+		/* Call an application function to set up the timer that will generate the

+		tick interrupt.  This way the application can decide which peripheral to 

+		use.  A demo application is provided to show a suitable example. */

+		vApplicationSetupTimerInterrupt();

+

+		/* Enable the software interrupt. */		

+		_IEN( _ICU_SWINT ) = 1;

+		

+		/* Ensure the software interrupt is clear. */

+		_IR( _ICU_SWINT ) = 0;

+		

+		/* Ensure the software interrupt is set to the kernel priority. */

+		_IPR( _ICU_SWINT ) = configKERNEL_INTERRUPT_PRIORITY;

+	

+		/* Start the first task. */

+		prvStartFirstTask();

+	}

+

+	/* Just to make sure the function is not optimised away. */

+	( void ) vSoftwareInterruptISR();

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+#pragma inline_asm prvStartFirstTask

+static void prvStartFirstTask( void )

+{

+	/* When starting the scheduler there is nothing that needs moving to the

+	interrupt stack because the function is not called from an interrupt.

+	Just ensure the current stack is the user stack. */

+	SETPSW	U

+

+	/* Obtain the location of the stack associated with which ever task 

+	pxCurrentTCB is currently pointing to. */

+	MOV.L	#_pxCurrentTCB, R15

+	MOV.L	[R15], R15

+	MOV.L	[R15], R0

+

+	/* Restore the registers from the stack of the task pointed to by 

+	pxCurrentTCB. */

+    POP		R15

+    MVTACLO	R15 		/* Accumulator low 32 bits. */

+    POP		R15

+    MVTACHI	R15 		/* Accumulator high 32 bits. */

+    POPM	R1-R15 		/* R1 to R15 - R0 is not included as it is the SP. */

+    RTE					/* This pops the remaining registers. */

+    NOP

+    NOP

+}

+/*-----------------------------------------------------------*/

+

+#pragma interrupt ( vTickISR( vect = _VECT( configTICK_VECTOR ), enable ) )

+void vTickISR( void )

+{

+	/* Increment the tick, and perform any processing the new tick value

+	necessitates. */

+	set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+	{

+		vTaskIncrementTick();

+	}

+	set_ipl( configKERNEL_INTERRUPT_PRIORITY );

+	

+	/* Only select a new task if the preemptive scheduler is being used. */

+	#if( configUSE_PREEMPTION == 1 )

+		taskYIELD();

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+void vSoftwareInterruptISR( void )

+{

+	prvYieldHandler();

+}

+/*-----------------------------------------------------------*/

+

+#pragma inline_asm prvYieldHandler

+static void prvYieldHandler( void )

+{

+	/* Re-enable interrupts. */

+	SETPSW	I

+

+	/* Move the data that was automatically pushed onto the interrupt stack when

+	the interrupt occurred from the interrupt stack to the user stack.  

+	

+	R15 is saved before it is clobbered. */

+	PUSH.L	R15

+	

+	/* Read the user stack pointer. */

+	MVFC	USP, R15

+	

+	/* Move the address down to the data being moved. */

+	SUB		#12, R15

+	MVTC	R15, USP

+	

+	/* Copy the data across. */

+	MOV.L	[ R0 ], [ R15 ] ; R15

+	MOV.L 	4[ R0 ], 4[ R15 ]  ; PC

+	MOV.L	8[ R0 ], 8[ R15 ]  ; PSW

+

+	/* Move the interrupt stack pointer to its new correct position. */

+	ADD	#12, R0

+	

+	/* All the rest of the registers are saved directly to the user stack. */

+	SETPSW	U

+

+	/* Save the rest of the general registers (R15 has been saved already). */

+	PUSHM	R1-R14

+	

+	/* Save the accumulator. */

+	MVFACHI	R15

+	PUSH.L	R15

+	MVFACMI	R15	; Middle order word.

+	SHLL	#16, R15 ; Shifted left as it is restored to the low order word.

+	PUSH.L	R15

+

+	/* Save the stack pointer to the TCB. */

+	MOV.L	#_pxCurrentTCB, R15

+	MOV.L	[ R15 ], R15

+	MOV.L	R0, [ R15 ]

+			

+	/* Ensure the interrupt mask is set to the syscall priority while the kernel

+	structures are being accessed. */

+	MVTIPL	#configMAX_SYSCALL_INTERRUPT_PRIORITY

+

+	/* Select the next task to run. */

+	BSR.A	_vTaskSwitchContext

+

+	/* Reset the interrupt mask as no more data structure access is required. */

+	MVTIPL	#configKERNEL_INTERRUPT_PRIORITY

+

+	/* Load the stack pointer of the task that is now selected as the Running

+	state task from its TCB. */

+	MOV.L	#_pxCurrentTCB,R15

+	MOV.L	[ R15 ], R15

+	MOV.L	[ R15 ], R0

+

+	/* Restore the context of the new task.  The PSW (Program Status Word) and

+	PC will be popped by the RTE instruction. */

+	POP		R15

+	MVTACLO	R15

+	POP		R15

+	MVTACHI	R15

+	POPM	R1-R15

+	RTE

+	NOP

+	NOP

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+	

+	/* The following line is just to prevent the symbol getting optimised away. */

+	( void ) vTaskSwitchContext();

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX200/port_asm.src b/FreeRTOS/Source/portable/Renesas/RX200/port_asm.src
new file mode 100644
index 0000000..1e506b3
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX200/port_asm.src
@@ -0,0 +1,67 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+		.GLB	_vSoftwareInterruptISR

+                .GLB    _vSoftwareInterruptEntry

+

+		.SECTION   P,CODE

+		

+_vSoftwareInterruptEntry:

+

+	BRA	_vSoftwareInterruptISR

+

+		.RVECTOR	27, _vSoftwareInterruptEntry

+

+		.END

+

+

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX200/portmacro.h b/FreeRTOS/Source/portable/Renesas/RX200/portmacro.h
new file mode 100644
index 0000000..beab146
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX200/portmacro.h
@@ -0,0 +1,150 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* Hardware specifics. */

+#include "machine.h"

+

+/*-----------------------------------------------------------

+ * 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 - these are a bit legacy and not really used now, other than

+portSTACK_TYPE and portBASE_TYPE. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT				8	/* Could make four, according to manual. */

+#define portSTACK_GROWTH				-1

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()						nop()

+

+/* The location of the software interrupt register.  Software interrupts use

+vector 27. */

+#define portITU_SWINTR			( ( unsigned char * ) 0x000872E0 )

+#define portYIELD()				*portITU_SWINTR = 0x01; nop(); nop(); nop(); nop(); nop()

+#define portYIELD_FROM_ISR( x )	if( x != pdFALSE ) portYIELD()

+

+/*

+ * These macros should be called directly, but through the taskENTER_CRITICAL()

+ * and taskEXIT_CRITICAL() macros.

+ */

+#define portENABLE_INTERRUPTS() 	set_ipl( 0 )

+#define portDISABLE_INTERRUPTS() 	set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+

+/* Critical nesting counts are stored in the TCB. */

+#define portCRITICAL_NESTING_IN_TCB ( 1 )

+

+/* The critical nesting functions defined within tasks.c. */

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()	vTaskEnterCritical();

+#define portEXIT_CRITICAL()		vTaskExitCritical();

+

+/* As this port allows interrupt nesting... */

+#define portSET_INTERRUPT_MASK_FROM_ISR() get_ipl(); set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus ) set_ipl( uxSavedInterruptStatus )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX600/port.c b/FreeRTOS/Source/portable/Renesas/RX600/port.c
new file mode 100644
index 0000000..2330aac
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX600/port.c
@@ -0,0 +1,368 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the SH2A port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "string.h"

+

+/* Hardware specifics. */

+#include "iodefine.h"

+

+/*-----------------------------------------------------------*/

+

+/* Tasks should start with interrupts enabled and in Supervisor mode, therefore 

+PSW is set with U and I set, and PM and IPL clear. */

+#define portINITIAL_PSW     ( ( portSTACK_TYPE ) 0x00030000 )

+#define portINITIAL_FPSW    ( ( portSTACK_TYPE ) 0x00000100 )

+

+/*-----------------------------------------------------------*/

+

+/* The following lines are to ensure vSoftwareInterruptEntry can be referenced,

+ and therefore installed in the vector table, when the FreeRTOS code is built

+as a library. */

+extern portBASE_TYPE vSoftwareInterruptEntry;

+const portBASE_TYPE * p_vSoftwareInterruptEntry = &vSoftwareInterruptEntry;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Function to start the first task executing - written in asm code as direct

+ * access to registers is required. 

+ */

+static void prvStartFirstTask( void );

+

+/*

+ * Software interrupt handler.  Performs the actual context switch (saving and

+ * restoring of registers).  Written in asm code as direct register access is

+ * required.

+ */

+static void prvYieldHandler( void );

+

+/*

+ * The entry point for the software interrupt handler.  This is the function

+ * that calls the inline asm function prvYieldHandler().  It is installed in 

+ * the vector table, but the code that installs it is in prvYieldHandler rather

+ * than using a #pragma.

+ */

+void vSoftwareInterruptISR( void );

+

+/*-----------------------------------------------------------*/

+

+/* This is accessed by the inline assembler functions so is file scope for

+convenience. */

+extern void *pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* R0 is not included as it is the stack pointer. */

+	

+	*pxTopOfStack = 0x00;

+	pxTopOfStack--;

+ 	*pxTopOfStack = portINITIAL_PSW;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	

+	/* When debugging it can be useful if every register is set to a known

+	value.  Otherwise code space can be saved by just setting the registers

+	that need to be set. */

+	#ifdef USE_FULL_REGISTER_INITIALISATION

+	{

+		pxTopOfStack--;

+		*pxTopOfStack = 0xffffffff;	/* r15. */

+		pxTopOfStack--;

+		*pxTopOfStack = 0xeeeeeeee;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xdddddddd;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xcccccccc;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xbbbbbbbb;

+		pxTopOfStack--;

+		*pxTopOfStack = 0xaaaaaaaa;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x99999999;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x88888888;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x77777777;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x66666666;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x55555555;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x44444444;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x33333333;

+		pxTopOfStack--;

+		*pxTopOfStack = 0x22222222;

+		pxTopOfStack--;

+	}

+	#else

+	{

+		pxTopOfStack -= 15;

+	}

+	#endif

+	

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters; /* R1 */

+	pxTopOfStack--;				

+	*pxTopOfStack = portINITIAL_FPSW;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x12345678; /* Accumulator. */

+	pxTopOfStack--;

+	*pxTopOfStack = 0x87654321; /* Accumulator. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vApplicationSetupTimerInterrupt( void );

+

+	/* Use pxCurrentTCB just so it does not get optimised away. */

+	if( pxCurrentTCB != NULL )

+	{

+		/* Call an application function to set up the timer that will generate the

+		tick interrupt.  This way the application can decide which peripheral to 

+		use.  A demo application is provided to show a suitable example. */

+		vApplicationSetupTimerInterrupt();

+

+		/* Enable the software interrupt. */		

+		_IEN( _ICU_SWINT ) = 1;

+		

+		/* Ensure the software interrupt is clear. */

+		_IR( _ICU_SWINT ) = 0;

+		

+		/* Ensure the software interrupt is set to the kernel priority. */

+		_IPR( _ICU_SWINT ) = configKERNEL_INTERRUPT_PRIORITY;

+	

+		/* Start the first task. */

+		prvStartFirstTask();

+	}

+

+	/* Just to make sure the function is not optimised away. */

+	( void ) vSoftwareInterruptISR();

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+#pragma inline_asm prvStartFirstTask

+static void prvStartFirstTask( void )

+{

+	/* When starting the scheduler there is nothing that needs moving to the

+	interrupt stack because the function is not called from an interrupt.

+	Just ensure the current stack is the user stack. */

+	SETPSW	U

+

+	/* Obtain the location of the stack associated with which ever task 

+	pxCurrentTCB is currently pointing to. */

+	MOV.L	#_pxCurrentTCB, R15

+	MOV.L	[R15], R15

+	MOV.L	[R15], R0

+

+	/* Restore the registers from the stack of the task pointed to by 

+	pxCurrentTCB. */

+    POP		R15

+    MVTACLO	R15 		/* Accumulator low 32 bits. */

+    POP		R15

+    MVTACHI	R15 		/* Accumulator high 32 bits. */

+    POP		R15

+    MVTC	R15,FPSW 	/* Floating point status word. */

+    POPM	R1-R15 		/* R1 to R15 - R0 is not included as it is the SP. */

+    RTE					/* This pops the remaining registers. */

+    NOP

+    NOP

+}

+/*-----------------------------------------------------------*/

+

+#pragma interrupt ( vTickISR( vect = _VECT( configTICK_VECTOR ), enable ) )

+void vTickISR( void )

+{

+	/* Increment the tick, and perform any processing the new tick value

+	necessitates. */

+	set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY );

+	{

+		vTaskIncrementTick();

+	}

+	set_ipl( configKERNEL_INTERRUPT_PRIORITY );

+	

+	/* Only select a new task if the preemptive scheduler is being used. */

+	#if( configUSE_PREEMPTION == 1 )

+		taskYIELD();

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+void vSoftwareInterruptISR( void )

+{

+	prvYieldHandler();

+}

+/*-----------------------------------------------------------*/

+

+#pragma inline_asm prvYieldHandler

+static void prvYieldHandler( void )

+{

+	/* Re-enable interrupts. */

+	SETPSW	I

+

+	/* Move the data that was automatically pushed onto the interrupt stack when

+	the interrupt occurred from the interrupt stack to the user stack.  

+	

+	R15 is saved before it is clobbered. */

+	PUSH.L	R15

+	

+	/* Read the user stack pointer. */

+	MVFC	USP, R15

+	

+	/* Move the address down to the data being moved. */

+	SUB		#12, R15

+	MVTC	R15, USP

+	

+	/* Copy the data across. */

+	MOV.L	[ R0 ], [ R15 ] ; R15

+	MOV.L 	4[ R0 ], 4[ R15 ]  ; PC

+	MOV.L	8[ R0 ], 8[ R15 ]  ; PSW

+

+	/* Move the interrupt stack pointer to its new correct position. */

+	ADD	#12, R0

+	

+	/* All the rest of the registers are saved directly to the user stack. */

+	SETPSW	U

+

+	/* Save the rest of the general registers (R15 has been saved already). */

+	PUSHM	R1-R14

+	

+	/* Save the FPSW and accumulator. */

+	MVFC	FPSW, R15

+	PUSH.L	R15

+	MVFACHI	R15

+	PUSH.L	R15

+	MVFACMI	R15	; Middle order word.

+	SHLL	#16, R15 ; Shifted left as it is restored to the low order word.

+	PUSH.L	R15

+

+	/* Save the stack pointer to the TCB. */

+	MOV.L	#_pxCurrentTCB, R15

+	MOV.L	[ R15 ], R15

+	MOV.L	R0, [ R15 ]

+			

+	/* Ensure the interrupt mask is set to the syscall priority while the kernel

+	structures are being accessed. */

+	MVTIPL	#configMAX_SYSCALL_INTERRUPT_PRIORITY

+

+	/* Select the next task to run. */

+	BSR.A	_vTaskSwitchContext

+

+	/* Reset the interrupt mask as no more data structure access is required. */

+	MVTIPL	#configKERNEL_INTERRUPT_PRIORITY

+

+	/* Load the stack pointer of the task that is now selected as the Running

+	state task from its TCB. */

+	MOV.L	#_pxCurrentTCB,R15

+	MOV.L	[ R15 ], R15

+	MOV.L	[ R15 ], R0

+

+	/* Restore the context of the new task.  The PSW (Program Status Word) and

+	PC will be popped by the RTE instruction. */

+	POP		R15

+	MVTACLO	R15

+	POP		R15

+	MVTACHI	R15

+	POP		R15

+	MVTC	R15,FPSW

+	POPM	R1-R15

+	RTE

+	NOP

+	NOP

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+	

+	/* The following line is just to prevent the symbol getting optimised away. */

+	( void ) vTaskSwitchContext();

+}

+/*-----------------------------------------------------------*/

+

+

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX600/port_asm.src b/FreeRTOS/Source/portable/Renesas/RX600/port_asm.src
new file mode 100644
index 0000000..1e506b3
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX600/port_asm.src
@@ -0,0 +1,67 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+		.GLB	_vSoftwareInterruptISR

+                .GLB    _vSoftwareInterruptEntry

+

+		.SECTION   P,CODE

+		

+_vSoftwareInterruptEntry:

+

+	BRA	_vSoftwareInterruptISR

+

+		.RVECTOR	27, _vSoftwareInterruptEntry

+

+		.END

+

+

+

diff --git a/FreeRTOS/Source/portable/Renesas/RX600/portmacro.h b/FreeRTOS/Source/portable/Renesas/RX600/portmacro.h
new file mode 100644
index 0000000..beab146
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/RX600/portmacro.h
@@ -0,0 +1,150 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#ifdef __cplusplus

+extern "C" {

+#endif

+

+/* Hardware specifics. */

+#include "machine.h"

+

+/*-----------------------------------------------------------

+ * 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 - these are a bit legacy and not really used now, other than

+portSTACK_TYPE and portBASE_TYPE. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT				8	/* Could make four, according to manual. */

+#define portSTACK_GROWTH				-1

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()						nop()

+

+/* The location of the software interrupt register.  Software interrupts use

+vector 27. */

+#define portITU_SWINTR			( ( unsigned char * ) 0x000872E0 )

+#define portYIELD()				*portITU_SWINTR = 0x01; nop(); nop(); nop(); nop(); nop()

+#define portYIELD_FROM_ISR( x )	if( x != pdFALSE ) portYIELD()

+

+/*

+ * These macros should be called directly, but through the taskENTER_CRITICAL()

+ * and taskEXIT_CRITICAL() macros.

+ */

+#define portENABLE_INTERRUPTS() 	set_ipl( 0 )

+#define portDISABLE_INTERRUPTS() 	set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+

+/* Critical nesting counts are stored in the TCB. */

+#define portCRITICAL_NESTING_IN_TCB ( 1 )

+

+/* The critical nesting functions defined within tasks.c. */

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()	vTaskEnterCritical();

+#define portEXIT_CRITICAL()		vTaskExitCritical();

+

+/* As this port allows interrupt nesting... */

+#define portSET_INTERRUPT_MASK_FROM_ISR() get_ipl(); set_ipl( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus ) set_ipl( uxSavedInterruptStatus )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Renesas/SH2A_FPU/ISR_Support.inc b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/ISR_Support.inc
new file mode 100644
index 0000000..d9e80c1
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/ISR_Support.inc
@@ -0,0 +1,100 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+	.macro portSAVE_CONTEXT

+

+	; Save r0 to r14 and pr.

+	movml.l r15, @-r15

+	

+	; Save mac1, mach and gbr

+	sts.l	macl, @-r15

+	sts.l	mach, @-r15

+	stc.l	gbr, @-r15

+	

+	; Get the address of pxCurrentTCB

+	mov.l	#_pxCurrentTCB, r0

+	

+	; Get the address of pxTopOfStack from the TCB.

+	mov.l	@r0, r0

+	

+	; Save the stack pointer in pxTopOfStack.

+	mov.l	r15, @r0

+

+	.endm

+

+;-----------------------------------------------------------

+

+	.macro portRESTORE_CONTEXT

+

+	; Get the address of the pxCurrentTCB variable.

+	mov.l	#_pxCurrentTCB, r0

+

+	; Get the address of the task stack from pxCurrentTCB.

+	mov.l	@r0, r0

+

+	; Get the task stack itself into the stack pointer. 

+	mov.l	@r0, r15		

+

+	; Restore system registers.

+	ldc.l	@r15+, gbr

+	lds.l	@r15+, mach

+	lds.l	@r15+, macl

+

+	; Restore r0 to r14 and PR

+	movml.l	@r15+, r15

+	

+	; Pop the SR and PC to jump to the start of the task.

+	rte

+	nop

+

+	.endm

+;-----------------------------------------------------------
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/Renesas/SH2A_FPU/port.c b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/port.c
new file mode 100644
index 0000000..7763b21
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/port.c
@@ -0,0 +1,306 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the SH2A port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Library includes. */

+#include "string.h"

+

+/*-----------------------------------------------------------*/

+

+/* The SR assigned to a newly created task.  The only important thing in this

+value is for all interrupts to be enabled. */

+#define portINITIAL_SR				( 0UL )

+

+/* Dimensions the array into which the floating point context is saved.  

+Allocate enough space for FPR0 to FPR15, FPUL and FPSCR, each of which is 4

+bytes big.  If this number is changed then the 72 in portasm.src also needs

+changing. */

+#define portFLOP_REGISTERS_TO_STORE	( 18 )

+#define portFLOP_STORAGE_SIZE 		( portFLOP_REGISTERS_TO_STORE * 4 )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * The TRAPA handler used to force a context switch.

+ */

+void vPortYield( void );

+

+/*

+ * Function to start the first task executing - defined in portasm.src.

+ */

+extern void vPortStartFirstTask( void );

+

+/*

+ * Obtains the current GBR value - defined in portasm.src.

+ */

+extern unsigned long ulPortGetGBR( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Mark the end of the stack - used for debugging only and can be removed. */

+	*pxTopOfStack = 0x11111111UL;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22222222UL;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33333333UL;

+	pxTopOfStack--;

+

+	/* SR. */

+	*pxTopOfStack = portINITIAL_SR; 

+	pxTopOfStack--;

+	

+	/* PC. */

+	*pxTopOfStack = ( unsigned long ) pxCode;

+	pxTopOfStack--;

+	

+	/* PR. */

+	*pxTopOfStack = 15;

+	pxTopOfStack--;

+	

+	/* 14. */

+	*pxTopOfStack = 14;

+	pxTopOfStack--;

+

+	/* R13. */

+	*pxTopOfStack = 13;

+	pxTopOfStack--;

+

+	/* R12. */

+	*pxTopOfStack = 12;

+	pxTopOfStack--;

+

+	/* R11. */

+	*pxTopOfStack = 11;

+	pxTopOfStack--;

+

+	/* R10. */

+	*pxTopOfStack = 10;

+	pxTopOfStack--;

+

+	/* R9. */

+	*pxTopOfStack = 9;

+	pxTopOfStack--;

+

+	/* R8. */

+	*pxTopOfStack = 8;

+	pxTopOfStack--;

+

+	/* R7. */

+	*pxTopOfStack = 7;

+	pxTopOfStack--;

+

+	/* R6. */

+	*pxTopOfStack = 6;

+	pxTopOfStack--;

+

+	/* R5. */

+	*pxTopOfStack = 5;

+	pxTopOfStack--;

+

+	/* R4. */

+	*pxTopOfStack = ( unsigned long ) pvParameters;

+	pxTopOfStack--;

+

+	/* R3. */

+	*pxTopOfStack = 3;

+	pxTopOfStack--;

+

+	/* R2. */

+	*pxTopOfStack = 2;

+	pxTopOfStack--;

+

+	/* R1. */

+	*pxTopOfStack = 1;

+	pxTopOfStack--;

+	

+	/* R0 */

+	*pxTopOfStack = 0;

+	pxTopOfStack--;

+	

+	/* MACL. */

+	*pxTopOfStack = 16;

+	pxTopOfStack--;

+	

+	/* MACH. */

+	*pxTopOfStack = 17;

+	pxTopOfStack--;

+	

+	/* GBR. */

+	*pxTopOfStack = ulPortGetGBR();

+	

+	/* GBR = global base register.

+	   VBR = vector base register.

+	   TBR = jump table base register.

+	   R15 is the stack pointer. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+extern void vApplicationSetupTimerInterrupt( void );

+

+	/* Call an application function to set up the timer that will generate the

+	tick interrupt.  This way the application can decide which peripheral to 

+	use.  A demo application is provided to show a suitable example. */

+	vApplicationSetupTimerInterrupt();

+

+	/* Start the first task.  This will only restore the standard registers and

+	not the flop registers.  This does not really matter though because the only

+	flop register that is initialised to a particular value is fpscr, and it is

+	only initialised to the current value, which will still be the current value

+	when the first task starts executing. */

+	trapa( portSTART_SCHEDULER_TRAP_NO );

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented as there is nothing to return to. */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYield( void )

+{

+long lInterruptMask;

+

+	/* Ensure the yield trap runs at the same priority as the other interrupts

+	that can cause a context switch. */

+	lInterruptMask = get_imask();

+

+	/* taskYIELD() can only be called from a task, not an interrupt, so the

+	current interrupt mask can only be 0 or portKERNEL_INTERRUPT_PRIORITY and

+	the mask can be set without risk of accidentally lowering the mask value. */	

+	set_imask( portKERNEL_INTERRUPT_PRIORITY );

+	

+	trapa( portYIELD_TRAP_NO );

+	

+	/* Restore the interrupt mask to whatever it was previously (when the

+	function was entered). */

+	set_imask( ( int ) lInterruptMask );

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortUsesFloatingPoint( xTaskHandle xTask )

+{

+unsigned long *pulFlopBuffer;

+portBASE_TYPE xReturn;

+extern void * volatile pxCurrentTCB;

+

+	/* This function tells the kernel that the task referenced by xTask is

+	going to use the floating point registers and therefore requires the

+	floating point registers saved as part of its context. */

+

+	/* Passing NULL as xTask is used to indicate that the calling task is the

+	subject task - so pxCurrentTCB is the task handle. */

+	if( xTask == NULL )

+	{

+		xTask = ( xTaskHandle ) pxCurrentTCB;

+	}

+

+	/* Allocate a buffer large enough to hold all the flop registers. */

+	pulFlopBuffer = ( unsigned long * ) pvPortMalloc( portFLOP_STORAGE_SIZE );

+	

+	if( pulFlopBuffer != NULL )

+	{

+		/* Start with the registers in a benign state. */

+		memset( ( void * ) pulFlopBuffer, 0x00, portFLOP_STORAGE_SIZE );

+		

+		/* The first thing to get saved in the buffer is the FPSCR value -

+		initialise this to the current FPSCR value. */

+		*pulFlopBuffer = get_fpscr();

+		

+		/* Use the task tag to point to the flop buffer.  Pass pointer to just 

+		above the buffer because the flop save routine uses a pre-decrement. */

+		vTaskSetApplicationTaskTag( xTask, ( void * ) ( pulFlopBuffer + portFLOP_REGISTERS_TO_STORE ) );		

+		xReturn = pdPASS;

+	}

+	else

+	{

+		xReturn = pdFAIL;

+	}

+	

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portasm.src b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portasm.src
new file mode 100644
index 0000000..a6c62de
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portasm.src
@@ -0,0 +1,176 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;	

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	.import _pxCurrentTCB

+	.import _vTaskSwitchContext

+	.import _vTaskIncrementTick

+

+	.export _vPortStartFirstTask

+	.export _ulPortGetGBR

+	.export _vPortYieldHandler

+	.export _vPortPreemptiveTick

+	.export _vPortCooperativeTick

+	.export _vPortSaveFlopRegisters

+	.export _vPortRestoreFlopRegisters

+

+    .section    P

+

+	.INCLUDE "ISR_Support.inc"

+	

+_vPortStartFirstTask:

+		

+	portRESTORE_CONTEXT

+	

+;-----------------------------------------------------------

+

+_vPortYieldHandler:

+

+	portSAVE_CONTEXT

+

+	mov.l	#_vTaskSwitchContext, r0

+	jsr		@r0

+	nop

+

+	portRESTORE_CONTEXT

+	

+;-----------------------------------------------------------

+

+_vPortPreemptiveTick

+

+	portSAVE_CONTEXT

+	

+	mov.l	#_vTaskIncrementTick, r0

+	jsr		@r0

+	nop

+

+	mov.l	#_vTaskSwitchContext, r0

+	jsr		@r0

+	nop

+

+	portRESTORE_CONTEXT

+	

+;-----------------------------------------------------------

+

+_vPortCooperativeTick

+

+	portSAVE_CONTEXT

+	

+	mov.l	#_vTaskIncrementTick, r0

+	jsr		@r0

+	nop

+

+	portRESTORE_CONTEXT

+	

+;-----------------------------------------------------------

+

+_ulPortGetGBR:

+

+	stc.l	gbr, r0

+	rts

+	nop

+

+;-----------------------------------------------------------

+

+_vPortSaveFlopRegisters:

+

+	fmov.s	fr0, @-r4

+	fmov.s	fr1, @-r4

+	fmov.s	fr2, @-r4

+	fmov.s	fr3, @-r4

+	fmov.s	fr4, @-r4

+	fmov.s	fr5, @-r4

+	fmov.s	fr6, @-r4

+	fmov.s	fr7, @-r4

+	fmov.s	fr8, @-r4

+	fmov.s	fr9, @-r4

+	fmov.s	fr10, @-r4

+	fmov.s	fr11, @-r4

+	fmov.s	fr12, @-r4

+	fmov.s	fr13, @-r4

+	fmov.s	fr14, @-r4

+	fmov.s	fr15, @-r4	

+	sts.l   fpul, @-r4

+	sts.l   fpscr, @-r4

+	

+	rts

+	nop

+

+;-----------------------------------------------------------

+	

+_vPortRestoreFlopRegisters:

+

+	add.l  #-72, r4

+	lds.l  @r4+, fpscr

+	lds.l  @r4+, fpul	

+	fmov.s @r4+, fr15

+	fmov.s @r4+, fr14

+	fmov.s @r4+, fr13

+	fmov.s @r4+, fr12

+	fmov.s @r4+, fr11

+	fmov.s @r4+, fr10

+	fmov.s @r4+, fr9

+	fmov.s @r4+, fr8

+	fmov.s @r4+, fr7

+	fmov.s @r4+, fr6

+	fmov.s @r4+, fr5

+	fmov.s @r4+, fr4

+	fmov.s @r4+, fr3

+	fmov.s @r4+, fr2

+	fmov.s @r4+, fr1

+	fmov.s @r4+, fr0

+	

+	rts

+	nop

+	

+	.end

+		

diff --git a/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portmacro.h b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portmacro.h
new file mode 100644
index 0000000..08da030
--- /dev/null
+++ b/FreeRTOS/Source/portable/Renesas/SH2A_FPU/portmacro.h
@@ -0,0 +1,170 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#include <machine.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 - these are a bit legacy and not really used now, other than

+portSTACK_TYPE and portBASE_TYPE. */

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		double

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT				8

+#define portSTACK_GROWTH				-1

+#define portTICK_RATE_MS				( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portNOP()						nop()

+#define portSTART_SCHEDULER_TRAP_NO		( 32 )

+#define portYIELD_TRAP_NO				( 33 )

+#define portKERNEL_INTERRUPT_PRIORITY	( 1 )

+

+void vPortYield( void );

+#define portYIELD()						vPortYield()

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( x )			if( x != pdFALSE ) vTaskSwitchContext()

+

+/* 

+ * This function tells the kernel that the task referenced by xTask is going to 

+ * use the floating point registers and therefore requires the floating point 

+ * registers saved as part of its context. 

+ */

+portBASE_TYPE xPortUsesFloatingPoint( void* xTask );

+

+/*

+ * The flop save and restore functions are defined in portasm.src and called by

+ * the trace "task switched in" and "trace task switched out" macros. 

+ */

+void vPortSaveFlopRegisters( void *pulBuffer );

+void vPortRestoreFlopRegisters( void *pulBuffer );

+

+/*

+ * pxTaskTag is used to point to the buffer into which the floating point 

+ * context should be saved.  If pxTaskTag is NULL then the task does not use

+ * a floating point context.

+ */

+#define traceTASK_SWITCHED_OUT() if( pxCurrentTCB->pxTaskTag != NULL ) vPortSaveFlopRegisters( pxCurrentTCB->pxTaskTag )

+#define traceTASK_SWITCHED_IN() if( pxCurrentTCB->pxTaskTag != NULL ) vPortRestoreFlopRegisters( pxCurrentTCB->pxTaskTag )

+

+/*

+ * These macros should be called directly, but through the taskENTER_CRITICAL()

+ * and taskEXIT_CRITICAL() macros.

+ */

+#define portENABLE_INTERRUPTS() 	set_imask( 0x00 )

+#define portDISABLE_INTERRUPTS() 	set_imask( portKERNEL_INTERRUPT_PRIORITY )

+

+/* Critical nesting counts are stored in the TCB. */

+#define portCRITICAL_NESTING_IN_TCB ( 1 )

+

+/* The critical nesting functions defined within tasks.c. */

+extern void vTaskEnterCritical( void );

+extern void vTaskExitCritical( void );

+#define portENTER_CRITICAL()	vTaskEnterCritical();

+#define portEXIT_CRITICAL()		vTaskExitCritical();

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Rowley/ARM7/readme.txt b/FreeRTOS/Source/portable/Rowley/ARM7/readme.txt
new file mode 100644
index 0000000..8d3e87f
--- /dev/null
+++ b/FreeRTOS/Source/portable/Rowley/ARM7/readme.txt
@@ -0,0 +1 @@
+The Rowley ARM7 demo uses the GCC ARM7 port files.
\ No newline at end of file
diff --git a/FreeRTOS/Source/portable/Rowley/MSP430F449/port.c b/FreeRTOS/Source/portable/Rowley/MSP430F449/port.c
new file mode 100644
index 0000000..362df03
--- /dev/null
+++ b/FreeRTOS/Source/portable/Rowley/MSP430F449/port.c
@@ -0,0 +1,211 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the MSP430 port.

+ *----------------------------------------------------------*/

+

+/* Constants required for hardware setup.  The tick ISR runs off the ACLK, 

+not the MCLK. */

+#define portACLK_FREQUENCY_HZ			( ( portTickType ) 32768 )

+#define portINITIAL_CRITICAL_NESTING	( ( unsigned short ) 10 )

+#define portFLAGS_INT_ENABLED			( ( portSTACK_TYPE ) 0x08 )

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/* Each task maintains a count of the critical section nesting depth.  Each 

+time a critical section is entered the count is incremented.  Each time a 

+critical section is exited the count is decremented - with interrupts only 

+being re-enabled if the count is zero.

+

+usCriticalNesting will get set to zero when the scheduler starts, but must

+not be initialised to zero as this will cause problems during the startup

+sequence. */

+volatile unsigned short usCriticalNesting = portINITIAL_CRITICAL_NESTING;

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses timer 0, but

+ * could have alternatively used the watchdog timer or timer 1.

+ */

+void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* 

+		Place a few bytes of known values on the bottom of the stack. 

+		This is just useful for debugging and can be included if required.

+

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;

+		pxTopOfStack--;

+		*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;

+		pxTopOfStack--; 

+	*/

+

+	/* The msp430 automatically pushes the PC then SR onto the stack before 

+	executing an ISR.  We want the stack to look just as if this has happened

+	so place a pointer to the start of the task on the stack first - followed

+	by the flags we want the task to use when it starts up. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;

+	pxTopOfStack--;

+	*pxTopOfStack = portFLAGS_INT_ENABLED;

+	pxTopOfStack--;

+

+	/* Next the general purpose registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x7777;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xaaaa;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xbbbb;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xcccc;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xdddd;

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xeeee;

+	pxTopOfStack--;

+

+	/* When the task starts is will expect to find the function parameter in

+	R15. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;

+	pxTopOfStack--;

+

+	/* A variable is used to keep track of the critical section nesting.  

+	This variable has to be stored as part of the task context and is 

+	initially set to zero. */

+	*pxTopOfStack = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	/* Return a pointer to the top of the stack we have generated so this can

+	be stored in the task control block for the task. */

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the MSP430 port will get stopped.  If required simply

+	disable the tick interrupt here. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Hardware initialisation to generate the RTOS tick.  This uses timer 0

+ * but could alternatively use the watchdog timer or timer 1. 

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Ensure the timer is stopped. */

+	TACTL = 0;

+

+	/* Run the timer of the ACLK. */

+	TACTL = TASSEL_1;

+

+	/* Clear everything to start with. */

+	TACTL |= TACLR;

+

+	/* Set the compare match value according to the tick rate we want. */

+	TACCR0 = portACLK_FREQUENCY_HZ / configTICK_RATE_HZ;

+

+	/* Enable the interrupts. */

+	TACCTL0 = CCIE;

+

+	/* Start up clean. */

+	TACTL |= TACLR;

+

+	/* Up mode. */

+	TACTL |= MC_1;

+}

+/*-----------------------------------------------------------*/

+

+

+	

diff --git a/FreeRTOS/Source/portable/Rowley/MSP430F449/portasm.h b/FreeRTOS/Source/portable/Rowley/MSP430F449/portasm.h
new file mode 100644
index 0000000..8a48bc2
--- /dev/null
+++ b/FreeRTOS/Source/portable/Rowley/MSP430F449/portasm.h
@@ -0,0 +1,119 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORT_ASM_H

+#define PORT_ASM_H

+

+portSAVE_CONTEXT macro

+                /* Save the remaining registers. */

+		push	r4

+		push	r5

+		push	r6

+		push	r7

+		push	r8

+		push	r9

+		push	r10

+		push	r11

+		push	r12

+		push	r13

+		push	r14

+		push	r15

+		mov.w	&_usCriticalNesting, r14

+		push	r14

+		mov.w	&_pxCurrentTCB, r12

+		mov.w	r1, @r12

+		endm

+/*-----------------------------------------------------------*/

+		

+portRESTORE_CONTEXT macro

+		mov.w	&_pxCurrentTCB, r12

+		mov.w	@r12, r1

+		pop		r15

+		mov.w	r15, &_usCriticalNesting

+		pop		r15

+		pop		r14

+		pop		r13

+		pop		r12

+		pop		r11

+		pop		r10

+		pop		r9

+		pop		r8

+		pop		r7

+		pop		r6

+		pop		r5

+		pop		r4

+

+		/* The last thing on the stack will be the status register.

+                Ensure the power down bits are clear ready for the next

+                time this power down register is popped from the stack. */

+		bic.w   #0xf0,0(SP)

+

+		reti

+		endm

+/*-----------------------------------------------------------*/

+

+#endif

+

diff --git a/FreeRTOS/Source/portable/Rowley/MSP430F449/portext.asm b/FreeRTOS/Source/portable/Rowley/MSP430F449/portext.asm
new file mode 100644
index 0000000..e64d2c0
--- /dev/null
+++ b/FreeRTOS/Source/portable/Rowley/MSP430F449/portext.asm
@@ -0,0 +1,142 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOSConfig.h"

+#include "portasm.h"

+

+

+.CODE

+

+/*

+ * The RTOS tick ISR.

+ *

+ * If the cooperative scheduler is in use this simply increments the tick 

+ * count.

+ *

+ * If the preemptive scheduler is in use a context switch can also occur.

+ */

+_vTickISR:

+		portSAVE_CONTEXT

+				

+		call	#_vTaskIncrementTick

+

+		#if configUSE_PREEMPTION == 1

+			call	#_vTaskSwitchContext

+		#endif

+		

+		portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Manual context switch called by the portYIELD() macro.

+ */                

+_vPortYield::

+

+		/* Mimic an interrupt by pushing the SR. */

+		push	SR			

+

+		/* Now the SR is stacked we can disable interrupts. */

+		dint			

+				

+		/* Save the context of the current task. */

+		portSAVE_CONTEXT			

+

+		/* Switch to the highest priority task that is ready to run. */

+		call	#_vTaskSwitchContext		

+

+		/* Restore the context of the new task. */

+		portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/

+

+

+/*

+ * Start off the scheduler by initialising the RTOS tick timer, then restoring

+ * the context of the first task.

+ */

+_xPortStartScheduler::

+

+		/* Setup the hardware to generate the tick.  Interrupts are disabled 

+		when this function is called. */

+		call	#_prvSetupTimerInterrupt

+

+		/* Restore the context of the first task that is going to run. */

+		portRESTORE_CONTEXT

+/*-----------------------------------------------------------*/          

+      		

+

+		/* Place the tick ISR in the correct vector. */

+		.VECTORS

+		

+		.KEEP

+		

+		ORG		TIMERA0_VECTOR

+		DW		_vTickISR

+		

+

+

+		END

+		

diff --git a/FreeRTOS/Source/portable/Rowley/MSP430F449/portmacro.h b/FreeRTOS/Source/portable/Rowley/MSP430F449/portmacro.h
new file mode 100644
index 0000000..864cb01
--- /dev/null
+++ b/FreeRTOS/Source/portable/Rowley/MSP430F449/portmacro.h
@@ -0,0 +1,166 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/*-----------------------------------------------------------

+ * 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		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* Interrupt control macros. */

+#define portDISABLE_INTERRUPTS()	_DINT(); _NOP()

+#define portENABLE_INTERRUPTS()		_EINT();

+/*-----------------------------------------------------------*/

+

+/* Critical section control macros. */

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portSHORT ) 0 )

+

+#define portENTER_CRITICAL()													\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	portDISABLE_INTERRUPTS();													\

+																				\

+	/* Now interrupts are disabled usCriticalNesting can be accessed */			\

+	/* directly.  Increment ulCriticalNesting to keep a count of how many */	\

+	/* times portENTER_CRITICAL() has been called. */							\

+	usCriticalNesting++;														\

+}

+

+#define portEXIT_CRITICAL()														\

+{																				\

+extern volatile unsigned portSHORT usCriticalNesting;							\

+																				\

+	if( usCriticalNesting > portNO_CRITICAL_SECTION_NESTING )					\

+	{																			\

+		/* Decrement the nesting count as we are leaving a critical section. */	\

+		usCriticalNesting--;													\

+																				\

+		/* If the nesting level has reached zero then interrupts should be */	\

+		/* re-enabled. */														\

+		if( usCriticalNesting == portNO_CRITICAL_SECTION_NESTING )				\

+		{																		\

+			portENABLE_INTERRUPTS();											\

+		}																		\

+	}																			\

+}

+/*-----------------------------------------------------------*/

+

+/* Task utilities. */

+

+/*

+ * Manual context switch called by portYIELD or taskYIELD.  

+ */

+extern void vPortYield( void ); 

+#define portYIELD() vPortYield()

+/*-----------------------------------------------------------*/

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			2

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )	

+#define portNOP()	

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters ) __toplevel

+

+#if configINTERRUPT_EXAMPLE_METHOD == 2

+

+extern void vTaskSwitchContext( void );

+#define portYIELD_FROM_ISR( x ) if( x ) vTaskSwitchContext()

+

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/SDCC/Cygnal/port.c b/FreeRTOS/Source/portable/SDCC/Cygnal/port.c
new file mode 100644
index 0000000..b9c7533
--- /dev/null
+++ b/FreeRTOS/Source/portable/SDCC/Cygnal/port.c
@@ -0,0 +1,461 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Cygnal port.

+ *----------------------------------------------------------*/

+

+/* Standard includes. */

+#include <string.h>

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to setup timer 2 to produce the RTOS tick. */

+#define portCLOCK_DIVISOR				( ( unsigned long ) 12 )

+#define portMAX_TIMER_VALUE				( ( unsigned long ) 0xffff )

+#define portENABLE_TIMER				( ( unsigned char ) 0x04 )

+#define portTIMER_2_INTERRUPT_ENABLE	( ( unsigned char ) 0x20 )

+

+/* The value used in the IE register when a task first starts. */

+#define portGLOBAL_INTERRUPT_BIT	( ( portSTACK_TYPE ) 0x80 )

+

+/* The value used in the PSW register when a task first starts. */

+#define portINITIAL_PSW				( ( portSTACK_TYPE ) 0x00 )

+

+/* Macro to clear the timer 2 interrupt flag. */

+#define portCLEAR_INTERRUPT_FLAG()	TMR2CN &= ~0x80;

+

+/* Used during a context switch to store the size of the stack being copied

+to or from XRAM. */

+data static unsigned char ucStackBytes;

+

+/* Used during a context switch to point to the next byte in XRAM from/to which

+a RAM byte is to be copied. */

+xdata static portSTACK_TYPE * data pxXRAMStack;

+

+/* Used during a context switch to point to the next byte in RAM from/to which

+an XRAM byte is to be copied. */

+data static portSTACK_TYPE * data pxRAMStack;

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/*

+ * Setup the hardware to generate an interrupt off timer 2 at the required 

+ * frequency.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*-----------------------------------------------------------*/

+/*

+ * Macro that copies the current stack from internal RAM to XRAM.  This is 

+ * required as the 8051 only contains enough internal RAM for a single stack, 

+ * but we have a stack for every task.

+ */

+#define portCOPY_STACK_TO_XRAM()																\

+{																								\

+	/* pxCurrentTCB points to a TCB which itself points to the location into					\

+	which the first	stack byte should be copied.  Set pxXRAMStack to point						\

+	to the location into which the first stack byte is to be copied. */							\

+	pxXRAMStack = ( xdata portSTACK_TYPE * ) *( ( xdata portSTACK_TYPE ** ) pxCurrentTCB );		\

+																								\

+	/* Set pxRAMStack to point to the first byte to be coped from the stack. */					\

+	pxRAMStack = ( data portSTACK_TYPE * data ) configSTACK_START;								\

+																								\

+	/* Calculate the size of the stack we are about to copy from the current					\

+	stack pointer value. */																		\

+	ucStackBytes = SP - ( configSTACK_START - 1 );												\

+																								\

+	/* Before starting to copy the stack, store the calculated stack size so					\

+	the stack can be restored when the task is resumed. */										\

+	*pxXRAMStack = ucStackBytes;																\

+																								\

+	/* Copy each stack byte in turn.  pxXRAMStack is incremented first as we					\

+	have already stored the stack size into XRAM. */											\

+	while( ucStackBytes )																		\

+	{																							\

+		pxXRAMStack++;																			\

+		*pxXRAMStack = *pxRAMStack;																\

+		pxRAMStack++;																			\

+		ucStackBytes--;																			\

+	}																							\

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro that copies the stack of the task being resumed from XRAM into 

+ * internal RAM.

+ */

+#define portCOPY_XRAM_TO_STACK()																\

+{																								\

+	/* Setup the pointers as per portCOPY_STACK_TO_XRAM(), but this time to						\

+	copy the data back out of XRAM and into the stack. */										\

+	pxXRAMStack = ( xdata portSTACK_TYPE * ) *( ( xdata portSTACK_TYPE ** ) pxCurrentTCB );		\

+	pxRAMStack = ( data portSTACK_TYPE * data ) ( configSTACK_START - 1 );						\

+																								\

+	/* The first value stored in XRAM was the size of the stack - i.e. the						\

+	number of bytes we need to copy back. */													\

+	ucStackBytes = pxXRAMStack[ 0 ];															\

+																								\

+	/* Copy the required number of bytes back into the stack. */								\

+	do																							\

+	{																							\

+		pxXRAMStack++;																			\

+		pxRAMStack++;																			\

+		*pxRAMStack = *pxXRAMStack;																\

+		ucStackBytes--;																			\

+	} while( ucStackBytes );																	\

+																								\

+	/* Restore the stack pointer ready to use the restored stack. */							\

+	SP = ( unsigned char ) pxRAMStack;														\

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro to push the current execution context onto the stack, before the stack 

+ * is moved to XRAM. 

+ */

+#define portSAVE_CONTEXT()																		\

+{																								\

+	_asm																						\

+		/* Push ACC first, as when restoring the context it must be restored					\

+		last (it is used to set the IE register). */											\

+		push	ACC																				\

+		/* Store the IE register then disable interrupts. */									\

+		push	IE																				\

+		clr		_EA																				\

+		push	DPL																				\

+		push	DPH																				\

+		push	b																				\

+		push	ar2																				\

+		push	ar3																				\

+		push	ar4																				\

+		push	ar5																				\

+		push	ar6																				\

+		push	ar7																				\

+		push	ar0																				\

+		push	ar1																				\

+		push	PSW																				\

+	_endasm;																					\

+		PSW = 0;																				\

+	_asm																						\

+		push	_bp																				\

+	_endasm;																					\

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro that restores the execution context from the stack.  The execution 

+ * context was saved into the stack before the stack was copied into XRAM.

+ */

+#define portRESTORE_CONTEXT()																	\

+{																								\

+	_asm																						\

+		pop		_bp																				\

+		pop		PSW																				\

+		pop		ar1																				\

+		pop		ar0																				\

+		pop		ar7																				\

+		pop		ar6																				\

+		pop		ar5																				\

+		pop		ar4																				\

+		pop		ar3																				\

+		pop		ar2																				\

+		pop		b																				\

+		pop		DPH																				\

+		pop		DPL																				\

+		/* The next byte of the stack is the IE register.  Only the global						\

+		enable bit forms part of the task context.  Pop off the IE then set						\

+		the global enable bit to match that of the stored IE register. */						\

+		pop		ACC																				\

+		JB		ACC.7,0098$																		\

+		CLR		IE.7																			\

+		LJMP	0099$																			\

+	0098$:																						\

+		SETB	IE.7																			\

+	0099$:																						\

+		/* Finally pop off the ACC, which was the first register saved. */						\

+		pop		ACC																				\

+		reti																					\

+	_endasm;																					\

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned long ulAddress;

+portSTACK_TYPE *pxStartOfStack;

+

+	/* Leave space to write the size of the stack as the first byte. */

+	pxStartOfStack = pxTopOfStack;

+	pxTopOfStack++;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging and can be uncommented if required.

+	*pxTopOfStack = 0x11;

+	pxTopOfStack++;

+	*pxTopOfStack = 0x22;

+	pxTopOfStack++;

+	*pxTopOfStack = 0x33;

+	pxTopOfStack++;

+	*/

+

+	/* Simulate how the stack would look after a call to the scheduler tick 

+	ISR. 

+

+	The return address that would have been pushed by the MCU. */

+	ulAddress = ( unsigned long ) pxCode;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulAddress;

+	ulAddress >>= 8;

+	pxTopOfStack++;

+	*pxTopOfStack = ( portSTACK_TYPE ) ( ulAddress );

+	pxTopOfStack++;

+

+	/* Next all the registers will have been pushed by portSAVE_CONTEXT(). */

+	*pxTopOfStack = 0xaa;	/* acc */

+	pxTopOfStack++;	

+

+	/* We want tasks to start with interrupts enabled. */

+	*pxTopOfStack = portGLOBAL_INTERRUPT_BIT;

+	pxTopOfStack++;

+

+	/* The function parameters will be passed in the DPTR and B register as

+	a three byte generic pointer is used. */

+	ulAddress = ( unsigned long ) pvParameters;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulAddress;	/* DPL */

+	ulAddress >>= 8;

+	*pxTopOfStack++;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulAddress;	/* DPH */

+	ulAddress >>= 8;

+	pxTopOfStack++;

+	*pxTopOfStack = ( portSTACK_TYPE ) ulAddress;	/* b */

+	pxTopOfStack++;

+

+	/* The remaining registers are straight forward. */

+	*pxTopOfStack = 0x02;	/* R2 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x03;	/* R3 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x04;	/* R4 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x05;	/* R5 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x06;	/* R6 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x07;	/* R7 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x00;	/* R0 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x01;	/* R1 */

+	pxTopOfStack++;

+	*pxTopOfStack = 0x00;	/* PSW */

+	pxTopOfStack++;

+	*pxTopOfStack = 0xbb;	/* BP */

+

+	/* Dont increment the stack size here as we don't want to include

+	the stack size byte as part of the stack size count.

+

+	Finally we place the stack size at the beginning. */

+	*pxStartOfStack = ( portSTACK_TYPE ) ( pxTopOfStack - pxStartOfStack );

+

+	/* Unlike most ports, we return the start of the stack as this is where the

+	size of the stack is stored. */

+	return pxStartOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/* 

+ * See header file for description. 

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup timer 2 to generate the RTOS tick. */

+	prvSetupTimerInterrupt();	

+

+	/* Make sure we start with the expected SFR page.  This line should not

+	really be required. */

+	SFRPAGE = 0;

+

+	/* Copy the stack for the first task to execute from XRAM into the stack,

+	restore the task context from the new stack, then start running the task. */

+	portCOPY_XRAM_TO_STACK();

+	portRESTORE_CONTEXT();

+

+	/* Should never get here! */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented for this port. */

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch.  The first thing we do is save the registers so we

+ * can use a naked attribute.

+ */

+void vPortYield( void ) _naked

+{

+	/* Save the execution context onto the stack, then copy the entire stack

+	to XRAM.  This is necessary as the internal RAM is only large enough to

+	hold one stack, and we want one per task. 

+	

+	PERFORMANCE COULD BE IMPROVED BY ONLY COPYING TO XRAM IF A TASK SWITCH

+	IS REQUIRED. */

+	portSAVE_CONTEXT();

+	portCOPY_STACK_TO_XRAM();

+

+	/* Call the standard scheduler context switch function. */

+	vTaskSwitchContext();

+

+	/* Copy the stack of the task about to execute from XRAM into RAM and

+	restore it's context ready to run on exiting. */

+	portCOPY_XRAM_TO_STACK();

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 1

+	void vTimer2ISR( void ) interrupt 5 _naked

+	{

+		/* Preemptive context switch function triggered by the timer 2 ISR.

+		This does the same as vPortYield() (see above) with the addition

+		of incrementing the RTOS tick count. */

+

+		portSAVE_CONTEXT();

+		portCOPY_STACK_TO_XRAM();

+

+		vTaskIncrementTick();

+		vTaskSwitchContext();

+		

+		portCLEAR_INTERRUPT_FLAG();

+		portCOPY_XRAM_TO_STACK();

+		portRESTORE_CONTEXT();

+	}

+#else

+	void vTimer2ISR( void ) interrupt 5

+	{

+		/* When using the cooperative scheduler the timer 2 ISR is only 

+		required to increment the RTOS tick count. */

+

+		vTaskIncrementTick();

+		portCLEAR_INTERRUPT_FLAG();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+unsigned char ucOriginalSFRPage;

+

+/* Constants calculated to give the required timer capture values. */

+const unsigned long ulTicksPerSecond = configCPU_CLOCK_HZ / portCLOCK_DIVISOR;

+const unsigned long ulCaptureTime = ulTicksPerSecond / configTICK_RATE_HZ;

+const unsigned long ulCaptureValue = portMAX_TIMER_VALUE - ulCaptureTime;

+const unsigned char ucLowCaptureByte = ( unsigned char ) ( ulCaptureValue & ( unsigned long ) 0xff );

+const unsigned char ucHighCaptureByte = ( unsigned char ) ( ulCaptureValue >> ( unsigned long ) 8 );

+

+	/* NOTE:  This uses a timer only present on 8052 architecture. */

+

+	/* Remember the current SFR page so we can restore it at the end of the

+	function. */

+	ucOriginalSFRPage = SFRPAGE;

+	SFRPAGE = 0;

+

+	/* TMR2CF can be left in its default state. */	

+	TMR2CF = ( unsigned char ) 0;

+

+	/* Setup the overflow reload value. */

+	RCAP2L = ucLowCaptureByte;

+	RCAP2H = ucHighCaptureByte;

+

+	/* The initial load is performed manually. */

+	TMR2L = ucLowCaptureByte;

+	TMR2H = ucHighCaptureByte;

+

+	/* Enable the timer 2 interrupts. */

+	IE |= portTIMER_2_INTERRUPT_ENABLE;

+

+	/* Interrupts are disabled when this is called so the timer can be started

+	here. */

+	TMR2CN = portENABLE_TIMER;

+

+	/* Restore the original SFR page. */

+	SFRPAGE = ucOriginalSFRPage;

+}

+

+

+

+

diff --git a/FreeRTOS/Source/portable/SDCC/Cygnal/portmacro.h b/FreeRTOS/Source/portable/SDCC/Cygnal/portmacro.h
new file mode 100644
index 0000000..9adf240
--- /dev/null
+++ b/FreeRTOS/Source/portable/SDCC/Cygnal/portmacro.h
@@ -0,0 +1,150 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#if configUSE_PREEMPTION == 0

+	void vTimer2ISR( void ) interrupt 5;

+#else

+	void vTimer2ISR( void ) interrupt 5 _naked;

+#endif

+

+void vSerialISR( void ) interrupt 4;

+

+

+/*-----------------------------------------------------------

+ * 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		float

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned portCHAR

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Critical section management. */

+#define portENTER_CRITICAL()		_asm		\

+									push	ACC	\

+									push	IE	\

+									_endasm;	\

+									EA = 0;

+

+#define portEXIT_CRITICAL()			_asm			\

+									pop		ACC		\

+									_endasm;		\

+									ACC &= 0x80;	\

+									IE |= ACC;		\

+									_asm			\

+									pop		ACC		\

+									_endasm;

+

+#define portDISABLE_INTERRUPTS()	EA = 0;

+#define portENABLE_INTERRUPTS()		EA = 1;

+/*-----------------------------------------------------------*/	

+

+/* Hardware specifics. */

+#define portBYTE_ALIGNMENT			1

+#define portSTACK_GROWTH			( 1 )

+#define portTICK_RATE_MS			( ( unsigned portLONG ) 1000 / configTICK_RATE_HZ )		

+/*-----------------------------------------------------------*/	

+

+/* Task utilities. */

+void vPortYield( void ) _naked;

+#define portYIELD()	vPortYield();

+/*-----------------------------------------------------------*/	

+

+#define portNOP()				_asm	\

+									nop \

+								_endasm;

+

+/*-----------------------------------------------------------*/	

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#endif /* PORTMACRO_H */

+

+

diff --git a/FreeRTOS/Source/portable/Softune/MB91460/__STD_LIB_sbrk.c b/FreeRTOS/Source/portable/Softune/MB91460/__STD_LIB_sbrk.c
new file mode 100644
index 0000000..fe70d48
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB91460/__STD_LIB_sbrk.c
@@ -0,0 +1,23 @@
+#include "FreeRTOSConfig.h"

+#include <stdlib.h>

+

+	static  long         brk_siz  =  0;

+//	#if  configTOTAL_HEAP_SIZE != 0

+	typedef int          _heep_t;

+	#define ROUNDUP(s)   (((s)+sizeof(_heep_t)-1)&~(sizeof(_heep_t)-1))

+	static  _heep_t      _heep[ROUNDUP(configTOTAL_HEAP_SIZE)/sizeof(_heep_t)];

+	#define              _heep_size      ROUNDUP(configTOTAL_HEAP_SIZE)

+/*	#else

+	extern  char        *_heep;

+	extern  long        _heep_size;

+	#endif

+*/	

+	extern  char  *sbrk(int  size)

+	{

+	   if  (brk_siz  +  size  >  _heep_size  ||  brk_siz  +  size  <  0)

+

+          return((char*)-1);

+	   brk_siz  +=  size;

+	   return(  (char*)_heep  +  brk_siz  -  size);

+	}

+

diff --git a/FreeRTOS/Source/portable/Softune/MB91460/port.c b/FreeRTOS/Source/portable/Softune/MB91460/port.c
new file mode 100644
index 0000000..830d1b4
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB91460/port.c
@@ -0,0 +1,360 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "mb91467d.h"

+

+/*-----------------------------------------------------------*/

+

+/* We require the address of the pxCurrentTCB variable, but don't want to know

+any details of its type. */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+ 

+#pragma asm

+#macro  SaveContext

+	 ORCCR #0x20								;Switch to user stack

+	 ST RP,@-R15								;Store RP

+	 STM0 (R7,R6,R5,R4,R3,R2,R1,R0)				;Store R7-R0

+	 STM1 (R14,R13,R12,R11,R10,R9,R8)			;Store R14-R8

+	 ST MDH, @-R15								;Store MDH

+	 ST MDL, @-R15								;Store MDL

+	 

+	 ANDCCR #0xDF								;Switch back to system stack

+	 LD @R15+,R0								;Store PC to R0 

+	 ORCCR #0x20								;Switch to user stack

+	 ST R0,@-R15								;Store PC to User stack

+	 

+	 ANDCCR #0xDF								;Switch back to system stack

+	 LD @R15+,R0								;Store PS to R0

+	 ORCCR #0x20								;Switch to user stack

+	 ST R0,@-R15								;Store PS to User stack

+	 

+	 LDI #_pxCurrentTCB, R0						;Get pxCurrentTCB address

+	 LD @R0, R0									;Get the pxCurrentTCB->pxTopOfStack address

+	 ST R15,@R0									;Store USP to pxCurrentTCB->pxTopOfStack

+	 

+	 ANDCCR #0xDF								;Switch back to system stack for the rest of tick ISR

+#endm

+

+#macro RestoreContext

+	 LDI #_pxCurrentTCB, R0						;Get pxCurrentTCB address

+	 LD @R0, R0									;Get the pxCurrentTCB->pxTopOfStack address

+	 ORCCR #0x20								;Switch to user stack

+	 LD @R0, R15								;Restore USP from pxCurrentTCB->pxTopOfStack

+

+	 LD @R15+,R0								;Store PS to R0

+	 ANDCCR #0xDF								;Switch to system stack

+	 ST R0,@-R15								;Store PS to system stack

+

+	 ORCCR #0x20								;Switch to user stack

+	 LD @R15+,R0								;Store PC to R0

+	 ANDCCR #0xDF								;Switch to system stack

+	 ST R0,@-R15								;Store PC to system stack

+

+	 ORCCR #0x20								;Switch back to retrieve the remaining context

+

+	 LD @R15+, MDL								;Restore MDL

+	 LD @R15+, MDH								;Restore MDH

+	 LDM1 (R14,R13,R12,R11,R10,R9,R8)			;Restore R14-R8

+	 LDM0 (R7,R6,R5,R4,R3,R2,R1,R0)				;Restore R7-R0

+	 LD @R15+, RP								;Restore RP

+	 

+	 ANDCCR #0xDF								;Switch back to system stack for the rest of tick ISR

+#endm

+#pragma endasm

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Perform hardware setup to enable ticks from timer 1,

+ */

+static void prvSetupTimerInterrupt( void );

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x11111111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x22222222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x33333333;

+	pxTopOfStack--;

+

+	/* This is a redundant push to the stack, it may be required if 

+	in some implementations of the compiler the parameter to the task 

+	is passed on to the stack rather than in R4 register. */

+	*pxTopOfStack = (portSTACK_TYPE)(pvParameters);

+	pxTopOfStack--;                  

+    

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000000;	/* RP */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00007777;	/* R7 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00006666;	/* R6 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00005555;	/* R5 */

+	pxTopOfStack--;

+	

+	/* In the current implementation of the compiler the first 

+	parameter to the task (or function) is passed via R4 parameter 

+	to the task, hence the pvParameters pointer is copied into the R4 

+	register. See compiler manual section 4.6.2 for more information. */

+	*pxTopOfStack = ( portSTACK_TYPE ) (pvParameters);	/* R4 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00003333;	/* R3 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00002222;	/* R2 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00001111;	/* R1 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00000001;	/* R0 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0000EEEE;	/* R14 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0000DDDD;	/* R13 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0000CCCC;	/* R12 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0000BBBB;	/* R11 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0000AAAA;	/* R10 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00009999;	/* R9 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x00008888;	/* R8 */

+	pxTopOfStack--;	

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x11110000;	/* MDH */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x22220000;	/* MDL */

+	pxTopOfStack--;

+

+	/* The start of the task code. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	 

+    /* PS - User Mode, USP, ILM=31, Interrupts enabled */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x001F0030;	/* PS */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick. */

+	prvSetupTimerInterrupt();

+

+	/* Restore the context of the first task that is going to run. */

+	#pragma asm

+		RestoreContext

+	#pragma endasm

+

+	/* Simulate a function call end as generated by the compiler.  We will now

+	jump to the start of the task the context of which we have just restored. */	

+	__asm(" reti ");

+

+	/* Should not get here. */

+	return pdFAIL;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented - unlikely to ever be required as there is nothing to

+	return to. */

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupTimerInterrupt( void )

+{

+/* The peripheral clock divided by 32 is used by the timer. */

+const unsigned short usReloadValue = ( unsigned short ) ( ( ( configPER_CLOCK_HZ / configTICK_RATE_HZ ) / 32UL ) - 1UL );

+

+	/* Setup RLT0 to generate a tick interrupt. */

+

+	TMCSR0_CNTE = 0;		/* Count Disable */

+    TMCSR0_CSL = 0x2;		/* CLKP/32 */

+    TMCSR0_MOD = 0;			/* Software trigger */

+    TMCSR0_RELD = 1;		/* Reload */

+    

+    TMCSR0_UF = 0;			/* Clear underflow flag */

+	TMRLR0 = usReloadValue;

+	TMCSR0_INTE = 1;		/* Interrupt Enable */

+	TMCSR0_CNTE = 1;		/* Count Enable */

+	TMCSR0_TRG = 1;			/* Trigger */

+	

+    PORTEN = 0x3;			/* Port Enable */

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_PREEMPTION == 1

+

+	/* 

+	 * Tick ISR for preemptive scheduler. The tick count is incremented 

+	 * after the context is saved. Then the context is switched if required,

+	 * and last the context of the task which is to be resumed is restored.

+	 */

+

+	#pragma asm

+

+	.global _ReloadTimer0_IRQHandler

+	_ReloadTimer0_IRQHandler:

+

+	ANDCCR #0xEF							;Disable Interrupts

+	SaveContext								;Save context

+	ORCCR #0x10								;Re-enable Interrupts

+

+	LDI #0xFFFB,R1

+	LDI #_tmcsr0, R0

+	AND R1,@R0								;Clear RLT0 interrupt flag

+

+	CALL32	 _vTaskIncrementTick,R12		;Increment Tick

+	CALL32	 _vTaskSwitchContext,R12		;Switch context if required

+

+	ANDCCR #0xEF							;Disable Interrupts

+	RestoreContext							;Restore context

+	ORCCR #0x10								;Re-enable Interrupts

+

+	RETI

+

+	#pragma endasm

+	

+#else

+	

+	/* 

+	 * Tick ISR for the cooperative scheduler.  All this does is increment the

+	 * tick count.  We don't need to switch context, this can only be done by

+	 * manual calls to taskYIELD();

+	 */

+	__interrupt void ReloadTimer0_IRQHandler( void )

+	{

+		/* Clear RLT0 interrupt flag */

+		TMCSR0_UF = 0; 

+		vTaskIncrementTick();

+	}

+

+#endif

+

+/*

+ * Manual context switch. We can use a __nosavereg attribute  as the context 

+ * would be saved by PortSAVE_CONTEXT().  The context is switched and then 

+ * the context of the new task is restored saved. 

+ */

+#pragma asm

+

+	.global _vPortYieldDelayed

+	_vPortYieldDelayed:

+

+	ANDCCR #0xEF							;Disable Interrupts

+	SaveContext								;Save context

+	ORCCR #0x10								;Re-enable Interrupts

+

+	LDI #_dicr, R0

+	BANDL #0x0E, @R0						;Clear Delayed interrupt flag

+

+	CALL32	 _vTaskSwitchContext,R12		;Switch context if required

+

+	ANDCCR #0xEF							;Disable Interrupts

+	RestoreContext							;Restore context

+	ORCCR #0x10								;Re-enable Interrupts

+

+	RETI

+

+#pragma endasm

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch. We can use a __nosavereg attribute  as the context 

+ * would be saved by PortSAVE_CONTEXT().  The context is switched and then 

+ * the context of the new task is restored saved. 

+ */ 	 

+#pragma asm

+

+	.global _vPortYield

+	_vPortYield:

+

+	SaveContext								;Save context

+	CALL32	 _vTaskSwitchContext,R12		;Switch context if required

+	RestoreContext							;Restore context

+	

+	RETI

+

+#pragma endasm

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/Softune/MB91460/portmacro.h b/FreeRTOS/Source/portable/Softune/MB91460/portmacro.h
new file mode 100644
index 0000000..0dffa3c
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB91460/portmacro.h
@@ -0,0 +1,143 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/* Hardware specific includes. */

+#include "mb91467d.h"

+

+/* Standard includes. */

+#include <stddef.h>

+

+/*-----------------------------------------------------------

+ * 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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Critical section management. */

+#if configKERNEL_INTERRUPT_PRIORITY != 30

+	#error configKERNEL_INTERRUPT_PRIORITY (set in FreeRTOSConfig.h) must match the ILM value set in the following line - 30 (1Eh) being the default.

+#endif

+#define portDISABLE_INTERRUPTS() __asm(" STILM #1Eh ")

+#define portENABLE_INTERRUPTS() __asm(" STILM #1Fh ")

+

+#define portENTER_CRITICAL()	\

+	__asm(" ST PS,@-R15 ");		\

+	__asm(" ANDCCR #0xef ");	\

+

+

+#define portEXIT_CRITICAL()		\

+	__asm(" LD @R15+,PS ");		\

+

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			4

+#define portNOP()					__asm( " nop " );

+/*-----------------------------------------------------------*/

+

+/* portYIELD() uses a SW interrupt */

+#define portYIELD()					__asm( " INT #40H " );

+

+/* portYIELD_FROM_ISR() uses delayed interrupt */

+#define portYIELD_FROM_ISR()			DICR_DLYI = 1

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portMINIMAL_STACK_SIZE configMINIMAL_STACK_SIZE

+

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Softune/MB96340/__STD_LIB_sbrk.c b/FreeRTOS/Source/portable/Softune/MB96340/__STD_LIB_sbrk.c
new file mode 100644
index 0000000..a520aff
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB96340/__STD_LIB_sbrk.c
@@ -0,0 +1,28 @@
+/* THIS SAMPLE CODE IS PROVIDED AS IS AND IS SUBJECT TO ALTERATIONS. FUJITSU */

+/* MICROELECTRONICS ACCEPTS NO RESPONSIBILITY OR LIABILITY FOR ANY ERRORS OR */

+/* ELIGIBILITY FOR ANY PURPOSES.                                             */

+/*                 (C) Fujitsu Microelectronics Europe GmbH                  */

+/*---------------------------------------------------------------------------

+  __STD_LIB_sbrk.C

+  - Used by heap_3.c for memory accocation and deletion.

+

+/*---------------------------------------------------------------------------*/

+

+#include "FreeRTOSConfig.h"

+#include <stdlib.h>

+

+	static  long         brk_siz  =  0;

+	typedef int          _heep_t;

+	#define ROUNDUP(s)   (((s)+sizeof(_heep_t)-1)&~(sizeof(_heep_t)-1))

+	static  _heep_t      _heep[ROUNDUP(configTOTAL_HEAP_SIZE)/sizeof(_heep_t)];

+	#define              _heep_size      ROUNDUP(configTOTAL_HEAP_SIZE)

+

+	extern  char  *sbrk(int  size)

+	{

+	   if  (brk_siz  +  size  >  _heep_size  ||  brk_siz  +  size  <  0)

+

+          return((char*)-1);

+	   brk_siz  +=  size;

+	   return(  (char*)_heep  +  brk_siz  -  size);

+	}

+

diff --git a/FreeRTOS/Source/portable/Softune/MB96340/port.c b/FreeRTOS/Source/portable/Softune/MB96340/port.c
new file mode 100644
index 0000000..ed0b248
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB96340/port.c
@@ -0,0 +1,546 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include "FreeRTOS.h"

+#include "task.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the 16FX port.

+ *----------------------------------------------------------*/

+

+/* 

+ * Get current value of DPR and ADB registers 

+ */

+portSTACK_TYPE xGet_DPR_ADB_bank( void ); 

+

+/* 

+ * Get current value of DTB and PCB registers 

+ */

+portSTACK_TYPE xGet_DTB_PCB_bank( void );

+

+/*

+ * Sets up the periodic ISR used for the RTOS tick.  This uses RLT0, but

+ * can be done using any given RLT.

+ */

+static void prvSetupRLT0Interrupt( void );

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * We require the address of the pxCurrentTCB variable, but don't want to know

+ * any details of its type. 

+ */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Macro to save a task context to the task stack. This macro  copies the 

+ * saved context (AH:AL, DPR:ADB, DTB:PCB , PC and PS) from  the   system 

+ * stack to task stack pointed by user stack pointer ( USP  for SMALL and 

+ * MEDIUM memory model amd USB:USP for COMPACT  and LARGE memory model ),

+ * then  it pushes the general purpose registers RW0-RW7  on  to the task 

+ * stack. Finally the  resultant  stack  pointer  value is saved into the 

+ * task  control  block  so  it  can  be retrieved the next time the task 

+ * executes.

+ */ 

+#if( ( configMEMMODEL == portSMALL ) || ( configMEMMODEL == portMEDIUM ) )

+

+	#define portSAVE_CONTEXT()											\

+			{	__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+	    		__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" PUSHW (RW0,RW1,RW2,RW3,RW4,RW5,RW6,RW7) ");		\

+				__asm(" MOVW A, _pxCurrentTCB ");						\

+				__asm(" MOVW A, SP ");									\

+  				__asm(" SWAPW ");										\

+				__asm(" MOVW @AL, AH ");								\

+				__asm(" OR   CCR,#H'20 ");								\

+			}

+

+/* 

+ * Macro to restore a task context from the task stack.  This is effecti-

+ * vely the reverse of SAVE_CONTEXT(). First the stack pointer  value

+ * (USP for SMALL and MEDIUM memory model amd  USB:USP  for  COMPACT  and 

+ * LARGE memory model ) is loaded from the task  control block.  Next the 

+ * value of all the general purpose registers RW0-RW7 is retrieved. Fina-

+ * lly it copies of the context ( AH:AL,  DPR:ADB, DTB:PCB, PC and PS) of 

+ * the task to be executed upon RETI from user stack to system stack.  

+ */

+ 

+	#define portRESTORE_CONTEXT()										\

+			{	__asm(" MOVW A, _pxCurrentTCB ");						\

+				__asm(" MOVW A, @A ");									\

+  				__asm(" AND  CCR,#H'DF ");  							\

+  				__asm(" MOVW SP, A ");									\

+				__asm(" POPW (RW0,RW1,RW2,RW3,RW4,RW5,RW6,RW7) ");		\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+			}

+		

+#elif( ( configMEMMODEL == portCOMPACT ) || ( configMEMMODEL == portLARGE ) )

+

+	#define portSAVE_CONTEXT()											\

+			{	__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+	    		__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" POPW  A ");										\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" PUSHW  A ");									\

+				__asm(" PUSHW (RW0,RW1,RW2,RW3,RW4,RW5,RW6,RW7) ");		\

+				__asm(" MOVL A, _pxCurrentTCB ");						\

+				__asm(" MOVL RL2, A ");									\

+				__asm(" MOVW A, SP ");									\

+				__asm(" MOVW @RL2+0, A ");								\

+				__asm(" MOV A, USB ");									\

+				__asm(" MOV @RL2+2, A ");								\

+			}	

+            

+	#define portRESTORE_CONTEXT()										\

+			{	__asm(" MOVL A, _pxCurrentTCB ");						\

+				__asm(" MOVL RL2, A ");									\

+				__asm(" MOVW A, @RL2+0 ");								\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" MOVW SP, A ");									\

+				__asm(" MOV A, @RL2+2 ");								\

+				__asm(" MOV USB, A ");									\

+				__asm(" POPW (RW0,RW1,RW2,RW3,RW4,RW5,RW6,RW7) ");		\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+				__asm(" AND  CCR,#H'DF ");  							\

+				__asm(" POPW  A ");										\

+				__asm(" OR   CCR,#H'20 ");								\

+				__asm(" PUSHW  A ");									\

+			}

+#endif

+

+/*-----------------------------------------------------------*/	

+

+/* 

+ * Functions for obtaining the current value  of  DPR:ADB, DTB:PCB bank registers

+ */

+ 

+#pragma asm

+

+        .GLOBAL    _xGet_DPR_ADB_bank

+        .GLOBAL    _xGet_DTB_PCB_bank

+        .SECTION   CODE, CODE, ALIGN=1

+

+_xGet_DPR_ADB_bank:

+

+    MOV A, DPR

+    SWAP

+    MOV A, ADB

+    ORW A

+	#if configMEMMODEL == portMEDIUM || configMEMMODEL == portLARGE

+		RETP

+	#elif configMEMMODEL == portSMALL || configMEMMODEL == portCOMPACT   

+		RET

+	#endif 

+

+

+_xGet_DTB_PCB_bank:

+

+    MOV A, DTB

+    SWAP

+    MOV A, PCB

+    ORW A

+	#if configMEMMODEL == portMEDIUM || configMEMMODEL == portLARGE

+		RETP

+	#elif configMEMMODEL == portSMALL || configMEMMODEL == portCOMPACT   

+		RET

+	#endif 

+

+#pragma endasm

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a task to look exactly as if a call to 

+ * portSAVE_CONTEXT had been called.

+ * 

+ * See the header file portable.h.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+	*pxTopOfStack = 0x1111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x2222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x3333;

+	pxTopOfStack--;

+

+	/* Once the task is called the task  would  push  the  pointer to the

+	parameter onto the stack. Hence here the pointer would be copied to the stack

+	first.  When using the COMPACT or LARGE memory model the pointer would be 24 

+	bits, and when using the SMALL or MEDIUM memory model the pointer would be 16 

+	bits. */ 

+	#if( ( configMEMMODEL == portCOMPACT ) || ( configMEMMODEL == portLARGE ) )

+	{

+		*pxTopOfStack = ( portSTACK_TYPE ) ( ( unsigned long ) ( pvParameters ) >> 16 );

+		pxTopOfStack--;         

+	}

+	#endif

+

+    *pxTopOfStack = ( portSTACK_TYPE ) ( pvParameters );

+    pxTopOfStack--;                  

+    

+    /* This is redundant push to the stack. This is required in order to introduce 

+    an offset so that the task accesses a parameter correctly that is passed on to 

+    the task stack. */

+	#if( ( configMEMMODEL == portMEDIUM ) || ( configMEMMODEL == portLARGE ) )

+	{

+		*pxTopOfStack = ( xGet_DTB_PCB_bank() & 0xff00 ) | ( ( ( long ) ( pxCode ) >> 16 ) & 0xff );      

+		pxTopOfStack--;       

+	}

+	#endif

+

+    /* This is redundant push to the stack. This is required in order to introduce 

+    an offset so the task correctly accesses the parameter passed on the task stack. */

+    *pxTopOfStack = ( portSTACK_TYPE ) ( pxCode );

+    pxTopOfStack--;       

+

+    /* PS - User Mode, ILM=7, RB=0, Interrupts enabled,USP */

+    *pxTopOfStack = 0xE0C0;							

+	pxTopOfStack--; 

+

+	/* PC */

+	*pxTopOfStack = ( portSTACK_TYPE ) ( pxCode );     

+    pxTopOfStack--;      

+    

+    /* DTB | PCB */

+	#if configMEMMODEL == portSMALL || configMEMMODEL == portCOMPACT

+	{

+		*pxTopOfStack = xGet_DTB_PCB_bank();         	

+		pxTopOfStack--;

+	}

+	#endif

+

+	/* DTB | PCB, in case of MEDIUM and LARGE memory models, PCB would be used

+	along with PC to indicate the start address of the function. */

+	#if( ( configMEMMODEL == portMEDIUM ) || ( configMEMMODEL == portLARGE ) )

+	{

+		*pxTopOfStack = ( xGet_DTB_PCB_bank() & 0xff00 ) | ( ( ( long ) ( pxCode ) >> 16 ) & 0xff );

+		pxTopOfStack--;       

+	}

+	#endif

+

+	/* DPR | ADB  */

+	*pxTopOfStack = xGet_DPR_ADB_bank();				

+	pxTopOfStack--;

+    

+	/* AL */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x9999;		

+	pxTopOfStack--;

+

+	/* AH */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xAAAA;		

+	pxTopOfStack--;

+	

+	/* Next the general purpose registers. */

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x7777;	/* RW7 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x6666;	/* RW6 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x5555;	/* RW5 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x4444;	/* RW4 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x3333;	/* RW3 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x2222;	/* RW2 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x1111;	/* RW1 */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x8888;	/* RW0 */

+		

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetupRLT0Interrupt( void )

+{

+/* The peripheral clock divided by 16 is used by the timer. */

+const unsigned short usReloadValue = ( unsigned short ) ( ( ( configCLKP1_CLOCK_HZ / configTICK_RATE_HZ ) / 16UL ) - 1UL );

+

+	/* set reload value = 34999+1, TICK Interrupt after 10 ms @ 56MHz of CLKP1 */

+	TMRLR0 = usReloadValue;    

+    

+    /* prescaler 1:16, reload, interrupt enable, count enable, trigger */

+    TMCSR0 = 0x041B;    

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* Setup the hardware to generate the tick. */

+	prvSetupRLT0Interrupt();

+	

+	/* Restore the context of the first task that is going to run. */

+	portRESTORE_CONTEXT();

+

+	/* Simulate a function call end as generated by the compiler.  We will now

+	jump to the start of the task the context of which we have just restored. */	

+	__asm(" reti ");

+

+

+	/* Should not get here. */

+	return pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Not implemented - unlikely to ever be required as there is nothing to

+	return to. */

+}

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * The interrupt service routine used depends on whether the pre-emptive

+ * scheduler is being used or not.

+ */

+

+#if configUSE_PREEMPTION == 1

+

+	/* 

+	 * Tick ISR for preemptive scheduler.  We can use a __nosavereg attribute

+	 * as the context is to be saved by the portSAVE_CONTEXT() macro, not the

+	 * compiler generated code.  The tick count is incremented after the context 

+	 * is saved. 

+	 */

+	__nosavereg __interrupt void prvRLT0_TICKISR( void )

+	{

+		/* Disable interrupts so that portSAVE_CONTEXT() is not interrupted */

+		__DI();

+		

+		/* Save the context of the interrupted task. */

+		portSAVE_CONTEXT();

+		

+		/* Enable interrupts */

+		__EI();

+		

+		/* Clear RLT0 interrupt flag */

+		TMCSR0_UF = 0;      

+		

+		/* Increment the tick count then switch to the highest priority task

+		that is ready to run. */

+		vTaskIncrementTick();

+		vTaskSwitchContext();

+

+		/* Disable interrupts so that portRESTORE_CONTEXT() is not interrupted */

+		__DI();

+		

+		/* Restore the context of the new task. */

+		portRESTORE_CONTEXT();

+		

+		/* Enable interrupts */

+		__EI();

+	}

+

+#else

+

+	/*

+	 * Tick ISR for the cooperative scheduler.  All this does is increment the

+	 * tick count.  We don't need to switch context, this can only be done by

+	 * manual calls to taskYIELD();

+	 */

+	__interrupt void prvRLT0_TICKISR( void )

+	{

+		/* Clear RLT0 interrupt flag */

+		TMCSR0_UF = 0;  

+		

+		vTaskIncrementTick();

+	}

+

+#endif

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch. We can use a __nosavereg attribute  as the context 

+ * is to be saved by the portSAVE_CONTEXT() macro, not the compiler generated 

+ * code.

+ */

+__nosavereg __interrupt void vPortYield( void )

+{

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT();

+	

+	/* Switch to the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+	

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+__nosavereg __interrupt void vPortYieldDelayed( void )

+{    

+    /* Disable interrupts so that portSAVE_CONTEXT() is not interrupted */      

+	__DI();

+	

+	/* Save the context of the interrupted task. */

+	portSAVE_CONTEXT();

+	

+	/* Enable interrupts */

+	__EI();

+				

+	/* Clear delayed interrupt flag */

+    __asm (" CLRB  03A4H:0 ");

+	

+	/* Switch to the highest priority task that is ready to run. */

+	vTaskSwitchContext();

+	

+	/* Disable interrupts so that portSAVE_CONTEXT() is not interrupted */   

+	__DI();

+	

+	/* Restore the context of the new task. */

+	portRESTORE_CONTEXT();

+

+	/* Enable interrupts */

+	__EI();

+}	

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/Softune/MB96340/portmacro.h b/FreeRTOS/Source/portable/Softune/MB96340/portmacro.h
new file mode 100644
index 0000000..a5f9e4a
--- /dev/null
+++ b/FreeRTOS/Source/portable/Softune/MB96340/portmacro.h
@@ -0,0 +1,150 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+/* Standard includes. */

+#include <stddef.h>

+

+/* Constants denoting the available memory models.  These are used within

+FreeRTOSConfig.h to set the configMEMMODEL value. */

+#define portSMALL     0

+#define portMEDIUM    1

+#define portCOMPACT   2

+#define portLARGE     3

+

+

+/*-----------------------------------------------------------

+ * 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	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Critical section handling. */

+#if configKERNEL_INTERRUPT_PRIORITY != 6

+	#error configKERNEL_INTERRUPT_PRIORITY (set in FreeRTOSConfig.h) must match the ILM value set in the following line - #06H being the default.

+#endif

+#define portDISABLE_INTERRUPTS()	__asm(" MOV ILM, #06h ")

+#define portENABLE_INTERRUPTS()		__asm(" MOV ILM, #07h ")

+

+#define portENTER_CRITICAL()								\

+		{	__asm(" PUSHW PS ");							\

+			portDISABLE_INTERRUPTS();						\

+		}

+

+#define portEXIT_CRITICAL()									\

+		{	__asm(" POPW PS ");								\

+		}

+

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			2

+#define portNOP()					__asm( " NOP " );

+/*-----------------------------------------------------------*/

+

+/* portYIELD() uses SW interrupt */

+#define portYIELD()					__asm( " INT #122 " );

+

+/* portYIELD_FROM_ISR() uses delayed interrupt */

+#define portYIELD_FROM_ISR()		 __asm( " SETB  03A4H:0 " );

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portMINIMAL_STACK_SIZE configMINIMAL_STACK_SIZE

+

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port.c b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port.c
new file mode 100644
index 0000000..7f0bf5c
--- /dev/null
+++ b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port.c
@@ -0,0 +1,251 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the ARM CM4F port.

+ *----------------------------------------------------------*/

+

+/* Scheduler includes. */

+#include "FreeRTOS.h"

+#include "task.h"

+

+/* Constants required to manipulate the NVIC. */

+#define portNVIC_SYSTICK_CTRL		( ( volatile unsigned long * ) 0xe000e010 )

+#define portNVIC_SYSTICK_LOAD		( ( volatile unsigned long * ) 0xe000e014 )

+#define portNVIC_INT_CTRL			( ( volatile unsigned long * ) 0xe000ed04 )

+#define portNVIC_SYSPRI2			( ( volatile unsigned long * ) 0xe000ed20 )

+#define portNVIC_SYSTICK_CLK		0x00000004

+#define portNVIC_SYSTICK_INT		0x00000002

+#define portNVIC_SYSTICK_ENABLE		0x00000001

+#define portNVIC_PENDSVSET			0x10000000

+#define portNVIC_PENDSV_PRI			( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 16 )

+#define portNVIC_SYSTICK_PRI		( ( ( unsigned long ) configKERNEL_INTERRUPT_PRIORITY ) << 24 )

+

+/* Constants required to manipulate the VFP. */

+#define portFPCCR					( ( volatile unsigned long * ) 0xe000ef34 ) /* Floating point context control register. */

+#define portASPEN_AND_LSPEN_BITS	( 0x3UL << 30UL )

+

+/* Constants required to set up the initial stack. */

+#define portINITIAL_XPSR			( 0x01000000 )

+#define portINITIAL_EXEC_RETURN		( 0xfffffffd )

+

+/* The priority used by the kernel is assigned to a variable to make access

+from inline assembler easier. */

+const unsigned long ulKernelPriority = configKERNEL_INTERRUPT_PRIORITY;

+

+/* Each task maintains its own interrupt status in the critical nesting

+variable. */

+static unsigned long ulCriticalNesting = 0xaaaaaaaaUL;

+

+/*

+ * Setup the timer to generate the tick interrupts.

+ */

+static void prvSetupTimerInterrupt( void );

+

+/*

+ * Exception handlers.

+ */

+void SysTick_Handler( void );

+

+/*

+ * Functions defined in port_asm.asm.

+ */

+extern void vPortEnableVFP( void );

+extern void vPortStartFirstTask( void );

+

+/* This exists purely to allow the const to be used from within the

+port_asm.asm assembly file. */

+const unsigned long ulMaxSyscallInterruptPriorityConst = configMAX_SYSCALL_INTERRUPT_PRIORITY;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+	/* Simulate the stack frame as it would be created by a context switch

+	interrupt. */

+

+	/* Offset added to account for the way the MCU uses the stack on entry/exit

+	of interrupts, and to ensure alignment. */

+	pxTopOfStack--;

+

+	*pxTopOfStack = portINITIAL_XPSR;	/* xPSR */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) pxCode;	/* PC */

+	pxTopOfStack--;

+	*pxTopOfStack = 0;	/* LR */

+

+	/* Save code space by skipping register initialisation. */

+	pxTopOfStack -= 5;	/* R12, R3, R2 and R1. */

+	*pxTopOfStack = ( portSTACK_TYPE ) pvParameters;	/* R0 */

+

+	/* A save method is being used that requires each task to maintain its

+	own exec return value. */

+	pxTopOfStack--;

+	*pxTopOfStack = portINITIAL_EXEC_RETURN;

+

+	pxTopOfStack -= 8;	/* R11, R10, R9, R8, R7, R6, R5 and R4. */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * See header file for description.

+ */

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to 0.

+	See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html */

+	configASSERT( ( configMAX_SYSCALL_INTERRUPT_PRIORITY ) );

+

+	/* Make PendSV and SysTick the lowest priority interrupts. */

+	*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

+	*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;

+

+	/* Start the timer that generates the tick ISR.  Interrupts are disabled

+	here already. */

+	prvSetupTimerInterrupt();

+

+	/* Initialise the critical nesting count ready for the first task. */

+	ulCriticalNesting = 0;

+

+	/* Ensure the VFP is enabled - it should be anyway. */

+	vPortEnableVFP();

+

+	/* Lazy save always. */

+	*( portFPCCR ) |= portASPEN_AND_LSPEN_BITS;

+

+	/* Start the first task. */

+	vPortStartFirstTask();

+

+	/* Should not get here! */

+	return 0;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* It is unlikely that the CM4F port will require this function as there

+	is nothing to return to.  */

+}

+/*-----------------------------------------------------------*/

+

+void vPortYieldFromISR( void )

+{

+	/* Set a PendSV to request a context switch. */

+	*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+}

+/*-----------------------------------------------------------*/

+

+void vPortEnterCritical( void )

+{

+	portDISABLE_INTERRUPTS();

+	ulCriticalNesting++;

+}

+/*-----------------------------------------------------------*/

+

+void vPortExitCritical( void )

+{

+	ulCriticalNesting--;

+	if( ulCriticalNesting == 0 )

+	{

+		portENABLE_INTERRUPTS();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void SysTick_Handler( void )

+{

+unsigned long ulDummy;

+

+	/* If using preemption, also force a context switch. */

+	#if configUSE_PREEMPTION == 1

+		*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;

+	#endif

+

+	ulDummy = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		vTaskIncrementTick();

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( ulDummy );

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup the systick timer to generate the tick interrupts at the required

+ * frequency.

+ */

+void prvSetupTimerInterrupt( void )

+{

+	/* Configure SysTick to interrupt at the requested rate. */

+	*(portNVIC_SYSTICK_LOAD) = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;

+	*(portNVIC_SYSTICK_CTRL) = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;

+}

+/*-----------------------------------------------------------*/

+

diff --git a/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port_asm.asm b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port_asm.asm
new file mode 100644
index 0000000..ff7365c
--- /dev/null
+++ b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/port_asm.asm
@@ -0,0 +1,168 @@
+;/*

+;    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+;

+;

+;    ***************************************************************************

+;     *                                                                       *

+;     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+;     *    Complete, revised, and edited pdf reference manuals are also       *

+;     *    available.                                                         *

+;     *                                                                       *

+;     *    Purchasing FreeRTOS documentation will not only help you, by       *

+;     *    ensuring you get running as quickly as possible and with an        *

+;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+;     *    the FreeRTOS project to continue with its mission of providing     *

+;     *    professional grade, cross platform, de facto standard solutions    *

+;     *    for microcontrollers - completely free of charge!                  *

+;     *                                                                       *

+;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+;     *                                                                       *

+;     *    Thank you for using FreeRTOS, and thank you for your support!      *

+;     *                                                                       *

+;    ***************************************************************************

+;

+;

+;    This file is part of the FreeRTOS distribution.

+;

+;    FreeRTOS is free software; you can redistribute it and/or modify it under

+;    the terms of the GNU General Public License (version 2) as published by the

+;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+;    >>>NOTE<<< The modification to the GPL is included to allow you to

+;    distribute a combined work that includes FreeRTOS without being obliged to

+;    provide the source code for proprietary components outside of the FreeRTOS

+;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+;    more details. You should have received a copy of the GNU General Public

+;    License and the FreeRTOS license exception along with FreeRTOS; if not it

+;    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+;    by writing to Richard Barry, contact details for whom are available on the

+;    FreeRTOS WEB site.

+;

+;    1 tab == 4 spaces!

+;

+;    http://www.FreeRTOS.org - Documentation, latest information, license and

+;    contact details.

+;

+;    http://www.SafeRTOS.com - A version that is certified for use in safety

+;    critical systems.

+;

+;    http://www.OpenRTOS.com - Commercial support, development, porting,

+;    licensing and training services.

+;*/

+

+	.extern pxCurrentTCB

+	.extern vTaskSwitchContext

+	.extern ulMaxSyscallInterruptPriorityConst

+

+	.global PendSV_Handler

+	.global SVC_Handler

+	.global vPortStartFirstTask

+	.global vPortEnableVFP

+	

+;-----------------------------------------------------------

+

+	.section .text

+	.thumb

+	.align 4

+PendSV_Handler: .type func

+	mrs r0, psp

+

+	;Get the location of the current TCB.

+	ldr.w	r3, =pxCurrentTCB

+	ldr	r2, [r3]

+

+	;Is the task using the FPU context?  If so, push high vfp registers.

+	tst r14, #0x10

+	it eq

+	vstmdbeq r0!, {s16-s31}

+

+	;Save the core registers.

+	stmdb r0!, {r4-r11, r14}

+

+	;Save the new top of stack into the first member of the TCB.

+	str r0, [r2]

+

+	stmdb sp!, {r3, r14}

+	ldr.w r0, =ulMaxSyscallInterruptPriorityConst

+	msr basepri, r0

+	bl vTaskSwitchContext

+	mov r0, #0

+	msr basepri, r0

+	ldmia sp!, {r3, r14}

+

+	;The first item in pxCurrentTCB is the task top of stack.

+	ldr r1, [r3]

+	ldr r0, [r1]

+

+	;Pop the core registers.

+	ldmia r0!, {r4-r11, r14}

+

+	;Is the task using the FPU context?  If so, pop the high vfp registers too.

+	tst r14, #0x10

+	it eq

+	vldmiaeq r0!, {s16-s31}

+

+	msr psp, r0

+	bx r14

+

+	.size	PendSV_Handler, $-PendSV_Handler

+	.endsec

+

+;-----------------------------------------------------------

+

+	.section .text

+	.thumb

+	.align 4

+SVC_Handler: .type func

+	;Get the location of the current TCB.

+	ldr.w	r3, =pxCurrentTCB

+	ldr r1, [r3]

+	ldr r0, [r1]

+	;Pop the core registers.

+	ldmia r0!, {r4-r11, r14}

+	msr psp, r0

+	mov r0, #0

+	msr	basepri, r0

+	bx r14

+	.size	SVC_Handler, $-SVC_Handler

+	.endsec

+

+;-----------------------------------------------------------

+

+	.section .text

+	.thumb

+	.align 4

+vPortStartFirstTask .type func

+	;Use the NVIC offset register to locate the stack.

+	ldr.w r0, =0xE000ED08

+	ldr r0, [r0]

+	ldr r0, [r0]

+	;Set the msp back to the start of the stack.

+	msr msp, r0

+	;Call SVC to start the first task.

+	cpsie i

+	svc 0

+	.size	vPortStartFirstTask, $-vPortStartFirstTask

+	.endsec

+

+;-----------------------------------------------------------

+

+	.section .text

+	.thumb

+	.align 4

+vPortEnableVFP .type func

+	;The FPU enable bits are in the CPACR.

+	ldr.w r0, =0xE000ED88

+	ldr	r1, [r0]

+

+	;Enable CP10 and CP11 coprocessors, then save back.

+	orr	r1, r1, #( 0xf << 20 )

+	str r1, [r0]

+	bx	r14

+	.size	vPortEnableVFP, $-vPortEnableVFP

+	.endsec

+

+

+	.end

+	

diff --git a/FreeRTOS/Source/portable/Tasking/ARM_CM4F/portmacro.h b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/portmacro.h
new file mode 100644
index 0000000..ea1e878
--- /dev/null
+++ b/FreeRTOS/Source/portable/Tasking/ARM_CM4F/portmacro.h
@@ -0,0 +1,165 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#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	unsigned portLONG

+#define portBASE_TYPE	long

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/	

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH			( -1 )

+#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+#define portBYTE_ALIGNMENT			8

+/*-----------------------------------------------------------*/	

+

+

+/* Scheduler utilities. */

+extern void vPortYieldFromISR( void );

+

+#define portYIELD()					vPortYieldFromISR()

+

+#define portEND_SWITCHING_ISR( xSwitchRequired ) if( xSwitchRequired ) vPortYieldFromISR()

+/*-----------------------------------------------------------*/

+

+

+/* Critical section management. */

+

+/* 

+ * Set basepri to portMAX_SYSCALL_INTERRUPT_PRIORITY without effecting other

+ * registers.  r0 is clobbered.

+ */ 

+#define portSET_INTERRUPT_MASK() __set_BASEPRI( configMAX_SYSCALL_INTERRUPT_PRIORITY )

+	

+/*

+ * Set basepri back to 0 without effective other registers.

+ * r0 is clobbered.  FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+ * http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing.

+ */

+#define portCLEAR_INTERRUPT_MASK() __set_BASEPRI( 0 )

+

+/* FAQ:  Setting BASEPRI to 0 is not a bug.  Please see 

+http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html before disagreeing. */

+#define portSET_INTERRUPT_MASK_FROM_ISR()		0;portSET_INTERRUPT_MASK()

+#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x)	portCLEAR_INTERRUPT_MASK();(void)x

+

+

+extern void vPortEnterCritical( void );

+extern void vPortExitCritical( void );

+

+#define portDISABLE_INTERRUPTS()	portSET_INTERRUPT_MASK()

+#define portENABLE_INTERRUPTS()		portCLEAR_INTERRUPT_MASK()

+#define portENTER_CRITICAL()		vPortEnterCritical()

+#define portEXIT_CRITICAL()			vPortExitCritical()

+

+/* There are an uneven number of items on the initial stack, so 

+portALIGNMENT_ASSERT_pxCurrentTCB() will trigger false positive asserts. */

+#define portALIGNMENT_ASSERT_pxCurrentTCB ( void )

+

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#define portNOP()

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/Tick.c b/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/Tick.c
new file mode 100644
index 0000000..cb84570
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/Tick.c
@@ -0,0 +1,177 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* 

+Changes from V3.0.0

+	+ ISRcode is pulled inline and portTICKisr() is therefore

+	  deleted from this file.

+

+	+ Prescaler logic for Timer1 added to allow for a wider

+	  range of TickRates.

+

+Changes from V3.0.1

+*/

+

+#include <FreeRTOS.h>

+#include <task.h>

+

+/* IO port constants. */

+#define portBIT_SET		(1)

+#define portBIT_CLEAR	(0)

+

+/* 

+ * Hardware setup for the tick.

+ * We use a compare match on timer1. Depending on MPU-frequency

+ * and requested tickrate, a prescaled value with a matching

+ * prescaler are determined.

+ */

+#define	portTIMER_COMPARE_BASE			((APROCFREQ/4)/configTICK_RATE_HZ)

+

+#if portTIMER_COMPARE_BASE   < 0x10000

+	#define	portTIMER_COMPARE_VALUE		(portTIMER_COMPARE_BASE)

+	#define portTIMER_COMPARE_PS1		(portBIT_CLEAR)

+	#define portTIMER_COMPARE_PS0		(portBIT_CLEAR)

+#elif portTIMER_COMPARE_BASE < 0x20000

+	#define	portTIMER_COMPARE_VALUE		(portTIMER_COMPARE_BASE / 2)

+	#define portTIMER_COMPARE_PS1		(portBIT_CLEAR)

+	#define portTIMER_COMPARE_PS0		(portBIT_SET)

+#elif portTIMER_COMPARE_BASE < 0x40000

+	#define	portTIMER_COMPARE_VALUE		(portTIMER_COMPARE_BASE / 4)

+	#define portTIMER_COMPARE_PS1		(portBIT_SET)

+	#define portTIMER_COMPARE_PS0		(portBIT_CLEAR)

+#elif portTIMER_COMPARE_BASE < 0x80000

+	#define	portTIMER_COMPARE_VALUE		(portTIMER_COMPARE_BASE / 8)

+	#define portTIMER_COMPARE_PS1		(portBIT_SET)

+	#define portTIMER_COMPARE_PS0		(portBIT_SET)

+#else

+	#error "TickRate out of range"

+#endif

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Setup a timer for a regular tick.

+ */

+void portSetupTick( void )

+{

+	/*

+	 * Interrupts are disabled when this function is called.

+	 */

+

+	/*

+	 * Setup CCP1

+	 * Provide the tick interrupt using a compare match on timer1.

+	 */

+

+	/*

+	 * Set the compare match value.

+	 */

+	CCPR1H = ( unsigned char ) ( ( portTIMER_COMPARE_VALUE >> 8 ) & 0xff );

+	CCPR1L = ( unsigned char )   ( portTIMER_COMPARE_VALUE & 0xff );

+

+	/*

+	 * Set Compare Special Event Trigger Mode

+	 */

+	bCCP1M3 	= portBIT_SET;

+	bCCP1M2 	= portBIT_CLEAR;

+	bCCP1M1 	= portBIT_SET;

+	bCCP1M0		= portBIT_SET;

+

+	/*

+	 * Enable CCP1 interrupt

+	 */

+	bCCP1IE 	= portBIT_SET;

+

+	/*

+	 * We are only going to use the global interrupt bit, so disable

+	 * interruptpriorities and enable peripheral interrupts.

+	 */

+	bIPEN		= portBIT_CLEAR;

+	bPEIE		= portBIT_SET;

+

+	/*

+	 * Set up timer1

+	 * It will produce the system tick.

+	 */

+

+	/*

+	 * Clear the time count

+	 */

+	TMR1H = ( unsigned char ) 0x00;

+	TMR1L = ( unsigned char ) 0x00;

+

+	/*

+	 * Setup the timer

+	 */

+	bRD16		= portBIT_SET;				// 16-bit

+	bT1CKPS1	= portTIMER_COMPARE_PS1;	// prescaler

+	bT1CKPS0	= portTIMER_COMPARE_PS0;	// prescaler

+	bT1OSCEN	= portBIT_SET;				// Oscillator enable

+	bT1SYNC		= portBIT_SET;				// No external clock sync

+	bTMR1CS		= portBIT_CLEAR;			// Internal clock

+	

+	bTMR1ON		= portBIT_SET;				// Start timer1

+}

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/isrTick.c b/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/isrTick.c
new file mode 100644
index 0000000..75871df
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/Drivers/Tick/isrTick.c
@@ -0,0 +1,120 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* 

+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

+*/

+

+/*

+ * ISR for the tick.

+ * This increments the tick count and, if using the preemptive scheduler, 

+ * performs a context switch.  This must be identical to the manual 

+ * context switch in how it stores the context of a task. 

+ */

+

+#ifndef _FREERTOS_DRIVERS_TICK_ISRTICK_C

+#define _FREERTOS_DRIVERS_TICK_ISRTICK_C

+

+{

+	/*

+	 * Was the interrupt the SystemClock?

+	 */

+	if( bCCP1IF && bCCP1IE )

+	{

+		/*

+		 * Reset the interrupt flag

+		 */

+		bCCP1IF = 0;

+	

+		/*

+	 	 * Maintain the tick count.

+	 	 */

+		vTaskIncrementTick();

+		

+		#if configUSE_PREEMPTION == 1

+		{

+			/*

+		 	 * Ask for a switch to the highest priority task

+		 	 * that is ready to run.

+		 	 */

+			uxSwitchRequested = pdTRUE;

+		}

+		#endif

+	}

+}

+

+#pragma wizcpp uselib     "$__PATHNAME__/Tick.c"

+

+#endif	/* _FREERTOS_DRIVERS_TICK_ISRTICK_C */

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/Install.bat b/FreeRTOS/Source/portable/WizC/PIC18/Install.bat
new file mode 100644
index 0000000..455b77f
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/Install.bat
@@ -0,0 +1,225 @@
+REM/*

+REM    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+REM

+REM

+REM    ***************************************************************************

+REM     *                                                                       *

+REM     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+REM     *    Complete, revised, and edited pdf reference manuals are also       *

+REM     *    available.                                                         *

+REM     *                                                                       *

+REM     *    Purchasing FreeRTOS documentation will not only help you, by       *

+REM     *    ensuring you get running as quickly as possible and with an        *

+REM     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+REM     *    the FreeRTOS project to continue with its mission of providing     *

+REM     *    professional grade, cross platform, de facto standard solutions    *

+REM     *    for microcontrollers - completely free of charge!                  *

+REM     *                                                                       *

+REM     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+REM     *                                                                       *

+REM     *    Thank you for using FreeRTOS, and thank you for your support!      *

+REM     *                                                                       *

+REM    ***************************************************************************

+REM

+REM

+REM    This file is part of the FreeRTOS distribution.

+REM

+REM    FreeRTOS is free softwareREM you can redistribute it and/or modify it under

+REM    the terms of the GNU General Public License (version 2) as published by the

+REM    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+REM    >>>NOTE<<< The modification to the GPL is included to allow you to

+REM    distribute a combined work that includes FreeRTOS without being obliged to

+REM    provide the source code for proprietary components outside of the FreeRTOS

+REM    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+REM    WITHOUT ANY WARRANTYREM without even the implied warranty of MERCHANTABILITY

+REM    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+REM    more details. You should have received a copy of the GNU General Public

+REM    License and the FreeRTOS license exception along with FreeRTOSREM if not it

+REM    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+REM    by writing to Richard Barry, contact details for whom are available on the

+REM    FreeRTOS WEB site.

+REM

+REM    1 tab == 4 spaces!

+REM

+REM    http://www.FreeRTOS.org - Documentation, latest information, license and

+REM    contact details.

+REM

+REM    http://www.SafeRTOS.com - A version that is certified for use in safety

+REM    critical systems.

+REM

+REM    http://www.OpenRTOS.com - Commercial support, development, porting,

+REM    licensing and training services.

+REM*/

+

+

+@echo off

+cls

+

+SET PACKAGENAME=the FreeRTOS port for fedC and wizC

+

+echo.

+echo Hello, I'm the installationscript for %PACKAGENAME%.

+echo.

+

+:CHECKFEDC

+  set FED=C:\Program Files\FED\PIC_C

+  echo.

+  echo I'm checking your system for fedC

+  if not exist "%FED%" goto NOFEDC

+  echo YES, I found a fedC-installation!

+  goto FOUNDFED

+:NOFEDC

+  echo I could not find a fedC-installation.

+

+

+:CHECKWIZC

+  set FED=C:\Program Files\FED\PIXIE

+  echo.

+  echo I'm checking your system for wizC

+  if not exist "%FED%" goto NOWIZC

+  echo YES, I found a wizC-installation!

+  goto FOUNDFED

+:noWIZC

+  echo I could not find a wizC-installation.

+

+

+:ERROR

+  echo.

+  echo.

+  echo I could not find a FED C-compiler installation on your system.

+  echo.

+  echo Perhaps I got confused because you installed fedC or wizC in a non-default directory.

+  echo If this is the case, please change the path at the top of this install-script.

+  echo After that rerun the script and I will be happy to try again.

+  echo.

+  goto ENDIT

+

+

+:FOUNDFED

+  echo.

+  echo.

+

+  set FEDLIBS=%FED%\Libs

+  set FEDLIBSUSER=%FEDLIBS%\LibsUser

+

+  if exist "%FEDLIBS%" goto INSTALL

+  echo The FED installationdirectory "%FED%"

+  echo contains no Libs subdirectory. This is weird!

+  echo.

+  echo Installation is aborted, sorry...

+  goto ENDIT

+

+

+:INSTALL

+  echo I am about to install %PACKAGENAME%

+  echo into directory %FEDLIBSUSER%

+  echo.

+  echo   Press 'enter'  to let me do my thing

+  echo   Press 'ctrl-c' to stop me

+  pause >nul

+  echo.

+  echo Installing...

+

+

+:RESET_READONLY

+  echo.

+  echo   Removing ReadOnly attributes

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Modules\Croutine.c"     >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Modules\Port.c"         >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Modules\List.c"         >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Modules\Queue.c"        >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Modules\Tasks.c"        >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\Tick.c"    >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\isrTick.c" >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Portmacro.h"    >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Croutine.h"     >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\List.h"         >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Portable.h"     >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Projdefs.h"     >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Queue.h"        >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Semphr.h"       >nul

+  attrib -R "%FEDLIBSUSER%\libFreeRTOS\Include\Task.h"         >nul

+  attrib -R "%FEDLIBSUSER%\FreeRTOS.h"                         >nul

+  echo   Done

+

+:CREATE_DIRECTORIES

+  echo.

+  echo   Creating directories (if necessary)...

+  if not exist "%FEDLIBSUSER%"                          mkdir "%FEDLIBSUSER%"

+  if not exist "%FEDLIBSUSER%\libFreeRTOS"              mkdir "%FEDLIBSUSER%\libFreeRTOS"

+  if not exist "%FEDLIBSUSER%\libFreeRTOS\Drivers"      mkdir "%FEDLIBSUSER%\libFreeRTOS\Drivers"

+  if not exist "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick" mkdir "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick"

+  if not exist "%FEDLIBSUSER%\libFreeRTOS\Include"      mkdir "%FEDLIBSUSER%\libFreeRTOS\Include"

+  if not exist "%FEDLIBSUSER%\libFreeRTOS\Modules"      mkdir "%FEDLIBSUSER%\libFreeRTOS\Modules"

+  echo   Done

+

+

+  echo.

+  echo   Copying Files...

+:COPY_MODULES

+  echo     Modules...

+  copy /V /Y "Port.c"                      "%FEDLIBSUSER%\libFreeRTOS\Modules\Port.c"         >nul

+  copy /V /Y "..\..\..\Croutine.c"         "%FEDLIBSUSER%\libFreeRTOS\Modules\Croutine.c"     >nul

+  copy /V /Y "..\..\..\List.c"             "%FEDLIBSUSER%\libFreeRTOS\Modules\List.c"         >nul

+  copy /V /Y "..\..\..\Queue.c"            "%FEDLIBSUSER%\libFreeRTOS\Modules\Queue.c"        >nul

+  copy /V /Y "..\..\..\Tasks.c"            "%FEDLIBSUSER%\libFreeRTOS\Modules\Tasks.c"        >nul

+

+:COPY_DRIVERS

+  echo     Drivers...

+  copy /V /Y "Drivers\Tick\Tick.c"         "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\Tick.c"    >nul

+  copy /V /Y "Drivers\Tick\isrTick.c"      "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\isrTick.c" >nul

+

+:COPY_HEADERS

+  echo     Headers...

+  copy /V /Y "portmacro.h"                 "%FEDLIBSUSER%\libFreeRTOS\Include\Portmacro.h"    >nul

+  copy /V /Y "..\..\..\include\Croutine.h" "%FEDLIBSUSER%\libFreeRTOS\Include\Croutine.h"     >nul

+  copy /V /Y "..\..\..\include\List.h"     "%FEDLIBSUSER%\libFreeRTOS\Include\List.h"         >nul

+  copy /V /Y "..\..\..\include\Portable.h" "%FEDLIBSUSER%\libFreeRTOS\Include\Portable.h"     >nul

+  copy /V /Y "..\..\..\include\Projdefs.h" "%FEDLIBSUSER%\libFreeRTOS\Include\Projdefs.h"     >nul

+  copy /V /Y "..\..\..\include\Queue.h"    "%FEDLIBSUSER%\libFreeRTOS\Include\Queue.h"        >nul

+  copy /V /Y "..\..\..\include\Semphr.h"   "%FEDLIBSUSER%\libFreeRTOS\Include\Semphr.h"       >nul

+  copy /V /Y "..\..\..\include\Task.h"     "%FEDLIBSUSER%\libFreeRTOS\Include\Task.h"         >nul

+  copy /V /Y "addFreeRTOS.h" + "..\..\..\include\FreeRTOS.h" "%FEDLIBSUSER%\FreeRTOS.h"       >nul

+

+

+  echo   Done

+

+

+:SET_READONLY

+  echo.

+  echo   Setting files to ReadOnly

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Modules\Port.c"         >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Modules\Croutine.c"     >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Modules\List.c"         >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Modules\Queue.c"        >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Modules\Tasks.c"        >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\Tick.c"    >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Drivers\Tick\isrTick.c" >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Portmacro.h"    >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Croutine.h"     >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\List.h"         >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Portable.h"     >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Projdefs.h"     >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Queue.h"        >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Semphr.h"       >nul

+  attrib +R "%FEDLIBSUSER%\libFreeRTOS\Include\Task.h"         >nul

+  attrib +R "%FEDLIBSUSER%\FreeRTOS.h"                         >nul

+  echo   Done

+

+

+:FINISHED

+  echo.

+  echo The installation of %PACKAGENAME% is completed.

+  echo.

+  echo Please review the installation instructions as additional libraries

+  echo  and fedC/wizC configuration settings may be needed for FreeRTOS

+  echo  to function correctly.

+

+  goto ENDIT

+

+

+:ENDIT

+  echo.

+  echo.

+  echo Press 'enter' to close this window

+  pause >nul

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/addFreeRTOS.h b/FreeRTOS/Source/portable/WizC/PIC18/addFreeRTOS.h
new file mode 100644
index 0000000..fc4f4c9
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/addFreeRTOS.h
@@ -0,0 +1,92 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V3.0.0

+

+Changes from V3.0.1

+

+Changes from V4.0.1

+    Uselib pragma added for Croutine.c

+*/

+

+/*

+ * The installation script will automatically prepend this file to the default FreeRTOS.h.

+ */

+

+#ifndef WIZC_FREERTOS_H

+#define WIZC_FREERTOS_H

+

+#pragma	noheap

+#pragma wizcpp expandnl   on

+#pragma wizcpp searchpath "$__PATHNAME__/libFreeRTOS/Include/"

+#pragma wizcpp uselib     "$__PATHNAME__/libFreeRTOS/Modules/Croutine.c"

+#pragma wizcpp uselib     "$__PATHNAME__/libFreeRTOS/Modules/Tasks.c"

+#pragma wizcpp uselib     "$__PATHNAME__/libFreeRTOS/Modules/Queue.c"

+#pragma wizcpp uselib     "$__PATHNAME__/libFreeRTOS/Modules/List.c"

+#pragma wizcpp uselib     "$__PATHNAME__/libFreeRTOS/Modules/Port.c"

+

+#endif	/* WIZC_FREERTOS_H */

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/port.c b/FreeRTOS/Source/portable/WizC/PIC18/port.c
new file mode 100644
index 0000000..187f262
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/port.c
@@ -0,0 +1,347 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V3.2.1

+	+ CallReturn Depth increased from 8 to 10 levels to accomodate wizC/fedC V12.

+	

+Changes from V3.2.0

+	+ TBLPTRU is now initialised to zero during the initial stack creation of a new task. This solves

+	an error on devices with more than 64kB ROM.

+

+Changes from V3.0.0

+	+ ucCriticalNesting is now initialised to 0x7F to prevent interrupts from being

+          handled before the scheduler is started.

+

+Changes from V3.0.1

+*/

+

+/* Scheduler include files. */

+#include <FreeRTOS.h>

+#include <task.h>

+

+#include <malloc.h>

+

+/*---------------------------------------------------------------------------

+ * Implementation of functions defined in portable.h for the WizC PIC18 port.

+ *---------------------------------------------------------------------------*/

+

+/*

+ * We require the address of the pxCurrentTCB variable, but don't want to

+ * know any details of its type.

+ */

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+

+/*

+ * Define minimal-stack constants

+ * -----

+ * FSR's:

+ *		STATUS, WREG, BSR, PRODH, PRODL, FSR0H, FSR0L,

+ *		FSR1H, FSR1L,TABLAT, (TBLPTRU), TBLPTRH, TBLPTRL,

+ *		(PCLATU), PCLATH

+ *		sfr's within parenthesis only on devices > 64kB

+ * -----

+ * Call/Return stack:

+ *		 2 bytes per entry on devices <= 64kB

+ *		 3 bytes per entry on devices >  64kB

+ * -----

+ * Other bytes:

+ *		 2 bytes: FunctionParameter for initial taskcode

+ *		 1 byte : Number of entries on call/return stack

+ *		 1 byte : ucCriticalNesting

+ *		16 bytes: Free space on stack

+ */

+#if _ROMSIZE > 0x8000

+	#define portSTACK_FSR_BYTES				( 15 )

+	#define portSTACK_CALLRETURN_ENTRY_SIZE	(  3 )

+#else

+	#define portSTACK_FSR_BYTES				( 13 )

+	#define portSTACK_CALLRETURN_ENTRY_SIZE	(  2 )

+#endif

+

+#define portSTACK_MINIMAL_CALLRETURN_DEPTH	( 10 )

+#define portSTACK_OTHER_BYTES				( 20 )

+

+unsigned short usCalcMinStackSize		= 0;

+

+/*-----------------------------------------------------------*/

+

+/*

+ * We initialise ucCriticalNesting to the middle value an 

+ * unsigned char can contain. This way portENTER_CRITICAL()

+ * and portEXIT_CRITICAL() can be called without interrupts

+ * being enabled before the scheduler starts.

+ */

+register unsigned char ucCriticalNesting = 0x7F;

+

+/*-----------------------------------------------------------*/

+

+/* 

+ * Initialise the stack of a new task.

+ * See portSAVE_CONTEXT macro for description. 

+ */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+unsigned char ucScratch;

+	/*

+	 * Get the size of the RAMarea in page 0 used by the compiler

+	 * We do this here already to avoid W-register conflicts.

+	 */

+	_Pragma("asm")

+		movlw	OVERHEADPAGE0-LOCOPTSIZE+MAXLOCOPTSIZE

+		movwf	PRODL,ACCESS		; PRODL is used as temp register

+	_Pragma("asmend")

+	ucScratch = PRODL;

+

+	/*

+	 * Place a few bytes of known values on the bottom of the stack. 

+	 * This is just useful for debugging.

+	 */

+//	*pxTopOfStack--	= 0x11;

+//	*pxTopOfStack-- = 0x22;

+//	*pxTopOfStack-- = 0x33;

+

+	/*

+	 * Simulate how the stack would look after a call to vPortYield()

+	 * generated by the compiler.

+	 */

+

+	/*

+	 * First store the function parameters.  This is where the task expects

+	 * to find them when it starts running.

+	 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) ( (( unsigned short ) pvParameters >> 8) & 0x00ff );

+	*pxTopOfStack-- = ( portSTACK_TYPE ) (  ( unsigned short ) pvParameters       & 0x00ff );

+

+	/*

+	 * Next are all the registers that form part of the task context.

+	 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x11; /* STATUS. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x22; /* WREG. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x33; /* BSR. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x44; /* PRODH. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x55; /* PRODL. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x66; /* FSR0H. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x77; /* FSR0L. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x88; /* FSR1H. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x99; /* FSR1L. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xAA; /* TABLAT. */

+#if _ROMSIZE > 0x8000

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0x00; /* TBLPTRU. */

+#endif

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xCC; /* TBLPTRH. */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xDD; /* TBLPTRL. */

+#if _ROMSIZE > 0x8000

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xEE; /* PCLATU. */

+#endif

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0xFF; /* PCLATH. */

+

+	/*

+	 * Next the compiler's scratchspace.

+	 */

+	while(ucScratch-- > 0)

+	{

+		*pxTopOfStack-- = ( portSTACK_TYPE ) 0;

+	}

+	

+	/*

+	 * The only function return address so far is the address of the task entry.

+	 * The order is TOSU/TOSH/TOSL. For devices > 64kB, TOSU is put on the 

+	 * stack, too. TOSU is always written as zero here because wizC does not allow

+	 * functionpointers to point above 64kB in ROM.

+	 */

+#if _ROMSIZE > 0x8000

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 0;

+#endif

+	*pxTopOfStack-- = ( portSTACK_TYPE ) ( ( ( unsigned short ) pxCode >> 8 ) & 0x00ff );

+	*pxTopOfStack-- = ( portSTACK_TYPE ) ( (   unsigned short ) pxCode        & 0x00ff );

+

+	/*

+	 * Store the number of return addresses on the hardware stack.

+	 * So far only the address of the task entry point.

+	 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) 1;

+

+	/*

+	 * The code generated by wizC does not maintain separate

+	 * stack and frame pointers. Therefore the portENTER_CRITICAL macro cannot 

+	 * use the stack as per other ports.  Instead a variable is used to keep

+	 * track of the critical section nesting.  This variable has to be stored

+	 * as part of the task context and is initially set to zero.

+	 */

+	*pxTopOfStack-- = ( portSTACK_TYPE ) portNO_CRITICAL_SECTION_NESTING;	

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+unsigned short usPortCALCULATE_MINIMAL_STACK_SIZE( void )

+{

+	/*

+	 * Fetch the size of compiler's scratchspace.

+	 */

+	_Pragma("asm")

+		movlw	OVERHEADPAGE0-LOCOPTSIZE+MAXLOCOPTSIZE

+		movlb	usCalcMinStackSize>>8

+		movwf	usCalcMinStackSize,BANKED

+	_Pragma("asmend")

+

+	/*

+	 * Add minimum needed stackspace

+	 */

+	usCalcMinStackSize	+=	( portSTACK_FSR_BYTES )

+		+	( portSTACK_MINIMAL_CALLRETURN_DEPTH * portSTACK_CALLRETURN_ENTRY_SIZE )

+		+	( portSTACK_OTHER_BYTES );

+

+	return(usCalcMinStackSize);

+}

+

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xPortStartScheduler( void )

+{

+	extern void portSetupTick( void );

+

+	/*

+	 * Setup a timer for the tick ISR for the preemptive scheduler.

+	 */

+	portSetupTick(); 

+

+	/*

+	 * Restore the context of the first task to run.

+	 */

+	portRESTORE_CONTEXT();

+

+	/*

+	 * This point should never be reached during execution.

+	 */

+	return pdTRUE;

+}

+

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/*

+	 * It is unlikely that the scheduler for the PIC port will get stopped

+	 * once running. When called a reset is done which is probably the

+	 * most valid action.

+	 */

+	_Pragma(asmline reset);

+}

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Manual context switch.  This is similar to the tick context switch,

+ * but does not increment the tick count.  It must be identical to the

+ * tick context switch in how it stores the stack of a task.

+ */

+void vPortYield( void )

+{

+	/*

+	 * Save the context of the current task.

+	 */

+	portSAVE_CONTEXT( portINTERRUPTS_UNCHANGED );

+

+	/*

+	 * Switch to the highest priority task that is ready to run.

+	 */

+	vTaskSwitchContext();

+

+	/*

+	 * Start executing the task we have just switched to.

+	 */

+	portRESTORE_CONTEXT();

+}

+

+/*-----------------------------------------------------------*/

+

+void *pvPortMalloc( unsigned short usWantedSize )

+{

+void *pvReturn;

+

+	vTaskSuspendAll();

+	{

+		pvReturn = malloc( ( malloc_t ) usWantedSize );

+	}

+	xTaskResumeAll();

+

+	return pvReturn;

+}

+

+void vPortFree( void *pv )

+{

+	if( pv )

+	{

+		vTaskSuspendAll();

+		{

+			free( pv );

+		}

+		xTaskResumeAll();

+	}

+}

diff --git a/FreeRTOS/Source/portable/WizC/PIC18/portmacro.h b/FreeRTOS/Source/portable/WizC/PIC18/portmacro.h
new file mode 100644
index 0000000..29a3c1d
--- /dev/null
+++ b/FreeRTOS/Source/portable/WizC/PIC18/portmacro.h
@@ -0,0 +1,457 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* 

+Changes from V3.0.0

+

+Changes from V3.0.1

+*/

+#ifndef PORTMACRO_H

+#define PORTMACRO_H

+

+#if !defined(_SERIES) || _SERIES != 18

+	#error "WizC supports FreeRTOS on the Microchip PIC18-series only"

+#endif

+

+#if !defined(QUICKCALL) || QUICKCALL != 1

+	#error "QuickCall must be enabled (see ProjectOptions/Optimisations)"

+#endif

+

+#include <stddef.h>

+#include <pic.h>

+

+#define portCHAR		char

+#define portFLOAT		float

+#define portDOUBLE		portFLOAT

+#define portLONG		long

+#define portSHORT		short

+#define portSTACK_TYPE	unsigned char

+#define portBASE_TYPE	char

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType )	( 0xFFFF )

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType )	( 0xFFFFFFFF )

+#endif

+

+#define portBYTE_ALIGNMENT			1

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Constant used for context switch macro when we require the interrupt 

+ * enable state to be forced when the interrupted task is switched back in.

+ */

+#define portINTERRUPTS_FORCED				(0x01)

+

+/*

+ * Constant used for context switch macro when we require the interrupt 

+ * enable state to be unchanged when the interrupted task is switched back in.

+ */

+#define portINTERRUPTS_UNCHANGED			(0x00)

+

+/* Initial interrupt enable state for newly created tasks.  This value is

+ * used when a task switches in for the first time.

+ */

+#define portINTERRUPTS_INITIAL_STATE		(portINTERRUPTS_FORCED)

+

+/*

+ * Macros to modify the global interrupt enable bit in INTCON.

+ */

+#define portDISABLE_INTERRUPTS()	\

+	do								\

+	{								\

+		bGIE=0;						\

+	} while(bGIE)	// MicroChip recommends this check!

+	

+#define portENABLE_INTERRUPTS()		\

+	do								\

+	{								\

+		bGIE=1;						\

+	} while(0)

+

+/*-----------------------------------------------------------*/	

+

+/*

+ * Critical section macros.

+ */

+extern unsigned portCHAR ucCriticalNesting;

+

+#define portNO_CRITICAL_SECTION_NESTING		( ( unsigned portCHAR ) 0 )

+

+#define portENTER_CRITICAL()										\

+	do																\

+	{																\

+		portDISABLE_INTERRUPTS();									\

+																	\

+		/*															\

+		 * Now interrupts are disabled ucCriticalNesting			\

+		 * can be accessed directly. Increment						\

+		 * ucCriticalNesting to keep a count of how					\

+		 * many times portENTER_CRITICAL() has been called. 		\

+		 */															\

+		ucCriticalNesting++;										\

+	} while(0)

+

+#define portEXIT_CRITICAL()											\

+	do																\

+	{																\

+		if(ucCriticalNesting > portNO_CRITICAL_SECTION_NESTING)		\

+		{															\

+			/*														\

+			 * Decrement the nesting count as we are leaving a		\

+			 * critical section.									\

+			 */														\

+			ucCriticalNesting--;									\

+		}															\

+																	\

+		/*															\

+		 * If the nesting level has reached zero then				\

+		 * interrupts should be re-enabled.							\

+		 */															\

+		if( ucCriticalNesting == portNO_CRITICAL_SECTION_NESTING )	\

+		{															\

+			portENABLE_INTERRUPTS();								\

+		}															\

+	} while(0)

+

+/*-----------------------------------------------------------*/

+

+/*

+ * The minimal stacksize is calculated on the first reference of

+ * portMINIMAL_STACK_SIZE. Some input to this calculation is

+ * compiletime determined, other input is port-defined (see port.c)

+ */

+extern unsigned portSHORT usPortCALCULATE_MINIMAL_STACK_SIZE( void );

+extern unsigned portSHORT usCalcMinStackSize;

+

+#define portMINIMAL_STACK_SIZE					\

+	((usCalcMinStackSize == 0)					\

+		? usPortCALCULATE_MINIMAL_STACK_SIZE()	\

+		: usCalcMinStackSize )

+

+/*

+ * WizC uses a downgrowing stack

+ */

+#define portSTACK_GROWTH			( -1 )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro's that pushes all the registers that make up the context of a task onto

+ * the stack, then saves the new top of stack into the TCB. TOSU and TBLPTRU

+ * are only saved/restored on devices with more than 64kB (32k Words) ROM.

+ * 

+ * The stackpointer is helt by WizC in FSR2 and points to the first free byte.

+ * WizC uses a "downgrowing" stack. There is no framepointer.

+ *

+ * We keep track of the interruptstatus using ucCriticalNesting. When this

+ * value equals zero, interrupts have to be enabled upon exit from the

+ * portRESTORE_CONTEXT macro.

+ * 

+ * If this is called from an ISR then the interrupt enable bits must have been 

+ * set for the ISR to ever get called.  Therefore we want to save

+ * ucCriticalNesting with value zero. This means the interrupts will again be

+ * re-enabled when the interrupted task is switched back in.

+ *

+ * If this is called from a manual context switch (i.e. from a call to yield),

+ * then we want to keep the current value of ucCritialNesting so it is restored

+ * with its current value. This allows a yield from within a critical section.

+ *

+ * The compiler uses some locations at the bottom of RAM for temporary

+ * storage. The compiler may also have been instructed to optimize

+ * function-parameters and local variables to global storage. The compiler

+ * uses an area called LocOpt for this wizC feature.

+ * The total overheadstorage has to be saved in it's entirety as part of

+ * a task context. These macro's store/restore from data address 0x0000 to

+ * (OVERHEADPAGE0-LOCOPTSIZE+MAXLOCOPTSIZE - 1).

+ * OVERHEADPAGE0, LOCOPTSIZE and MAXLOCOPTSIZE are compiler-generated

+ * assembler definitions.

+ */

+

+#define	portSAVE_CONTEXT( ucInterruptForced )						\

+	do																\

+	{																\

+		portDISABLE_INTERRUPTS();									\

+																	\

+		_Pragma("asm")												\

+			;														\

+			; Push the relevant SFR's onto the task's stack			\

+			;														\

+			movff   STATUS,POSTDEC2									\

+			movff	WREG,POSTDEC2									\

+			movff	BSR,POSTDEC2									\

+			movff	PRODH,POSTDEC2									\

+			movff	PRODL,POSTDEC2									\

+			movff	FSR0H,POSTDEC2									\

+			movff	FSR0L,POSTDEC2									\

+			movff	FSR1H,POSTDEC2									\

+			movff	FSR1L,POSTDEC2									\

+			movff	TABLAT,POSTDEC2									\

+			if __ROMSIZE > 0x8000									\

+				movff	TBLPTRU,POSTDEC2							\

+			endif													\

+			movff	TBLPTRH,POSTDEC2								\

+			movff	TBLPTRL,POSTDEC2								\

+			if __ROMSIZE > 0x8000									\

+				movff	PCLATU,POSTDEC2								\

+			endif													\

+			movff	PCLATH,POSTDEC2									\

+			;														\

+			; Store the compiler-scratch-area as described above.	\

+			;														\

+			movlw	OVERHEADPAGE0-LOCOPTSIZE+MAXLOCOPTSIZE			\

+			clrf	FSR0L,ACCESS									\

+			clrf	FSR0H,ACCESS									\

+		_rtos_S1:													\

+			movff	POSTINC0,POSTDEC2								\

+			decfsz	WREG,W,ACCESS									\

+			SMARTJUMP _rtos_S1										\

+			;														\

+			; Save the pic call/return-stack belonging to the		\

+			; current task by copying it to the task's software-	\

+			; stack. We save the hardware stack pointer (which		\

+			; is the number of addresses on the stack) in the		\

+			; W-register first because we need it later and it		\

+			; is modified in the save-loop by executing pop's.		\

+			; After the loop the W-register is stored on the		\

+			; stack, too.											\

+			;														\

+			movf	STKPTR,W,ACCESS									\

+			bz		_rtos_s3										\

+		_rtos_S2:													\

+			if __ROMSIZE > 0x8000									\

+				movff	TOSU,POSTDEC2								\

+			endif													\

+			movff	TOSH,POSTDEC2									\

+			movff	TOSL,POSTDEC2									\

+			pop														\

+			tstfsz	STKPTR,ACCESS									\

+			SMARTJUMP _rtos_S2										\

+		_rtos_s3:													\

+			movwf	POSTDEC2,ACCESS									\

+			;														\

+			; Next the value for ucCriticalNesting used by the		\

+			; task is stored on the stack. When						\

+			; (ucInterruptForced == portINTERRUPTS_FORCED), we save	\

+			; it as 0 (portNO_CRITICAL_SECTION_NESTING).			\

+			;														\

+			if ucInterruptForced == portINTERRUPTS_FORCED			\

+				clrf POSTDEC2,ACCESS								\

+			else													\

+				movff	ucCriticalNesting,POSTDEC2					\

+			endif													\

+			;														\

+			; Save the new top of the software stack in the TCB.	\

+			;														\

+			movff	pxCurrentTCB,FSR0L								\

+			movff	pxCurrentTCB+1,FSR0H							\

+			movff	FSR2L,POSTINC0									\

+			movff	FSR2H,POSTINC0									\

+		_Pragma("asmend")											\

+	} while(0)

+

+/************************************************************/

+

+/*

+ * This is the reverse of portSAVE_CONTEXT.

+ */

+#define portRESTORE_CONTEXT()										\

+	do																\

+	{																\

+		_Pragma("asm")												\

+			;														\

+			; Set FSR0 to point to pxCurrentTCB->pxTopOfStack.		\

+			;														\

+			movff	pxCurrentTCB,FSR0L								\

+			movff	pxCurrentTCB+1,FSR0H							\

+			;														\

+			; De-reference FSR0 to set the address it holds into	\

+			; FSR2 (i.e. *( pxCurrentTCB->pxTopOfStack ) ). FSR2	\

+			; is used by wizC as stackpointer.						\

+			;														\

+			movff	POSTINC0,FSR2L									\

+			movff	POSTINC0,FSR2H									\

+			;														\

+			; Next, the value for ucCriticalNesting used by the		\

+			; task is retrieved from the stack.						\

+			;														\

+			movff	PREINC2,ucCriticalNesting						\

+			;														\

+			; Rebuild the pic call/return-stack. The number of		\

+			; return addresses is the next item on the task stack.	\

+			; Save this number in PRODL. Then fetch the addresses	\

+			; and store them on the hardwarestack.					\

+			; The datasheets say we can't use movff here...			\

+			;														\

+			movff	PREINC2,PRODL	// Use PRODL as tempregister	\

+			clrf	STKPTR,ACCESS									\

+		_rtos_R1:													\

+			push													\

+			movf	PREINC2,W,ACCESS								\

+			movwf	TOSL,ACCESS										\

+			movf	PREINC2,W,ACCESS								\

+			movwf	TOSH,ACCESS										\

+			if __ROMSIZE > 0x8000									\

+				movf	PREINC2,W,ACCESS							\

+				movwf	TOSU,ACCESS									\

+			else													\

+				clrf	TOSU,ACCESS									\

+			endif													\

+			decfsz	PRODL,F,ACCESS									\

+			SMARTJUMP _rtos_R1										\

+			;														\

+			; Restore the compiler's working storage area to page 0	\

+			;														\

+			movlw	OVERHEADPAGE0-LOCOPTSIZE+MAXLOCOPTSIZE			\

+			movwf	FSR0L,ACCESS									\

+			clrf	FSR0H,ACCESS									\

+		_rtos_R2:													\

+			decf	FSR0L,F,ACCESS									\

+			movff	PREINC2,INDF0									\

+			tstfsz	FSR0L,ACCESS									\

+			SMARTJUMP _rtos_R2										\

+			;														\

+			; Restore the sfr's forming the tasks context.			\

+			; We cannot yet restore bsr, w and status because		\

+			; we need these	registers for a final test.				\

+			;														\

+			movff	PREINC2,PCLATH									\

+			if __ROMSIZE > 0x8000									\

+				movff	PREINC2,PCLATU								\

+			else													\

+				clrf	PCLATU,ACCESS								\

+			endif													\

+			movff	PREINC2,TBLPTRL									\

+			movff	PREINC2,TBLPTRH									\

+			if __ROMSIZE > 0x8000									\

+				movff	PREINC2,TBLPTRU								\

+			else													\

+				clrf	TBLPTRU,ACCESS								\

+			endif													\

+			movff	PREINC2,TABLAT									\

+			movff	PREINC2,FSR1L									\

+			movff	PREINC2,FSR1H									\

+			movff	PREINC2,FSR0L									\

+			movff	PREINC2,FSR0H									\

+			movff	PREINC2,PRODL									\

+			movff	PREINC2,PRODH									\

+			;														\

+			; The return from portRESTORE_CONTEXT() depends on		\

+			; the value of ucCriticalNesting. When it is zero,		\

+			; interrupts need to be enabled. This is done via a		\

+			; retfie instruction because we need the				\

+			; interrupt-enabling and the return to the restored		\

+			; task to be uninterruptable.							\

+	 		; Because bsr, status and W are affected by the test	\

+	 		; they are restored after the test.						\

+			;														\

+			movlb	ucCriticalNesting>>8							\

+			tstfsz	ucCriticalNesting,BANKED						\

+			SMARTJUMP _rtos_R4										\

+		_rtos_R3:													\

+			movff	PREINC2,BSR										\

+			movff	PREINC2,WREG									\

+			movff	PREINC2,STATUS									\

+			retfie	0		; Return enabling interrupts			\

+		_rtos_R4:													\

+			movff	PREINC2,BSR										\

+			movff	PREINC2,WREG									\

+			movff	PREINC2,STATUS									\

+			return	0		; Return without affecting interrupts	\

+		_Pragma("asmend")											\

+	} while(0)

+

+/*-----------------------------------------------------------*/

+

+#define portTICK_RATE_MS	( ( portTickType ) 1000 / configTICK_RATE_HZ )		

+

+/*-----------------------------------------------------------*/

+

+extern void vPortYield( void );

+#define portYIELD()				vPortYield()

+

+#define portNOP()	_Pragma("asm")									\

+						nop											\

+					_Pragma("asmend")

+

+/*-----------------------------------------------------------*/

+

+#define portTASK_FUNCTION( xFunction, pvParameters )	 	\

+	void pointed xFunction( void *pvParameters )		\

+	_Pragma(asmfunc xFunction)

+

+#define portTASK_FUNCTION_PROTO		portTASK_FUNCTION

+/*-----------------------------------------------------------*/

+

+

+#define volatile

+#define register

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/port.c b/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/port.c
new file mode 100644
index 0000000..99cff59
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/port.c
@@ -0,0 +1,284 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.00:

+	

+	+ Call to taskYIELD() from within tick ISR has been replaced by the more

+	  efficient portSWITCH_CONTEXT().

+	+ ISR function definitions renamed to include the prv prefix.

+

+Changes from V1.2.0:

+

+	+ portRESET_PIC() is now called last thing before the end of the preemptive

+	  tick routine.

+

+Changes from V2.6.1

+

+	+ Replaced the sUsingPreemption variable with the configUSE_PREEMPTION

+	  macro to be consistent with the later ports.

+*/

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the Flashlite 186

+ * port.

+ *----------------------------------------------------------*/

+

+#include <stdlib.h>

+#include <i86.h>

+#include <dos.h>

+#include <setjmp.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/*lint -e950 Non ANSI reserved words okay in this file only. */

+

+#define portTIMER_EOI_TYPE		( 8 )

+#define portRESET_PIC()			portOUTPUT_WORD( ( unsigned short ) 0xff22, portTIMER_EOI_TYPE )

+#define portTIMER_INT_NUMBER	0x12

+

+#define portTIMER_1_CONTROL_REGISTER	( ( unsigned short ) 0xff5e )

+#define portTIMER_0_CONTROL_REGISTER	( ( unsigned short ) 0xff56 )

+#define portTIMER_INTERRUPT_ENABLE		( ( unsigned short ) 0x2000 )

+

+/* Setup the hardware to generate the required tick frequency. */

+static void prvSetTickFrequency( unsigned long ulTickRateHz );

+

+/* Set the hardware back to the state as per before the scheduler started. */

+static void prvExitFunction( void );

+

+#if configUSE_PREEMPTION == 1

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is 

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/*lint -e956 File scopes necessary here. */

+

+/* Set true when the vectors are set so the scheduler will service the tick. */

+static short sSchedulerRunning = pdFALSE;

+

+/* Points to the original routine installed on the vector we use for manual context switches.  This is then used to restore the original routine during prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISR )();

+

+/* Used to restore the original DOS context when the scheduler is ended. */

+static jmp_buf xJumpBuf;

+

+/*lint +e956 */

+

+/*-----------------------------------------------------------*/

+portBASE_TYPE xPortStartScheduler( void )

+{

+	/* This is called with interrupts already disabled. */

+

+	/* Remember what was on the interrupts we are going to use

+	so we can put them back later if required. */

+	pxOldSwitchISR = _dos_getvect( portSWITCH_INT_NUMBER );

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	_dos_setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	#if configUSE_PREEMPTION == 1

+	{		

+		/* Put our tick switch function on the timer interrupt. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvPreemptiveTick );

+	}

+	#else

+	{

+		/* We want the timer interrupt to just increment the tick count. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvNonPreemptiveTick );

+	}

+	#endif

+

+	prvSetTickFrequency( configTICK_RATE_HZ );

+

+	/* Clean up function if we want to return to DOS. */

+	if( setjmp( xJumpBuf ) != 0 )

+	{

+		prvExitFunction();

+		sSchedulerRunning = pdFALSE;

+	}

+	else

+	{

+		sSchedulerRunning = pdTRUE;

+

+		/* Kick off the scheduler by setting up the context of the first task. */

+		portFIRST_CONTEXT();

+	}

+

+	return sSchedulerRunning;

+}

+/*-----------------------------------------------------------*/

+

+/* The tick ISR used depend on whether or not the preemptive or cooperative

+kernel is being used. */

+#if configUSE_PREEMPTION == 1

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portSWITCH_CONTEXT();

+

+		/* Reset the PIC ready for the next time. */

+		portRESET_PIC();

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		portRESET_PIC();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portSWITCH_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Jump back to the processor state prior to starting the

+	scheduler.  This means we are not going to be using a

+	task stack frame so the task can be deleted. */

+	longjmp( xJumpBuf, 1 );

+}

+/*-----------------------------------------------------------*/

+

+static void prvExitFunction( void )

+{

+const unsigned short usTimerDisable = 0x0000;

+unsigned short usTimer0Control;

+

+	/* Interrupts should be disabled here anyway - but no 

+	harm in making sure. */

+	portDISABLE_INTERRUPTS();

+	if( sSchedulerRunning == pdTRUE )

+	{

+		/* Put back the switch interrupt routines that was in place

+		before the scheduler started. */

+		_dos_setvect( portSWITCH_INT_NUMBER, pxOldSwitchISR );

+	}

+

+	/* Disable the timer used for the tick to ensure the scheduler is

+	not called before restoring interrupts.  There was previously nothing

+	on this timer so there is no old ISR to restore. */

+	portOUTPUT_WORD( portTIMER_1_CONTROL_REGISTER, usTimerDisable );

+

+	/* Restart the DOS tick. */

+	usTimer0Control = portINPUT_WORD( portTIMER_0_CONTROL_REGISTER );

+	usTimer0Control |= portTIMER_INTERRUPT_ENABLE;

+	portOUTPUT_WORD( portTIMER_0_CONTROL_REGISTER, usTimer0Control );

+

+

+	portENABLE_INTERRUPTS();

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequency( unsigned long ulTickRateHz )

+{

+const unsigned short usMaxCountRegister = 0xff5a;

+const unsigned short usTimerPriorityRegister = 0xff32;

+const unsigned short usTimerEnable = 0xC000;

+const unsigned short usRetrigger = 0x0001;

+const unsigned short usTimerHighPriority = 0x0000;

+unsigned short usTimer0Control;

+

+/* ( CPU frequency / 4 ) / clock 2 max count [inpw( 0xff62 ) = 7] */

+

+const unsigned long ulClockFrequency = 0x7f31a0;

+

+unsigned long ulTimerCount = ulClockFrequency / ulTickRateHz;

+

+	portOUTPUT_WORD( portTIMER_1_CONTROL_REGISTER, usTimerEnable | portTIMER_INTERRUPT_ENABLE | usRetrigger );

+	portOUTPUT_WORD( usMaxCountRegister, ( unsigned short ) ulTimerCount );

+	portOUTPUT_WORD( usTimerPriorityRegister, usTimerHighPriority );

+

+	/* Stop the DOS tick - don't do this if you want to maintain a TOD clock. */

+	usTimer0Control = portINPUT_WORD( portTIMER_0_CONTROL_REGISTER );

+	usTimer0Control &= ~portTIMER_INTERRUPT_ENABLE;

+	portOUTPUT_WORD( portTIMER_0_CONTROL_REGISTER, usTimer0Control );

+}

+

+

+/*lint +e950 */

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/portmacro.h b/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/portmacro.h
new file mode 100644
index 0000000..3870fa3
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/Flsh186/portmacro.h
@@ -0,0 +1,144 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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      long

+#define portLONG        long

+#define portSHORT       int

+#define portSTACK_TYPE  unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+        typedef unsigned portSHORT portTickType;

+        #define portMAX_DELAY ( portTickType ) 0xffff

+#else

+        typedef unsigned portLONG portTickType;

+        #define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section management. */

+void portENTER_CRITICAL( void );

+#pragma aux portENTER_CRITICAL = "pushf" \

+                                 "cli";

+

+void portEXIT_CRITICAL( void );

+#pragma aux portEXIT_CRITICAL   = "popf";

+

+void portDISABLE_INTERRUPTS( void );

+#pragma aux portDISABLE_INTERRUPTS = "cli";

+

+void portENABLE_INTERRUPTS( void );

+#pragma aux portENABLE_INTERRUPTS = "sti";

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH        ( -1 )

+#define portSWITCH_INT_NUMBER   0x80

+#define portYIELD()             __asm{ int portSWITCH_INT_NUMBER } 

+#define portTICK_RATE_MS        ( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portBYTE_ALIGNMENT      2

+#define portINITIAL_SW          ( ( portSTACK_TYPE ) 0x0202 )   /* Start the tasks with interrupts enabled. */

+#define portNOP()				__asm{ nop }

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )                 inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )       outp( xAddr, ucValue )

+#define portINPUT_WORD( xAddr )                 inpw( xAddr )

+#define portOUTPUT_WORD( xAddr, usValue )       outpw( xAddr, usValue )

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )

+#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/port.c b/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/port.c
new file mode 100644
index 0000000..72be381
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/port.c
@@ -0,0 +1,340 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.00:

+	

+	+ Call to taskYIELD() from within tick ISR has been replaced by the more

+	  efficient portSWITCH_CONTEXT().

+	+ ISR function definitions renamed to include the prv prefix.

+

+Changes from V1.2.0:

+

+	+ prvPortResetPIC() is now called last thing before the end of the 

+	  preemptive tick routine.

+

+Changes from V2.6.1

+

+	+ Replaced the sUsingPreemption variable with the configUSE_PREEMPTION

+	  macro to be consistent with the later ports.

+

+Changes from V4.0.1

+	

+	+ Add function prvSetTickFrequencyDefault() to set the DOS tick back to

+	  its proper value when the scheduler exits. 

+*/

+

+#include <stdlib.h>

+#include <stdio.h>

+#include <i86.h>

+#include <dos.h>

+#include <setjmp.h>

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "portasm.h"

+

+/*-----------------------------------------------------------

+ * Implementation of functions defined in portable.h for the industrial

+ * PC port.

+ *----------------------------------------------------------*/

+

+/*lint -e950 Non ANSI reserved words okay in this file only. */

+

+#define portTIMER_INT_NUMBER	0x08

+

+/* Setup hardware for required tick interrupt rate. */

+static void prvSetTickFrequency( unsigned long ulTickRateHz );

+

+/* Restore hardware to as it was prior to starting the scheduler. */

+static void prvExitFunction( void );

+

+/* Either chain to the DOS tick (which itself clears the PIC) or clear the PIC

+directly.  We chain to the DOS tick as close as possible to the standard DOS

+tick rate. */

+static void prvPortResetPIC( void );

+

+/* The tick ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if configUSE_PREEMPTION == 1

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void );

+#else

+	/* Tick service routine used by the scheduler when cooperative scheduling is 

+	being used. */

+	static void __interrupt __far prvNonPreemptiveTick( void );

+#endif

+/* Trap routine used by taskYIELD() to manually cause a context switch. */

+static void __interrupt __far prvYieldProcessor( void );

+

+/* Set the tick frequency back so the floppy drive works correctly when the

+scheduler exits. */

+static void prvSetTickFrequencyDefault( void );

+

+/*lint -e956 File scopes necessary here. */

+

+/* Used to signal when to chain to the DOS tick, and when to just clear the PIC ourselves. */

+static short sDOSTickCounter;							

+

+/* Set true when the vectors are set so the scheduler will service the tick. */

+static short sSchedulerRunning = pdFALSE;				

+

+/* Points to the original routine installed on the vector we use for manual context switches.  This is then used to restore the original routine during prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISR )();		

+

+/* Points to the original routine installed on the vector we use to chain to the DOS tick.  This is then used to restore the original routine during prvExitFunction(). */

+static void ( __interrupt __far *pxOldSwitchISRPlus1 )();	

+

+/* Used to restore the original DOS context when the scheduler is ended. */

+static jmp_buf xJumpBuf;

+

+/*lint +e956 */

+

+/*-----------------------------------------------------------*/

+portBASE_TYPE xPortStartScheduler( void )

+{

+pxISR pxOriginalTickISR;

+	

+	/* This is called with interrupts already disabled. */

+

+	/* Remember what was on the interrupts we are going to use

+	so we can put them back later if required. */

+	pxOldSwitchISR = _dos_getvect( portSWITCH_INT_NUMBER );

+	pxOriginalTickISR = _dos_getvect( portTIMER_INT_NUMBER );

+	pxOldSwitchISRPlus1 = _dos_getvect( portSWITCH_INT_NUMBER + 1 );

+

+	prvSetTickFrequency( configTICK_RATE_HZ );

+

+	/* Put our manual switch (yield) function on a known

+	vector. */

+	_dos_setvect( portSWITCH_INT_NUMBER, prvYieldProcessor );

+

+	/* Put the old tick on a different interrupt number so we can

+	call it when we want. */

+	_dos_setvect( portSWITCH_INT_NUMBER + 1, pxOriginalTickISR );

+

+	#if configUSE_PREEMPTION == 1

+	{		

+		/* Put our tick switch function on the timer interrupt. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvPreemptiveTick );

+	}

+	#else

+	{

+		/* We want the timer interrupt to just increment the tick count. */

+		_dos_setvect( portTIMER_INT_NUMBER, prvNonPreemptiveTick );

+	}

+	#endif

+

+	/* Setup a counter that is used to call the DOS interrupt as close

+	to it's original frequency as can be achieved given our chosen tick

+	frequency. */

+	sDOSTickCounter = portTICKS_PER_DOS_TICK;

+

+	/* Clean up function if we want to return to DOS. */

+	if( setjmp( xJumpBuf ) != 0 )

+	{

+		prvExitFunction();

+		sSchedulerRunning = pdFALSE;

+	}

+	else

+	{

+		sSchedulerRunning = pdTRUE;

+

+		/* Kick off the scheduler by setting up the context of the first task. */

+		portFIRST_CONTEXT();

+	}

+

+	return sSchedulerRunning;

+}

+/*-----------------------------------------------------------*/

+

+/* The tick ISR used depends on whether the preemptive or cooperative scheduler

+is being used. */

+#if configUSE_PREEMPTION == 1

+	/* Tick service routine used by the scheduler when preemptive scheduling is

+	being used. */

+	static void __interrupt __far prvPreemptiveTick( void )

+	{

+		/* Get the scheduler to update the task states following the tick. */

+		vTaskIncrementTick();

+

+		/* Switch in the context of the next task to be run. */

+		portSWITCH_CONTEXT();

+

+		/* Reset the PIC ready for the next time. */

+		prvPortResetPIC();

+	}

+#else

+	static void __interrupt __far prvNonPreemptiveTick( void )

+	{

+		/* Same as preemptive tick, but the cooperative scheduler is being used

+		so we don't have to switch in the context of the next task. */

+		vTaskIncrementTick();

+		prvPortResetPIC();

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+

+static void __interrupt __far prvYieldProcessor( void )

+{

+	/* Switch in the context of the next task to be run. */

+	portSWITCH_CONTEXT();

+}

+/*-----------------------------------------------------------*/

+

+static void prvPortResetPIC( void )

+{

+	/* We are going to call the DOS tick interrupt at as close a

+	frequency to the normal DOS tick as possible. */

+

+	/* WE SHOULD NOT DO THIS IF YIELD WAS CALLED. */

+	--sDOSTickCounter;

+	if( sDOSTickCounter <= 0 )

+	{

+		sDOSTickCounter = ( short ) portTICKS_PER_DOS_TICK;

+		__asm{ int	portSWITCH_INT_NUMBER + 1 };		 

+	}

+	else

+	{

+		/* Reset the PIC as the DOS tick is not being called to

+		do it. */

+		__asm

+		{

+			mov	al, 20H

+			out 20H, al

+		};

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vPortEndScheduler( void )

+{

+	/* Jump back to the processor state prior to starting the

+	scheduler.  This means we are not going to be using a

+	task stack frame so the task can be deleted. */

+	longjmp( xJumpBuf, 1 );

+}

+/*-----------------------------------------------------------*/

+

+static void prvExitFunction( void )

+{

+void ( __interrupt __far *pxOriginalTickISR )();

+

+	/* Interrupts should be disabled here anyway - but no 

+	harm in making sure. */

+	portDISABLE_INTERRUPTS();

+	if( sSchedulerRunning == pdTRUE )

+	{

+		/* Set the DOS tick back onto the timer ticker. */

+		pxOriginalTickISR = _dos_getvect( portSWITCH_INT_NUMBER + 1 );

+		_dos_setvect( portTIMER_INT_NUMBER, pxOriginalTickISR );

+		prvSetTickFrequencyDefault();

+

+		/* Put back the switch interrupt routines that was in place

+		before the scheduler started. */

+		_dos_setvect( portSWITCH_INT_NUMBER, pxOldSwitchISR );

+		_dos_setvect( portSWITCH_INT_NUMBER + 1, pxOldSwitchISRPlus1 );

+	}

+	/* The tick timer is back how DOS wants it.  We can re-enable

+	interrupts without the scheduler being called. */

+	portENABLE_INTERRUPTS();

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequency( unsigned long ulTickRateHz )

+{

+const unsigned short usPIT_MODE = ( unsigned short ) 0x43;

+const unsigned short usPIT0 = ( unsigned short ) 0x40;

+const unsigned long ulPIT_CONST = ( unsigned long ) 1193180;

+const unsigned short us8254_CTR0_MODE3 = ( unsigned short ) 0x36;

+unsigned long ulOutput;

+

+	/* Setup the 8245 to tick at the wanted frequency. */

+	portOUTPUT_BYTE( usPIT_MODE, us8254_CTR0_MODE3 );

+	ulOutput = ulPIT_CONST / ulTickRateHz;

+   

+	portOUTPUT_BYTE( usPIT0, ( unsigned short )( ulOutput & ( unsigned long ) 0xff ) );

+	ulOutput >>= 8;

+	portOUTPUT_BYTE( usPIT0, ( unsigned short ) ( ulOutput & ( unsigned long ) 0xff ) );

+}

+/*-----------------------------------------------------------*/

+

+static void prvSetTickFrequencyDefault( void )

+{

+const unsigned short usPIT_MODE = ( unsigned short ) 0x43;

+const unsigned short usPIT0 = ( unsigned short ) 0x40;

+const unsigned short us8254_CTR0_MODE3 = ( unsigned short ) 0x36;

+

+	portOUTPUT_BYTE( usPIT_MODE, us8254_CTR0_MODE3 );

+	portOUTPUT_BYTE( usPIT0,0 );

+	portOUTPUT_BYTE( usPIT0,0 );

+}

+

+

+/*lint +e950 */

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/portmacro.h b/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/portmacro.h
new file mode 100644
index 0000000..b4ce2d6
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/PC/portmacro.h
@@ -0,0 +1,146 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#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		int

+#define portSTACK_TYPE	unsigned portSHORT

+#define portBASE_TYPE	portSHORT

+

+#if( configUSE_16_BIT_TICKS == 1 )

+	typedef unsigned portSHORT portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffff

+#else

+	typedef unsigned portLONG portTickType;

+	#define portMAX_DELAY ( portTickType ) 0xffffffff

+#endif

+/*-----------------------------------------------------------*/

+

+/* Critical section definitions.  portENTER_CRITICAL() must be defined as a

+macro for portable.h to work properly. */

+void portLOCAL_ENTER_CRITICAL( void );

+#pragma aux portLOCAL_ENTER_CRITICAL = 	"pushf" \

+										"cli";

+#define portENTER_CRITICAL() portLOCAL_ENTER_CRITICAL()

+										

+void portEXIT_CRITICAL( void );

+#pragma aux portEXIT_CRITICAL	=		"popf";

+

+void portDISABLE_INTERRUPTS( void );

+#pragma aux portDISABLE_INTERRUPTS =	"cli";

+

+void portENABLE_INTERRUPTS( void );

+#pragma aux portENABLE_INTERRUPTS =		"sti";

+/*-----------------------------------------------------------*/

+

+/* Architecture specifics. */

+#define portSTACK_GROWTH		( -1 )

+#define portSWITCH_INT_NUMBER 	0x80

+#define portYIELD()				__asm{ int portSWITCH_INT_NUMBER } 

+#define portDOS_TICK_RATE		( 18.20648 )

+#define portTICK_RATE_MS        ( ( portTickType ) 1000 / configTICK_RATE_HZ )

+#define portTICKS_PER_DOS_TICK	( ( unsigned portSHORT ) ( ( ( portDOUBLE ) configTICK_RATE_HZ / portDOS_TICK_RATE ) + 0.5 ) )

+#define portINITIAL_SW			( ( portSTACK_TYPE ) 0x0202 )	/* Start the tasks with interrupts enabled. */

+#define portBYTE_ALIGNMENT		( 2 )

+/*-----------------------------------------------------------*/

+

+/* Compiler specifics. */

+#define portINPUT_BYTE( xAddr )				inp( xAddr )

+#define portOUTPUT_BYTE( xAddr, ucValue )	outp( xAddr, ucValue )

+#define portNOP() __asm{ nop }

+/*-----------------------------------------------------------*/

+

+/* Task function macros as described on the FreeRTOS.org WEB site. */

+#define portTASK_FUNCTION_PROTO( vTaskFunction, pvParameters ) void vTaskFunction( void *pvParameters )

+#define portTASK_FUNCTION( vTaskFunction, pvParameters ) void vTaskFunction( void *pvParameters )

+

+#ifdef __cplusplus

+}

+#endif

+

+

+#endif /* PORTMACRO_H */

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portasm.h b/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portasm.h
new file mode 100644
index 0000000..a968d6c
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portasm.h
@@ -0,0 +1,149 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+typedef void tskTCB;

+extern volatile tskTCB * volatile pxCurrentTCB;

+extern void vTaskSwitchContext( void );

+

+/* 

+ * Saves the stack pointer for one task into its TCB, calls 

+ * vTaskSwitchContext() to update the TCB being used, then restores the stack 

+ * from the new TCB read to run the task. 

+ */

+void portSWITCH_CONTEXT( void );

+

+/*

+ * Load the stack pointer from the TCB of the task which is going to be first

+ * to execute.  Then force an IRET so the registers and IP are popped off the

+ * stack.

+ */

+void portFIRST_CONTEXT( void );

+

+/* There are slightly different versions depending on whether you are building

+to include debugger information.  If debugger information is used then there

+are a couple of extra bytes left of the ISR stack (presumably for use by the

+debugger).  The true stack pointer is then stored in the bp register.  We add

+2 to the stack pointer to remove the extra bytes before we restore our context. */

+

+#ifdef DEBUG_BUILD

+

+	#pragma aux portSWITCH_CONTEXT =	"mov	ax, seg pxCurrentTCB"														\

+										"mov	ds, ax"																		\

+										"les	bx, pxCurrentTCB"			/* Save the stack pointer into the TCB. */		\

+										"mov	es:0x2[ bx ], ss"															\

+										"mov	es:[ bx ], sp"																\

+										"call	vTaskSwitchContext"			/* Perform the switch. */						\

+										"mov	ax, seg pxCurrentTCB"		/* Restore the stack pointer from the TCB. */	\

+										"mov	ds, ax"																		\

+										"les	bx, dword ptr pxCurrentTCB"													\

+										"mov	ss, es:[ bx + 2 ]"															\

+										"mov	sp, es:[ bx ]"																\

+										"mov	bp, sp"						/* Prepair the bp register for the restoration of the SP in the compiler generated portion of the ISR */	\

+										"add	bp, 0x0002"

+

+										

+

+	#pragma aux portFIRST_CONTEXT =		"mov	ax, seg pxCurrentTCB"			\

+										"mov	ds, ax"							\

+										"les	bx, dword ptr pxCurrentTCB"		\

+										"mov	ss, es:[ bx + 2 ]"				\

+										"mov	sp, es:[ bx ]"					\

+										"add	sp, 0x0002"						/* Remove the extra bytes that exist in debug builds before restoring the context. */ \

+										"pop	ax"								\

+										"pop	ax"								\

+										"pop	es"								\

+										"pop	ds"								\

+										"popa"									\

+										"iret"									

+#else

+

+	#pragma aux portSWITCH_CONTEXT =	"mov	ax, seg pxCurrentTCB"														\

+										"mov	ds, ax"																		\

+										"les	bx, pxCurrentTCB"			/* Save the stack pointer into the TCB. */		\

+										"mov	es:0x2[ bx ], ss"															\

+										"mov	es:[ bx ], sp"																\

+										"call	vTaskSwitchContext"			/* Perform the switch. */						\

+										"mov	ax, seg pxCurrentTCB"		/* Restore the stack pointer from the TCB. */	\

+										"mov	ds, ax"																		\

+										"les	bx, dword ptr pxCurrentTCB"													\

+										"mov	ss, es:[ bx + 2 ]"															\

+										"mov	sp, es:[ bx ]"

+										

+

+	#pragma aux portFIRST_CONTEXT =		"mov	ax, seg pxCurrentTCB"			\

+										"mov	ds, ax"							\

+										"les	bx, dword ptr pxCurrentTCB"		\

+										"mov	ss, es:[ bx + 2 ]"				\

+										"mov	sp, es:[ bx ]"					\

+										"pop	ax"								\

+										"pop	ax"								\

+										"pop	es"								\

+										"pop	ds"								\

+										"popa"									\

+										"iret"									

+#endif

+

+

diff --git a/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portcomn.c b/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portcomn.c
new file mode 100644
index 0000000..352631a
--- /dev/null
+++ b/FreeRTOS/Source/portable/oWatcom/16BitDOS/common/portcomn.c
@@ -0,0 +1,180 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/*

+Changes from V1.00:

+	

+	+ pxPortInitialiseStack() now initialises the stack of new tasks to the 

+	  same format used by the compiler.  This allows the compiler generated

+	  interrupt mechanism to be used for context switches.

+

+Changes from V2.4.2:

+

+	+ pvPortMalloc and vPortFree have been removed.  The projects now use

+	  the definitions from the source/portable/MemMang directory.

+

+Changes from V2.6.1:

+

+	+ usPortCheckFreeStackSpace() has been moved to tasks.c.

+*/

+

+	

+

+#include <stdlib.h>

+#include "FreeRTOS.h"

+

+/*-----------------------------------------------------------*/

+

+/* See header file for description. */

+portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE *pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )

+{

+portSTACK_TYPE DS_Reg = 0, *pxOriginalSP;

+

+	/* Place a few bytes of known values on the bottom of the stack. 

+	This is just useful for debugging. */

+

+	*pxTopOfStack = 0x1111;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x2222;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x3333;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x4444;

+	pxTopOfStack--;

+	*pxTopOfStack = 0x5555;

+	pxTopOfStack--;

+

+

+	/*lint -e950 -e611 -e923 Lint doesn't like this much - but nothing I can do about it. */

+

+	/* We are going to start the scheduler using a return from interrupt

+	instruction to load the program counter, so first there would be the

+	status register and interrupt return address.  We make this the start 

+	of the task. */

+	*pxTopOfStack = portINITIAL_SW; 

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pxCode );

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxCode );

+	pxTopOfStack--;

+

+	/* We are going to setup the stack for the new task to look like

+	the stack frame was setup by a compiler generated ISR.  We need to know

+	the address of the existing stack top to place in the SP register within

+	the stack frame.  pxOriginalSP holds SP before (simulated) pusha was 

+	called. */

+	pxOriginalSP = pxTopOfStack;

+

+	/* The remaining registers would be pushed on the stack by our context 

+	switch function.  These are loaded with values simply to make debugging

+	easier. */

+	*pxTopOfStack = FP_OFF( pvParameters );		/* AX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xCCCC;	/* CX */

+	pxTopOfStack--;

+	*pxTopOfStack = FP_SEG( pvParameters );		/* DX */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BX */

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pxOriginalSP );		/* SP */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xBBBB;	/* BP */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0x0123;	/* SI */

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xDDDD;	/* DI */

+

+	/* We need the true data segment. */

+	__asm{	MOV DS_Reg, DS };

+

+	pxTopOfStack--;

+	*pxTopOfStack = DS_Reg;	/* DS */

+

+	pxTopOfStack--;

+	*pxTopOfStack = ( portSTACK_TYPE ) 0xEEEE;	/* ES */

+

+	/* The AX register is pushed again twice - don't know why. */

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pvParameters );		/* AX */

+	pxTopOfStack--;

+	*pxTopOfStack = FP_OFF( pvParameters );		/* AX */

+

+

+	#ifdef DEBUG_BUILD

+		/* The compiler adds space to each ISR stack if building to

+		include debug information.  Presumably this is used by the

+		debugger - we don't need to initialise it to anything just

+		make sure it is there. */

+		pxTopOfStack--;

+	#endif

+

+	/*lint +e950 +e611 +e923 */

+

+	return pxTopOfStack;

+}

+/*-----------------------------------------------------------*/

+

+

diff --git a/FreeRTOS/Source/portable/readme.txt b/FreeRTOS/Source/portable/readme.txt
new file mode 100644
index 0000000..a20d687
--- /dev/null
+++ b/FreeRTOS/Source/portable/readme.txt
@@ -0,0 +1,19 @@
+Each real time kernel port consists of three files that contain the core kernel

+components and are common to every port, and one or more files that are 

+specific to a particular microcontroller and/or compiler.

+

+

++ The FreeRTOS/Source/Portable/MemMang directory contains the three sample 

+memory allocators as described on the http://www.FreeRTOS.org WEB site.

+

++ The other directories each contain files specific to a particular 

+microcontroller or compiler.

+

+

+

+For example, if you are interested in the GCC port for the ATMega323 

+microcontroller then the port specific files are contained in

+FreeRTOS/Source/Portable/GCC/ATMega323 directory.  If this is the only

+port you are interested in then all the other directories can be

+ignored.

+

diff --git a/FreeRTOS/Source/queue.c b/FreeRTOS/Source/queue.c
new file mode 100644
index 0000000..ca171b0
--- /dev/null
+++ b/FreeRTOS/Source/queue.c
@@ -0,0 +1,1743 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+#include <stdlib.h>

+#include <string.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "static-allocator.h"

+

+#if ( configUSE_CO_ROUTINES == 1 )

+	#include "croutine.h"

+#endif

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/*-----------------------------------------------------------

+ * PUBLIC LIST API documented in list.h

+ *----------------------------------------------------------*/

+

+/* Constants used with the cRxLock and xTxLock structure members. */

+#define queueUNLOCKED					( ( signed portBASE_TYPE ) -1 )

+#define queueLOCKED_UNMODIFIED			( ( signed portBASE_TYPE ) 0 )

+

+#define queueERRONEOUS_UNBLOCK			( -1 )

+

+/* For internal use only. */

+#define	queueSEND_TO_BACK				( 0 )

+#define	queueSEND_TO_FRONT				( 1 )

+

+/* Effectively make a union out of the xQUEUE structure. */

+#define pxMutexHolder					pcTail

+#define uxQueueType						pcHead

+#define uxRecursiveCallCount			pcReadFrom

+#define queueQUEUE_IS_MUTEX				NULL

+

+/* Semaphores do not actually store or copy data, so have an items size of

+zero. */

+#define queueSEMAPHORE_QUEUE_ITEM_LENGTH ( ( unsigned portBASE_TYPE ) 0 )

+#define queueDONT_BLOCK					 ( ( portTickType ) 0U )

+#define queueMUTEX_GIVE_BLOCK_TIME		 ( ( portTickType ) 0U )

+

+/* These definitions *must* match those in queue.h. */

+#define queueQUEUE_TYPE_BASE				( 0U )

+#define queueQUEUE_TYPE_MUTEX 				( 1U )

+#define queueQUEUE_TYPE_COUNTING_SEMAPHORE	( 2U )

+#define queueQUEUE_TYPE_BINARY_SEMAPHORE	( 3U )

+#define queueQUEUE_TYPE_RECURSIVE_MUTEX		( 4U )

+

+/*

+ * Definition of the queue used by the scheduler.

+ * Items are queued by copy, not reference.

+ */

+typedef struct QueueDefinition

+{

+	signed char *pcHead;				/*< Points to the beginning of the queue storage area. */

+	signed char *pcTail;				/*< Points to the byte at the end of the queue storage area.  Once more byte is allocated than necessary to store the queue items, this is used as a marker. */

+

+	signed char *pcWriteTo;				/*< Points to the free next place in the storage area. */

+	signed char *pcReadFrom;			/*< Points to the last place that a queued item was read from. */

+

+	xList xTasksWaitingToSend;				/*< List of tasks that are blocked waiting to post onto this queue.  Stored in priority order. */

+	xList xTasksWaitingToReceive;			/*< List of tasks that are blocked waiting to read from this queue.  Stored in priority order. */

+

+	volatile unsigned portBASE_TYPE uxMessagesWaiting;/*< The number of items currently in the queue. */

+	unsigned portBASE_TYPE uxLength;		/*< The length of the queue defined as the number of items it will hold, not the number of bytes. */

+	unsigned portBASE_TYPE uxItemSize;		/*< The size of each items that the queue will hold. */

+

+	volatile signed portBASE_TYPE xRxLock;	/*< Stores the number of items received from the queue (removed from the queue) while the queue was locked.  Set to queueUNLOCKED when the queue is not locked. */

+	volatile signed portBASE_TYPE xTxLock;	/*< Stores the number of items transmitted to the queue (added to the queue) while the queue was locked.  Set to queueUNLOCKED when the queue is not locked. */

+

+    unsigned char ucQueueType;

+    

+	#if ( configUSE_TRACE_FACILITY == 1 )

+		unsigned char ucQueueNumber;

+	#endif

+

+} xQUEUE;

+/*-----------------------------------------------------------*/

+

+/*

+ * Inside this file xQueueHandle is a pointer to a xQUEUE structure.

+ * To keep the definition private the API header file defines it as a

+ * pointer to void.

+ */

+typedef xQUEUE * xQueueHandle;

+

+/*

+ * Prototypes for public functions are included here so we don't have to

+ * include the API header file (as it defines xQueueHandle differently).  These

+ * functions are documented in the API header file.

+ */

+void xInitQueues(void);

+xQueueHandle xQueueGenericCreate( void* , unsigned portBASE_TYPE uxQueueLength, unsigned portBASE_TYPE uxItemSize, unsigned char ucQueueType ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition ) PRIVILEGED_FUNCTION;

+unsigned portBASE_TYPE uxQueueMessagesWaiting( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+void vQueueDelete( xQueueHandle xQueue ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueGenericSendFromISR( xQueueHandle pxQueue, const void * const pvItemToQueue, signed portBASE_TYPE *pxHigherPriorityTaskWoken, portBASE_TYPE xCopyPosition ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueReceiveFromISR( xQueueHandle pxQueue, void * const pvBuffer, signed portBASE_TYPE *pxHigherPriorityTaskWoken ) PRIVILEGED_FUNCTION;

+xQueueHandle xQueueCreateMutex( unsigned char ucQueueType ) PRIVILEGED_FUNCTION;

+xQueueHandle xQueueCreateCountingSemaphore( unsigned portBASE_TYPE uxCountValue, unsigned portBASE_TYPE uxInitialCount ) PRIVILEGED_FUNCTION;

+portBASE_TYPE xQueueTakeMutexRecursive( xQueueHandle xMutex, portTickType xBlockTime ) PRIVILEGED_FUNCTION;

+portBASE_TYPE xQueueGiveMutexRecursive( xQueueHandle xMutex ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueAltGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueAltGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueIsQueueEmptyFromISR( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+signed portBASE_TYPE xQueueIsQueueFullFromISR( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+unsigned portBASE_TYPE uxQueueMessagesWaitingFromISR( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+void vQueueWaitForMessageRestricted( xQueueHandle pxQueue, portTickType xTicksToWait ) PRIVILEGED_FUNCTION;

+unsigned char ucQueueGetQueueNumber( xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+void vQueueSetQueueNumber( xQueueHandle pxQueue, unsigned char ucQueueNumber ) PRIVILEGED_FUNCTION;

+unsigned char ucQueueGetQueueType( xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+portBASE_TYPE xQueueGenericReset( xQueueHandle pxQueue, portBASE_TYPE xNewQueue ) PRIVILEGED_FUNCTION;

+xTaskHandle xQueueGetMutexHolder( xQueueHandle xSemaphore ) PRIVILEGED_FUNCTION;

+

+/*

+ * Co-routine queue functions differ from task queue functions.  Co-routines are

+ * an optional component.

+ */

+#if configUSE_CO_ROUTINES == 1

+	signed portBASE_TYPE xQueueCRSendFromISR( xQueueHandle pxQueue, const void *pvItemToQueue, signed portBASE_TYPE xCoRoutinePreviouslyWoken ) PRIVILEGED_FUNCTION;

+	signed portBASE_TYPE xQueueCRReceiveFromISR( xQueueHandle pxQueue, void *pvBuffer, signed portBASE_TYPE *pxTaskWoken ) PRIVILEGED_FUNCTION;

+	signed portBASE_TYPE xQueueCRSend( xQueueHandle pxQueue, const void *pvItemToQueue, portTickType xTicksToWait ) PRIVILEGED_FUNCTION;

+	signed portBASE_TYPE xQueueCRReceive( xQueueHandle pxQueue, void *pvBuffer, portTickType xTicksToWait ) PRIVILEGED_FUNCTION;

+#endif

+

+#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))

+

+#ifndef configMAX_NUM_OF_QUEUES

+#define configMAX_NUM_OF_QUEUES (64)

+#endif

+#define NUM_OF_QUEUE_FLAGS ((configMAX_NUM_OF_QUEUES+31)/32)

+static xQUEUE sNlQueues[configMAX_NUM_OF_QUEUES];

+static uint32_t sNlQueuesFlags[NUM_OF_QUEUE_FLAGS];

+static static_pool_t sQueuesPool;

+

+#if configUSE_COUNTING_SEMAPHORES == 1

+static uint8_t sNlCountingSemaphores[configMAX_COUNTING_SEMAPHORES];

+#define MAX_COUNTING_SEMAPHORES_FLAGS ((configMAX_COUNTING_SEMAPHORES+31)/32)

+static uint32_t sNlCountingSemaphoresFlags[MAX_COUNTING_SEMAPHORES_FLAGS];

+static static_pool_t sSemaphoresPool;

+xQueueHandle xSemaphoreCreateBinary(void);

+#endif

+

+// xxx

+#define semSEMAPHORE_QUEUE_ITEM_LENGTH		( ( unsigned char ) 0U )

+

+xQueueHandle xSemaphoreCreateBinary(void)

+{   

+    void* binarySema = poolAllocateBuffer(&sSemaphoresPool);

+    xQueueHandle retval = xQueueGenericCreate( binarySema, ( unsigned portBASE_TYPE ) 1, semSEMAPHORE_QUEUE_ITEM_LENGTH, queueQUEUE_TYPE_BINARY_SEMAPHORE );

+    if(retval != NULL )

+    {

+        // xSemaphoreGive

+        xQueueGenericSend( retval, 

+                           NULL,

+                           0, // block time

+                           queueSEND_TO_BACK );

+    }

+    return retval;

+}

+

+

+void xInitQueues(void)

+{

+    poolInit( &sQueuesPool,

+              sizeof(sNlQueues[0]),

+              ARRAY_SIZE(sNlQueues),

+              &sNlQueues,

+              &sNlQueuesFlags);

+

+#if configUSE_COUNTING_SEMAPHORES == 1

+    poolInit( &sSemaphoresPool,

+              sizeof(sNlCountingSemaphores[0]),

+              ARRAY_SIZE(sNlCountingSemaphores),

+              &sNlCountingSemaphores,

+              &sNlCountingSemaphoresFlags);

+#endif

+}

+

+

+/*

+ * The queue registry is just a means for kernel aware debuggers to locate

+ * queue structures.  It has no other purpose so is an optional component.

+ */

+#if configQUEUE_REGISTRY_SIZE > 0

+

+	/* The type stored within the queue registry array.  This allows a name

+	to be assigned to each queue making kernel aware debugging a little

+	more user friendly. */

+	typedef struct QUEUE_REGISTRY_ITEM

+	{

+		signed char *pcQueueName;

+		xQueueHandle xHandle;

+	} xQueueRegistryItem;

+

+	/* The queue registry is simply an array of xQueueRegistryItem structures.

+	The pcQueueName member of a structure being NULL is indicative of the

+	array position being vacant. */

+	xQueueRegistryItem xQueueRegistry[ configQUEUE_REGISTRY_SIZE ];

+

+	/* Removes a queue from the registry by simply setting the pcQueueName

+	member to NULL. */

+	static void vQueueUnregisterQueue( xQueueHandle xQueue ) PRIVILEGED_FUNCTION;

+	void vQueueAddToRegistry( xQueueHandle xQueue, signed char *pcQueueName ) PRIVILEGED_FUNCTION;

+#endif

+

+/*

+ * Unlocks a queue locked by a call to prvLockQueue.  Locking a queue does not

+ * prevent an ISR from adding or removing items to the queue, but does prevent

+ * an ISR from removing tasks from the queue event lists.  If an ISR finds a

+ * queue is locked it will instead increment the appropriate queue lock count

+ * to indicate that a task may require unblocking.  When the queue in unlocked

+ * these lock counts are inspected, and the appropriate action taken.

+ */

+static void prvUnlockQueue( xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+

+/*

+ * Uses a critical section to determine if there is any data in a queue.

+ *

+ * @return pdTRUE if the queue contains no items, otherwise pdFALSE.

+ */

+static signed portBASE_TYPE prvIsQueueEmpty( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+

+/*

+ * Uses a critical section to determine if there is any space in a queue.

+ *

+ * @return pdTRUE if there is no space, otherwise pdFALSE;

+ */

+static signed portBASE_TYPE prvIsQueueFull( const xQueueHandle pxQueue ) PRIVILEGED_FUNCTION;

+

+/*

+ * Copies an item into the queue, either at the front of the queue or the

+ * back of the queue.

+ */

+static void prvCopyDataToQueue( xQUEUE *pxQueue, const void *pvItemToQueue, portBASE_TYPE xPosition ) PRIVILEGED_FUNCTION;

+

+/*

+ * Copies an item out of a queue.

+ */

+static void prvCopyDataFromQueue( xQUEUE * const pxQueue, const void *pvBuffer ) PRIVILEGED_FUNCTION;

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro to mark a queue as locked.  Locking a queue prevents an ISR from

+ * accessing the queue event lists.

+ */

+#define prvLockQueue( pxQueue )								\

+	taskENTER_CRITICAL();									\

+	{														\

+		if( ( pxQueue )->xRxLock == queueUNLOCKED )			\

+		{													\

+			( pxQueue )->xRxLock = queueLOCKED_UNMODIFIED;	\

+		}													\

+		if( ( pxQueue )->xTxLock == queueUNLOCKED )			\

+		{													\

+			( pxQueue )->xTxLock = queueLOCKED_UNMODIFIED;	\

+		}													\

+	}														\

+	taskEXIT_CRITICAL()

+/*-----------------------------------------------------------*/

+

+

+/*-----------------------------------------------------------

+ * PUBLIC QUEUE MANAGEMENT API documented in queue.h

+ *----------------------------------------------------------*/

+

+portBASE_TYPE xQueueGenericReset( xQueueHandle pxQueue, portBASE_TYPE xNewQueue )

+{

+	configASSERT( pxQueue );

+

+	taskENTER_CRITICAL();

+	{

+		pxQueue->pcTail = pxQueue->pcHead + ( pxQueue->uxLength * pxQueue->uxItemSize );

+		pxQueue->uxMessagesWaiting = ( unsigned portBASE_TYPE ) 0U;

+		pxQueue->pcWriteTo = pxQueue->pcHead;

+		pxQueue->pcReadFrom = pxQueue->pcHead + ( ( pxQueue->uxLength - ( unsigned portBASE_TYPE ) 1U ) * pxQueue->uxItemSize );

+		pxQueue->xRxLock = queueUNLOCKED;

+		pxQueue->xTxLock = queueUNLOCKED;

+

+		if( xNewQueue == pdFALSE )

+		{

+			/* If there are tasks blocked waiting to read from the queue, then 

+			the tasks will remain blocked as after this function exits the queue 

+			will still be empty.  If there are tasks blocked waiting to	write to 

+			the queue, then one should be unblocked as after this function exits 

+			it will be possible to write to it. */

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+			{

+				if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) == pdTRUE )

+				{

+					portYIELD_WITHIN_API();

+				}

+			}

+		}

+		else

+		{

+			/* Ensure the event queues start in the correct state. */

+			vListInitialise( &( pxQueue->xTasksWaitingToSend ) );

+			vListInitialise( &( pxQueue->xTasksWaitingToReceive ) );		

+		}

+	}

+	taskEXIT_CRITICAL();

+

+	/* A value is returned for calling semantic consistency with previous

+	versions. */

+	return pdPASS;

+}

+/*-----------------------------------------------------------*/

+

+xQueueHandle xQueueGenericCreate( void* queueBuffer, 

+                                  unsigned portBASE_TYPE uxQueueLength,

+                                  unsigned portBASE_TYPE uxItemSize, 

+                                  unsigned char ucQueueType )

+{

+xQUEUE *pxNewQueue = (xQUEUE *)0xdeadbeef;

+xQueueHandle xReturn = NULL;

+

+	/* Allocate the new queue structure. */

+	if( uxQueueLength > ( unsigned portBASE_TYPE ) 0 )

+	{

+        pxNewQueue = (xQUEUE*) poolAllocateBuffer(&sQueuesPool);

+		if( pxNewQueue != NULL )

+		{

+			pxNewQueue->pcHead = ( signed char * ) queueBuffer;

+			if( pxNewQueue->pcHead != NULL )

+			{

+				/* Initialise the queue members as described above where the

+				queue type is defined. */

+				pxNewQueue->uxLength = uxQueueLength;

+				pxNewQueue->uxItemSize = uxItemSize;

+				xQueueGenericReset( pxNewQueue, pdTRUE );

+                pxNewQueue->ucQueueType = ucQueueType;

+

+				traceQUEUE_CREATE( pxNewQueue );

+				xReturn = pxNewQueue;

+			}

+			else

+			{

+				traceQUEUE_CREATE_FAILED( ucQueueType );

+				poolFreeBuffer( &sQueuesPool, pxNewQueue );

+			}

+		}

+	}

+

+	configASSERT( xReturn );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+

+	xQueueHandle xQueueCreateMutex( unsigned char ucQueueType )

+	{

+	xQUEUE *pxNewQueue;

+

+		/* Prevent compiler warnings about unused parameters if

+		configUSE_TRACE_FACILITY does not equal 1. */

+		( void ) ucQueueType;

+

+		/* Allocate the new queue structure. */

+        pxNewQueue = (xQUEUE*) poolAllocateBuffer(&sQueuesPool);

+		if( pxNewQueue != NULL )

+		{

+			/* Information required for priority inheritance. */

+			pxNewQueue->pxMutexHolder = NULL;

+			pxNewQueue->uxQueueType = queueQUEUE_IS_MUTEX;

+

+			/* Queues used as a mutex no data is actually copied into or out

+			of the queue. */

+			pxNewQueue->pcWriteTo = NULL;

+			pxNewQueue->pcReadFrom = NULL;

+

+			/* Each mutex has a length of 1 (like a binary semaphore) and

+			an item size of 0 as nothing is actually copied into or out

+			of the mutex. */

+			pxNewQueue->uxMessagesWaiting = ( unsigned portBASE_TYPE ) 0U;

+			pxNewQueue->uxLength = ( unsigned portBASE_TYPE ) 1U;

+			pxNewQueue->uxItemSize = ( unsigned portBASE_TYPE ) 0U;

+			pxNewQueue->xRxLock = queueUNLOCKED;

+			pxNewQueue->xTxLock = queueUNLOCKED;

+

+            pxNewQueue->ucQueueType = ucQueueType;

+

+			/* Ensure the event queues start with the correct state. */

+			vListInitialise( &( pxNewQueue->xTasksWaitingToSend ) );

+			vListInitialise( &( pxNewQueue->xTasksWaitingToReceive ) );

+

+			traceCREATE_MUTEX( pxNewQueue );

+

+			/* Start with the semaphore in the expected state. */

+			xQueueGenericSend( pxNewQueue, NULL, ( portTickType ) 0U, queueSEND_TO_BACK );

+		}

+		else

+		{

+			traceCREATE_MUTEX_FAILED();

+		}

+

+		configASSERT( pxNewQueue );

+		return pxNewQueue;

+	}

+

+#endif /* configUSE_MUTEXES */

+/*-----------------------------------------------------------*/

+

+#if ( ( configUSE_MUTEXES == 1 ) && ( INCLUDE_xQueueGetMutexHolder == 1 ) )

+

+	void* xQueueGetMutexHolder( xQueueHandle xSemaphore )

+	{

+	void *pxReturn;

+

+		/* This function is called by xSemaphoreGetMutexHolder(), and should not

+		be called directly.  Note:  This is is a good way of determining if the

+		calling task is the mutex holder, but not a good way of determining the

+		identity of the mutex holder, as the holder may change between the 

+		following critical section exiting and the function returning. */

+		taskENTER_CRITICAL();

+		{

+			if( xSemaphore->uxQueueType == queueQUEUE_IS_MUTEX )

+			{

+				pxReturn = ( void * ) xSemaphore->pxMutexHolder;

+			}

+			else

+			{

+				pxReturn = NULL;

+			}

+		}

+		taskEXIT_CRITICAL();

+		

+		return pxReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_RECURSIVE_MUTEXES == 1 )

+

+	portBASE_TYPE xQueueGiveMutexRecursive( xQueueHandle pxMutex )

+	{

+	portBASE_TYPE xReturn;

+

+		configASSERT( pxMutex );

+

+		/* If this is the task that holds the mutex then pxMutexHolder will not

+		change outside of this task.  If this task does not hold the mutex then

+		pxMutexHolder can never coincidentally equal the tasks handle, and as

+		this is the only condition we are interested in it does not matter if

+		pxMutexHolder is accessed simultaneously by another task.  Therefore no

+		mutual exclusion is required to test the pxMutexHolder variable. */

+		if( pxMutex->pxMutexHolder == xTaskGetCurrentTaskHandle() )

+		{

+			traceGIVE_MUTEX_RECURSIVE( pxMutex );

+

+			/* uxRecursiveCallCount cannot be zero if pxMutexHolder is equal to

+			the task handle, therefore no underflow check is required.  Also,

+			uxRecursiveCallCount is only modified by the mutex holder, and as

+			there can only be one, no mutual exclusion is required to modify the

+			uxRecursiveCallCount member. */

+

+            /* 

+            ( pxMutex->uxRecursiveCallCount )--;

+            if( pxMutex->uxRecursiveCallCount == 0 )

+            Here we use uxRecursiveCallCount(which is a pointer) as integer, the compiler

+            will assume it would never be NULL when we do ++/--, hence the if statement was 

+            always optimized out. We force cast to int to work around this.*/

+			unsigned portBASE_TYPE tmp = (unsigned portBASE_TYPE) (pxMutex->uxRecursiveCallCount);

+			tmp -= sizeof(*pxMutex->uxRecursiveCallCount);

+            pxMutex->uxRecursiveCallCount = (signed char*) tmp;

+			/* Have we unwound the call count? */

+			if( tmp == 0 )

+			{

+				/* Return the mutex.  This will automatically unblock any other

+				task that might be waiting to access the mutex. */

+				xQueueGenericSend( pxMutex, NULL, queueMUTEX_GIVE_BLOCK_TIME, queueSEND_TO_BACK );

+			}

+            

+

+			xReturn = pdPASS;

+		}

+		else

+		{

+			/* We cannot give the mutex because we are not the holder. */

+			xReturn = pdFAIL;

+

+			traceGIVE_MUTEX_RECURSIVE_FAILED( pxMutex );

+		}

+

+		return xReturn;

+	}

+

+#endif /* configUSE_RECURSIVE_MUTEXES */

+/*-----------------------------------------------------------*/

+

+#if configUSE_RECURSIVE_MUTEXES == 1

+

+	portBASE_TYPE xQueueTakeMutexRecursive( xQueueHandle pxMutex, portTickType xBlockTime )

+	{

+	portBASE_TYPE xReturn;

+

+		configASSERT( pxMutex );

+

+		/* Comments regarding mutual exclusion as per those within

+		xQueueGiveMutexRecursive(). */

+

+		traceTAKE_MUTEX_RECURSIVE( pxMutex );

+

+		if( pxMutex->pxMutexHolder == xTaskGetCurrentTaskHandle() )

+		{

+			( pxMutex->uxRecursiveCallCount )++;

+			xReturn = pdPASS;

+		}

+		else

+		{

+			xReturn = xQueueGenericReceive( pxMutex, NULL, xBlockTime, pdFALSE );

+

+			/* pdPASS will only be returned if we successfully obtained the mutex,

+			we may have blocked to reach here. */

+			if( xReturn == pdPASS )

+			{

+				( pxMutex->uxRecursiveCallCount )++;

+			}

+			else

+			{

+				traceTAKE_MUTEX_RECURSIVE_FAILED( pxMutex );

+			}

+		}

+

+		return xReturn;

+	}

+

+#endif /* configUSE_RECURSIVE_MUTEXES */

+/*-----------------------------------------------------------*/

+

+#if configUSE_COUNTING_SEMAPHORES == 1

+

+xQueueHandle xQueueCreateCountingSemaphore( unsigned portBASE_TYPE uxCountValue, unsigned portBASE_TYPE uxInitialCount )

+	{

+	xQueueHandle pxHandle;

+

+        void* semaBackingStore = poolAllocateBuffer(&sSemaphoresPool);

+		configASSERT( semaBackingStore );

+

+        pxHandle = xQueueGenericCreate( semaBackingStore, ( unsigned portBASE_TYPE ) uxCountValue, queueSEMAPHORE_QUEUE_ITEM_LENGTH, queueQUEUE_TYPE_COUNTING_SEMAPHORE );

+

+		if( pxHandle != NULL )

+		{

+			pxHandle->uxMessagesWaiting = uxInitialCount;

+

+			traceCREATE_COUNTING_SEMAPHORE();

+		}

+		else

+		{

+			traceCREATE_COUNTING_SEMAPHORE_FAILED();

+		}

+

+		configASSERT( pxHandle );

+		return pxHandle;

+	}

+

+#endif /* configUSE_COUNTING_SEMAPHORES */

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition )

+{

+signed portBASE_TYPE xEntryTimeSet = pdFALSE;

+xTimeOutType xTimeOut;

+

+	configASSERT( pxQueue );

+	configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+	/* This function relaxes the coding standard somewhat to allow return

+	statements within the function itself.  This is done in the interest

+	of execution time efficiency. */

+	for( ;; )

+	{

+		taskENTER_CRITICAL();

+		{

+			/* Is there room on the queue now?  To be running we must be

+			the highest priority task wanting to access the queue. */

+			if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

+			{

+				traceQUEUE_SEND( pxQueue );

+				prvCopyDataToQueue( pxQueue, pvItemToQueue, xCopyPosition );

+

+				/* If there was a task waiting for data to arrive on the

+				queue then unblock it now. */

+				if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+				{

+					if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) == pdTRUE )

+					{

+						/* The unblocked task has a priority higher than

+						our own so yield immediately.  Yes it is ok to do

+						this from within the critical section - the kernel

+						takes care of that. */

+						portYIELD_WITHIN_API();

+					}

+				}

+

+				taskEXIT_CRITICAL();

+

+				/* Return to the original privilege level before exiting the

+				function. */

+				return pdPASS;

+			}

+			else

+			{

+				if( xTicksToWait == ( portTickType ) 0 )

+				{

+					/* The queue was full and no block time is specified (or

+					the block time has expired) so leave now. */

+					taskEXIT_CRITICAL();

+

+					/* Return to the original privilege level before exiting

+					the function. */

+					traceQUEUE_SEND_FAILED( pxQueue );

+					return errQUEUE_FULL;

+				}

+				else if( xEntryTimeSet == pdFALSE )

+				{

+					/* The queue was full and a block time was specified so

+					configure the timeout structure. */

+					vTaskSetTimeOutState( &xTimeOut );

+					xEntryTimeSet = pdTRUE;

+				}

+			}

+		}

+		taskEXIT_CRITICAL();

+

+		/* Interrupts and other tasks can send to and receive from the queue

+		now the critical section has been exited. */

+

+		vTaskSuspendAll();

+		prvLockQueue( pxQueue );

+

+		/* Update the timeout state to see if it has expired yet. */

+		if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )

+		{

+			if( prvIsQueueFull( pxQueue ) != pdFALSE )

+			{

+				traceBLOCKING_ON_QUEUE_SEND( pxQueue );

+				vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToSend ), xTicksToWait );

+

+				/* Unlocking the queue means queue events can effect the

+				event list.  It is possible	that interrupts occurring now

+				remove this task from the event	list again - but as the

+				scheduler is suspended the task will go onto the pending

+				ready last instead of the actual ready list. */

+				prvUnlockQueue( pxQueue );

+

+				/* Resuming the scheduler will move tasks from the pending

+				ready list into the ready list - so it is feasible that this

+				task is already in a ready list before it yields - in which

+				case the yield will not cause a context switch unless there

+				is also a higher priority task in the pending ready list. */

+				if( xTaskResumeAll() == pdFALSE )

+				{

+					portYIELD_WITHIN_API();

+				}

+			}

+			else

+			{

+				/* Try again. */

+				prvUnlockQueue( pxQueue );

+				( void ) xTaskResumeAll();

+			}

+		}

+		else

+		{

+			/* The timeout has expired. */

+			prvUnlockQueue( pxQueue );

+			( void ) xTaskResumeAll();

+

+			/* Return to the original privilege level before exiting the

+			function. */

+			traceQUEUE_SEND_FAILED( pxQueue );

+			return errQUEUE_FULL;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_ALTERNATIVE_API == 1

+

+	signed portBASE_TYPE xQueueAltGenericSend( xQueueHandle pxQueue, const void * const pvItemToQueue, portTickType xTicksToWait, portBASE_TYPE xCopyPosition )

+	{

+	signed portBASE_TYPE xEntryTimeSet = pdFALSE;

+	xTimeOutType xTimeOut;

+

+		configASSERT( pxQueue );

+		configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+		for( ;; )

+		{

+			taskENTER_CRITICAL();

+			{

+				/* Is there room on the queue now?  To be running we must be

+				the highest priority task wanting to access the queue. */

+				if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

+				{

+					traceQUEUE_SEND( pxQueue );

+					prvCopyDataToQueue( pxQueue, pvItemToQueue, xCopyPosition );

+

+					/* If there was a task waiting for data to arrive on the

+					queue then unblock it now. */

+					if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+					{

+						if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) == pdTRUE )

+						{

+							/* The unblocked task has a priority higher than

+							our own so yield immediately. */

+							portYIELD_WITHIN_API();

+						}

+					}

+

+					taskEXIT_CRITICAL();

+					return pdPASS;

+				}

+				else

+				{

+					if( xTicksToWait == ( portTickType ) 0 )

+					{

+						taskEXIT_CRITICAL();

+						return errQUEUE_FULL;

+					}

+					else if( xEntryTimeSet == pdFALSE )

+					{

+						vTaskSetTimeOutState( &xTimeOut );

+						xEntryTimeSet = pdTRUE;

+					}

+				}

+			}

+			taskEXIT_CRITICAL();

+

+			taskENTER_CRITICAL();

+			{

+				if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )

+				{

+					if( prvIsQueueFull( pxQueue ) != pdFALSE )

+					{

+						traceBLOCKING_ON_QUEUE_SEND( pxQueue );

+						vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToSend ), xTicksToWait );

+						portYIELD_WITHIN_API();

+					}

+				}

+				else

+				{

+					taskEXIT_CRITICAL();

+					traceQUEUE_SEND_FAILED( pxQueue );

+					return errQUEUE_FULL;

+				}

+			}

+			taskEXIT_CRITICAL();

+		}

+	}

+

+#endif /* configUSE_ALTERNATIVE_API */

+/*-----------------------------------------------------------*/

+

+#if configUSE_ALTERNATIVE_API == 1

+

+	signed portBASE_TYPE xQueueAltGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking )

+	{

+	signed portBASE_TYPE xEntryTimeSet = pdFALSE;

+	xTimeOutType xTimeOut;

+	signed char *pcOriginalReadPosition;

+

+		configASSERT( pxQueue );

+		configASSERT( !( ( pvBuffer == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+		for( ;; )

+		{

+			taskENTER_CRITICAL();

+			{

+				if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

+				{

+					/* Remember our read position in case we are just peeking. */

+					pcOriginalReadPosition = pxQueue->pcReadFrom;

+

+					prvCopyDataFromQueue( pxQueue, pvBuffer );

+

+					if( xJustPeeking == pdFALSE )

+					{

+						traceQUEUE_RECEIVE( pxQueue );

+

+						/* We are actually removing data. */

+						--( pxQueue->uxMessagesWaiting );

+

+						#if ( configUSE_MUTEXES == 1 )

+						{

+							if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )

+							{

+								/* Record the information required to implement

+								priority inheritance should it become necessary. */

+								pxQueue->pxMutexHolder = xTaskGetCurrentTaskHandle();

+							}

+						}

+						#endif

+

+						if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+						{

+							if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) == pdTRUE )

+							{

+								portYIELD_WITHIN_API();

+							}

+						}

+					}

+					else

+					{

+						traceQUEUE_PEEK( pxQueue );

+

+						/* We are not removing the data, so reset our read

+						pointer. */

+						pxQueue->pcReadFrom = pcOriginalReadPosition;

+

+						/* The data is being left in the queue, so see if there are

+						any other tasks waiting for the data. */

+						if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+						{

+							/* Tasks that are removed from the event list will get added to

+							the pending ready list as the scheduler is still suspended. */

+							if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+							{

+								/* The task waiting has a higher priority than this task. */

+								portYIELD_WITHIN_API();

+							}

+						}

+

+					}

+

+					taskEXIT_CRITICAL();

+					return pdPASS;

+				}

+				else

+				{

+					if( xTicksToWait == ( portTickType ) 0 )

+					{

+						taskEXIT_CRITICAL();

+						traceQUEUE_RECEIVE_FAILED( pxQueue );

+						return errQUEUE_EMPTY;

+					}

+					else if( xEntryTimeSet == pdFALSE )

+					{

+						vTaskSetTimeOutState( &xTimeOut );

+						xEntryTimeSet = pdTRUE;

+					}

+				}

+			}

+			taskEXIT_CRITICAL();

+

+			taskENTER_CRITICAL();

+			{

+				if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )

+				{

+					if( prvIsQueueEmpty( pxQueue ) != pdFALSE )

+					{

+						traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue );

+

+						#if ( configUSE_MUTEXES == 1 )

+						{

+							if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )

+							{

+								portENTER_CRITICAL();

+									vTaskPriorityInherit( ( void * ) pxQueue->pxMutexHolder );

+								portEXIT_CRITICAL();

+							}

+						}

+						#endif

+

+						vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToReceive ), xTicksToWait );

+						portYIELD_WITHIN_API();

+					}

+				}

+				else

+				{

+					taskEXIT_CRITICAL();

+					traceQUEUE_RECEIVE_FAILED( pxQueue );

+					return errQUEUE_EMPTY;

+				}

+			}

+			taskEXIT_CRITICAL();

+		}

+	}

+

+

+#endif /* configUSE_ALTERNATIVE_API */

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueGenericSendFromISR( xQueueHandle pxQueue, const void * const pvItemToQueue, signed portBASE_TYPE *pxHigherPriorityTaskWoken, portBASE_TYPE xCopyPosition )

+{

+signed portBASE_TYPE xReturn;

+unsigned portBASE_TYPE uxSavedInterruptStatus;

+

+	configASSERT( pxQueue );

+	configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+	/* Similar to xQueueGenericSend, except we don't block if there is no room

+	in the queue.  Also we don't directly wake a task that was blocked on a

+	queue read, instead we return a flag to say whether a context switch is

+	required or not (i.e. has a task with a higher priority than us been woken

+	by this	post). */

+	uxSavedInterruptStatus = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

+		{

+			traceQUEUE_SEND_FROM_ISR( pxQueue );

+

+			prvCopyDataToQueue( pxQueue, pvItemToQueue, xCopyPosition );

+

+			/* If the queue is locked we do not alter the event list.  This will

+			be done when the queue is unlocked later. */

+			if( pxQueue->xTxLock == queueUNLOCKED )

+			{

+				if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+				{

+					if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+					{

+						/* The task waiting has a higher priority so record that a

+						context	switch is required. */

+						if( pxHigherPriorityTaskWoken != NULL )

+						{

+							*pxHigherPriorityTaskWoken = pdTRUE;

+						}

+					}

+				}

+			}

+			else

+			{

+				/* Increment the lock count so the task that unlocks the queue

+				knows that data was posted while it was locked. */

+				++( pxQueue->xTxLock );

+			}

+

+			xReturn = pdPASS;

+		}

+		else

+		{

+			traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue );

+			xReturn = errQUEUE_FULL;

+		}

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueGenericReceive( xQueueHandle pxQueue, void * const pvBuffer, portTickType xTicksToWait, portBASE_TYPE xJustPeeking )

+{

+signed portBASE_TYPE xEntryTimeSet = pdFALSE;

+xTimeOutType xTimeOut;

+signed char *pcOriginalReadPosition;

+

+	configASSERT( pxQueue );

+	configASSERT( !( ( pvBuffer == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+	/* This function relaxes the coding standard somewhat to allow return

+	statements within the function itself.  This is done in the interest

+	of execution time efficiency. */

+

+	for( ;; )

+	{

+		taskENTER_CRITICAL();

+		{

+			/* Is there data in the queue now?  To be running we must be

+			the highest priority task wanting to access the queue. */

+			if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

+			{

+				/* Remember our read position in case we are just peeking. */

+				pcOriginalReadPosition = pxQueue->pcReadFrom;

+

+				prvCopyDataFromQueue( pxQueue, pvBuffer );

+

+				if( xJustPeeking == pdFALSE )

+				{

+					traceQUEUE_RECEIVE( pxQueue );

+

+					/* We are actually removing data. */

+					--( pxQueue->uxMessagesWaiting );

+

+					#if ( configUSE_MUTEXES == 1 )

+					{

+						if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )

+						{

+							/* Record the information required to implement

+							priority inheritance should it become necessary. */

+							pxQueue->pxMutexHolder = xTaskGetCurrentTaskHandle();

+						}

+					}

+					#endif

+

+					if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+					{

+						if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) == pdTRUE )

+						{

+							portYIELD_WITHIN_API();

+						}

+					}

+				}

+				else

+				{

+					traceQUEUE_PEEK( pxQueue );

+

+					/* We are not removing the data, so reset our read

+					pointer. */

+					pxQueue->pcReadFrom = pcOriginalReadPosition;

+

+					/* The data is being left in the queue, so see if there are

+					any other tasks waiting for the data. */

+					if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+					{

+						/* Tasks that are removed from the event list will get added to

+						the pending ready list as the scheduler is still suspended. */

+						if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+						{

+							/* The task waiting has a higher priority than this task. */

+							portYIELD_WITHIN_API();

+						}

+					}

+				}

+

+				taskEXIT_CRITICAL();

+				return pdPASS;

+			}

+			else

+			{

+				if( xTicksToWait == ( portTickType ) 0 )

+				{

+					/* The queue was empty and no block time is specified (or

+					the block time has expired) so leave now. */

+					taskEXIT_CRITICAL();

+					traceQUEUE_RECEIVE_FAILED( pxQueue );

+					return errQUEUE_EMPTY;

+				}

+				else if( xEntryTimeSet == pdFALSE )

+				{

+					/* The queue was empty and a block time was specified so

+					configure the timeout structure. */

+					vTaskSetTimeOutState( &xTimeOut );

+					xEntryTimeSet = pdTRUE;

+				}

+			}

+		}

+		taskEXIT_CRITICAL();

+

+		/* Interrupts and other tasks can send to and receive from the queue

+		now the critical section has been exited. */

+

+		vTaskSuspendAll();

+		prvLockQueue( pxQueue );

+

+		/* Update the timeout state to see if it has expired yet. */

+		if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )

+		{

+			if( prvIsQueueEmpty( pxQueue ) != pdFALSE )

+			{

+				traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue );

+

+				#if ( configUSE_MUTEXES == 1 )

+				{

+					if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )

+					{

+						portENTER_CRITICAL();

+						{

+							vTaskPriorityInherit( ( void * ) pxQueue->pxMutexHolder );

+						}

+						portEXIT_CRITICAL();

+					}

+				}

+				#endif

+

+				vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToReceive ), xTicksToWait );

+				prvUnlockQueue( pxQueue );

+				if( xTaskResumeAll() == pdFALSE )

+				{

+					portYIELD_WITHIN_API();

+				}

+			}

+			else

+			{

+				/* Try again. */

+				prvUnlockQueue( pxQueue );

+				( void ) xTaskResumeAll();

+			}

+		}

+		else

+		{

+			prvUnlockQueue( pxQueue );

+			( void ) xTaskResumeAll();

+			traceQUEUE_RECEIVE_FAILED( pxQueue );

+			return errQUEUE_EMPTY;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueReceiveFromISR( xQueueHandle pxQueue, void * const pvBuffer, signed portBASE_TYPE *pxHigherPriorityTaskWoken )

+{

+signed portBASE_TYPE xReturn;

+unsigned portBASE_TYPE uxSavedInterruptStatus;

+

+	configASSERT( pxQueue );

+	configASSERT( !( ( pvBuffer == NULL ) && ( pxQueue->uxItemSize != ( unsigned portBASE_TYPE ) 0U ) ) );

+

+	uxSavedInterruptStatus = portSET_INTERRUPT_MASK_FROM_ISR();

+	{

+		/* We cannot block from an ISR, so check there is data available. */

+		if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

+		{

+			traceQUEUE_RECEIVE_FROM_ISR( pxQueue );

+

+			prvCopyDataFromQueue( pxQueue, pvBuffer );

+			--( pxQueue->uxMessagesWaiting );

+

+			/* If the queue is locked we will not modify the event list.  Instead

+			we update the lock count so the task that unlocks the queue will know

+			that an ISR has removed data while the queue was locked. */

+			if( pxQueue->xRxLock == queueUNLOCKED )

+			{

+				if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+				{

+					if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

+					{

+						/* The task waiting has a higher priority than us so

+						force a context switch. */

+						if( pxHigherPriorityTaskWoken != NULL )

+						{

+							*pxHigherPriorityTaskWoken = pdTRUE;

+						}

+					}

+				}

+			}

+			else

+			{

+				/* Increment the lock count so the task that unlocks the queue

+				knows that data was removed while it was locked. */

+				++( pxQueue->xRxLock );

+			}

+

+			xReturn = pdPASS;

+		}

+		else

+		{

+			xReturn = pdFAIL;

+			traceQUEUE_RECEIVE_FROM_ISR_FAILED( pxQueue );

+		}

+	}

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE uxQueueMessagesWaiting( const xQueueHandle pxQueue )

+{

+unsigned portBASE_TYPE uxReturn;

+

+	configASSERT( pxQueue );

+

+	taskENTER_CRITICAL();

+		uxReturn = pxQueue->uxMessagesWaiting;

+	taskEXIT_CRITICAL();

+

+	return uxReturn;

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE uxQueueMessagesWaitingFromISR( const xQueueHandle pxQueue )

+{

+unsigned portBASE_TYPE uxReturn;

+

+	configASSERT( pxQueue );

+

+	uxReturn = pxQueue->uxMessagesWaiting;

+

+	return uxReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vQueueDelete( xQueueHandle pxQueue )

+{

+	configASSERT( pxQueue );

+

+	traceQUEUE_DELETE( pxQueue );

+	vQueueUnregisterQueue( pxQueue );

+    if((pxQueue->ucQueueType == queueQUEUE_TYPE_BINARY_SEMAPHORE)

+       || (pxQueue->ucQueueType == queueQUEUE_TYPE_COUNTING_SEMAPHORE))

+    {

+        poolFreeBuffer( &sSemaphoresPool, pxQueue->pcHead);

+    }

+	poolFreeBuffer( &sQueuesPool, pxQueue );

+}

+

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+	unsigned char ucQueueGetQueueNumber( xQueueHandle pxQueue )

+	{

+		return pxQueue->ucQueueNumber;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+	void vQueueSetQueueNumber( xQueueHandle pxQueue, unsigned char ucQueueNumber )

+	{

+		pxQueue->ucQueueNumber = ucQueueNumber;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+	unsigned char ucQueueGetQueueType( xQueueHandle pxQueue )

+	{

+		return pxQueue->ucQueueType;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+static void prvCopyDataToQueue( xQUEUE *pxQueue, const void *pvItemToQueue, portBASE_TYPE xPosition )

+{

+	if( pxQueue->uxItemSize == ( unsigned portBASE_TYPE ) 0 )

+	{

+		#if ( configUSE_MUTEXES == 1 )

+		{

+			if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )

+			{

+				/* The mutex is no longer being held. */

+				vTaskPriorityDisinherit( ( void * ) pxQueue->pxMutexHolder );

+				pxQueue->pxMutexHolder = NULL;

+			}

+		}

+		#endif

+	}

+	else if( xPosition == queueSEND_TO_BACK )

+	{

+		memcpy( ( void * ) pxQueue->pcWriteTo, pvItemToQueue, ( unsigned ) pxQueue->uxItemSize );

+		pxQueue->pcWriteTo += pxQueue->uxItemSize;

+		if( pxQueue->pcWriteTo >= pxQueue->pcTail )

+		{

+			pxQueue->pcWriteTo = pxQueue->pcHead;

+		}

+	}

+	else

+	{

+		memcpy( ( void * ) pxQueue->pcReadFrom, pvItemToQueue, ( unsigned ) pxQueue->uxItemSize );

+		pxQueue->pcReadFrom -= pxQueue->uxItemSize;

+		if( pxQueue->pcReadFrom < pxQueue->pcHead )

+		{

+			pxQueue->pcReadFrom = ( pxQueue->pcTail - pxQueue->uxItemSize );

+		}

+	}

+

+	++( pxQueue->uxMessagesWaiting );

+}

+/*-----------------------------------------------------------*/

+

+static void prvCopyDataFromQueue( xQUEUE * const pxQueue, const void *pvBuffer )

+{

+	if( pxQueue->uxQueueType != queueQUEUE_IS_MUTEX )

+	{

+		pxQueue->pcReadFrom += pxQueue->uxItemSize;

+		if( pxQueue->pcReadFrom >= pxQueue->pcTail )

+		{

+			pxQueue->pcReadFrom = pxQueue->pcHead;

+		}

+		memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->pcReadFrom, ( unsigned ) pxQueue->uxItemSize );

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvUnlockQueue( xQueueHandle pxQueue )

+{

+	/* THIS FUNCTION MUST BE CALLED WITH THE SCHEDULER SUSPENDED. */

+

+	/* The lock counts contains the number of extra data items placed or

+	removed from the queue while the queue was locked.  When a queue is

+	locked items can be added or removed, but the event lists cannot be

+	updated. */

+	taskENTER_CRITICAL();

+	{

+		/* See if data was added to the queue while it was locked. */

+		while( pxQueue->xTxLock > queueLOCKED_UNMODIFIED )

+		{

+			/* Data was posted while the queue was locked.  Are any tasks

+			blocked waiting for data to become available? */

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+			{

+				/* Tasks that are removed from the event list will get added to

+				the pending ready list as the scheduler is still suspended. */

+				if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+				{

+					/* The task waiting has a higher priority so record that a

+					context	switch is required. */

+					vTaskMissedYield();

+				}

+

+				--( pxQueue->xTxLock );

+			}

+			else

+			{

+				break;

+			}

+		}

+

+		pxQueue->xTxLock = queueUNLOCKED;

+	}

+	taskEXIT_CRITICAL();

+

+	/* Do the same for the Rx lock. */

+	taskENTER_CRITICAL();

+	{

+		while( pxQueue->xRxLock > queueLOCKED_UNMODIFIED )

+		{

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+			{

+				if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

+				{

+					vTaskMissedYield();

+				}

+

+				--( pxQueue->xRxLock );

+			}

+			else

+			{

+				break;

+			}

+		}

+

+		pxQueue->xRxLock = queueUNLOCKED;

+	}

+	taskEXIT_CRITICAL();

+}

+/*-----------------------------------------------------------*/

+

+static signed portBASE_TYPE prvIsQueueEmpty( const xQueueHandle pxQueue )

+{

+signed portBASE_TYPE xReturn;

+

+	taskENTER_CRITICAL();

+		xReturn = ( pxQueue->uxMessagesWaiting == ( unsigned portBASE_TYPE ) 0 );

+	taskEXIT_CRITICAL();

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueIsQueueEmptyFromISR( const xQueueHandle pxQueue )

+{

+signed portBASE_TYPE xReturn;

+

+	configASSERT( pxQueue );

+	xReturn = ( pxQueue->uxMessagesWaiting == ( unsigned portBASE_TYPE ) 0 );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+static signed portBASE_TYPE prvIsQueueFull( const xQueueHandle pxQueue )

+{

+signed portBASE_TYPE xReturn;

+

+	taskENTER_CRITICAL();

+		xReturn = ( pxQueue->uxMessagesWaiting == pxQueue->uxLength );

+	taskEXIT_CRITICAL();

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xQueueIsQueueFullFromISR( const xQueueHandle pxQueue )

+{

+signed portBASE_TYPE xReturn;

+

+	configASSERT( pxQueue );

+	xReturn = ( pxQueue->uxMessagesWaiting == pxQueue->uxLength );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_CO_ROUTINES == 1

+signed portBASE_TYPE xQueueCRSend( xQueueHandle pxQueue, const void *pvItemToQueue, portTickType xTicksToWait )

+{

+signed portBASE_TYPE xReturn;

+

+	/* If the queue is already full we may have to block.  A critical section

+	is required to prevent an interrupt removing something from the queue

+	between the check to see if the queue is full and blocking on the queue. */

+	portDISABLE_INTERRUPTS();

+	{

+		if( prvIsQueueFull( pxQueue ) != pdFALSE )

+		{

+			/* The queue is full - do we want to block or just leave without

+			posting? */

+			if( xTicksToWait > ( portTickType ) 0 )

+			{

+				/* As this is called from a coroutine we cannot block directly, but

+				return indicating that we need to block. */

+				vCoRoutineAddToDelayedList( xTicksToWait, &( pxQueue->xTasksWaitingToSend ) );

+				portENABLE_INTERRUPTS();

+				return errQUEUE_BLOCKED;

+			}

+			else

+			{

+				portENABLE_INTERRUPTS();

+				return errQUEUE_FULL;

+			}

+		}

+	}

+	portENABLE_INTERRUPTS();

+

+	portNOP();

+

+	portDISABLE_INTERRUPTS();

+	{

+		if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

+		{

+			/* There is room in the queue, copy the data into the queue. */

+			prvCopyDataToQueue( pxQueue, pvItemToQueue, queueSEND_TO_BACK );

+			xReturn = pdPASS;

+

+			/* Were any co-routines waiting for data to become available? */

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+			{

+				/* In this instance the co-routine could be placed directly

+				into the ready list as we are within a critical section.

+				Instead the same pending ready list mechanism is used as if

+				the event were caused from within an interrupt. */

+				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+				{

+					/* The co-routine waiting has a higher priority so record

+					that a yield might be appropriate. */

+					xReturn = errQUEUE_YIELD;

+				}

+			}

+		}

+		else

+		{

+			xReturn = errQUEUE_FULL;

+		}

+	}

+	portENABLE_INTERRUPTS();

+

+	return xReturn;

+}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_CO_ROUTINES == 1

+signed portBASE_TYPE xQueueCRReceive( xQueueHandle pxQueue, void *pvBuffer, portTickType xTicksToWait )

+{

+signed portBASE_TYPE xReturn;

+

+	/* If the queue is already empty we may have to block.  A critical section

+	is required to prevent an interrupt adding something to the queue

+	between the check to see if the queue is empty and blocking on the queue. */

+	portDISABLE_INTERRUPTS();

+	{

+		if( pxQueue->uxMessagesWaiting == ( unsigned portBASE_TYPE ) 0 )

+		{

+			/* There are no messages in the queue, do we want to block or just

+			leave with nothing? */

+			if( xTicksToWait > ( portTickType ) 0 )

+			{

+				/* As this is a co-routine we cannot block directly, but return

+				indicating that we need to block. */

+				vCoRoutineAddToDelayedList( xTicksToWait, &( pxQueue->xTasksWaitingToReceive ) );

+				portENABLE_INTERRUPTS();

+				return errQUEUE_BLOCKED;

+			}

+			else

+			{

+				portENABLE_INTERRUPTS();

+				return errQUEUE_FULL;

+			}

+		}

+	}

+	portENABLE_INTERRUPTS();

+

+	portNOP();

+

+	portDISABLE_INTERRUPTS();

+	{

+		if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

+		{

+			/* Data is available from the queue. */

+			pxQueue->pcReadFrom += pxQueue->uxItemSize;

+			if( pxQueue->pcReadFrom >= pxQueue->pcTail )

+			{

+				pxQueue->pcReadFrom = pxQueue->pcHead;

+			}

+			--( pxQueue->uxMessagesWaiting );

+			memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->pcReadFrom, ( unsigned ) pxQueue->uxItemSize );

+

+			xReturn = pdPASS;

+

+			/* Were any co-routines waiting for space to become available? */

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+			{

+				/* In this instance the co-routine could be placed directly

+				into the ready list as we are within a critical section.

+				Instead the same pending ready list mechanism is used as if

+				the event were caused from within an interrupt. */

+				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

+				{

+					xReturn = errQUEUE_YIELD;

+				}

+			}

+		}

+		else

+		{

+			xReturn = pdFAIL;

+		}

+	}

+	portENABLE_INTERRUPTS();

+

+	return xReturn;

+}

+#endif

+/*-----------------------------------------------------------*/

+

+

+

+#if configUSE_CO_ROUTINES == 1

+signed portBASE_TYPE xQueueCRSendFromISR( xQueueHandle pxQueue, const void *pvItemToQueue, signed portBASE_TYPE xCoRoutinePreviouslyWoken )

+{

+	/* Cannot block within an ISR so if there is no space on the queue then

+	exit without doing anything. */

+	if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

+	{

+		prvCopyDataToQueue( pxQueue, pvItemToQueue, queueSEND_TO_BACK );

+

+		/* We only want to wake one co-routine per ISR, so check that a

+		co-routine has not already been woken. */

+		if( xCoRoutinePreviouslyWoken == pdFALSE )

+		{

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )

+			{

+				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

+				{

+					return pdTRUE;

+				}

+			}

+		}

+	}

+

+	return xCoRoutinePreviouslyWoken;

+}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_CO_ROUTINES == 1

+signed portBASE_TYPE xQueueCRReceiveFromISR( xQueueHandle pxQueue, void *pvBuffer, signed portBASE_TYPE *pxCoRoutineWoken )

+{

+signed portBASE_TYPE xReturn;

+

+	/* We cannot block from an ISR, so check there is data available. If

+	not then just leave without doing anything. */

+	if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

+	{

+		/* Copy the data from the queue. */

+		pxQueue->pcReadFrom += pxQueue->uxItemSize;

+		if( pxQueue->pcReadFrom >= pxQueue->pcTail )

+		{

+			pxQueue->pcReadFrom = pxQueue->pcHead;

+		}

+		--( pxQueue->uxMessagesWaiting );

+		memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->pcReadFrom, ( unsigned ) pxQueue->uxItemSize );

+

+		if( ( *pxCoRoutineWoken ) == pdFALSE )

+		{

+			if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )

+			{

+				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

+				{

+					*pxCoRoutineWoken = pdTRUE;

+				}

+			}

+		}

+

+		xReturn = pdPASS;

+	}

+	else

+	{

+		xReturn = pdFAIL;

+	}

+

+	return xReturn;

+}

+#endif

+/*-----------------------------------------------------------*/

+

+#if configQUEUE_REGISTRY_SIZE > 0

+

+	void vQueueAddToRegistry( xQueueHandle xQueue, signed char *pcQueueName )

+	{

+	unsigned portBASE_TYPE ux;

+

+		/* See if there is an empty space in the registry.  A NULL name denotes

+		a free slot. */

+		for( ux = ( unsigned portBASE_TYPE ) 0U; ux < ( unsigned portBASE_TYPE ) configQUEUE_REGISTRY_SIZE; ux++ )

+		{

+			if( xQueueRegistry[ ux ].pcQueueName == NULL )

+			{

+				/* Store the information on this queue. */

+				xQueueRegistry[ ux ].pcQueueName = pcQueueName;

+				xQueueRegistry[ ux ].xHandle = xQueue;

+				break;

+			}

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if configQUEUE_REGISTRY_SIZE > 0

+

+	static void vQueueUnregisterQueue( xQueueHandle xQueue )

+	{

+	unsigned portBASE_TYPE ux;

+

+		/* See if the handle of the queue being unregistered in actually in the

+		registry. */

+		for( ux = ( unsigned portBASE_TYPE ) 0U; ux < ( unsigned portBASE_TYPE ) configQUEUE_REGISTRY_SIZE; ux++ )

+		{

+			if( xQueueRegistry[ ux ].xHandle == xQueue )

+			{

+				/* Set the name to NULL to show that this slot if free again. */

+				xQueueRegistry[ ux ].pcQueueName = NULL;

+				break;

+			}

+		}

+

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if configUSE_TIMERS == 1

+

+	void vQueueWaitForMessageRestricted( xQueueHandle pxQueue, portTickType xTicksToWait )

+	{

+		/* This function should not be called by application code hence the

+		'Restricted' in its name.  It is not part of the public API.  It is

+		designed for use by kernel code, and has special calling requirements.

+		It can result in vListInsert() being called on a list that can only

+		possibly ever have one item in it, so the list will be fast, but even

+		so it should be called with the scheduler locked and not from a critical

+		section. */

+

+		/* Only do anything if there are no messages in the queue.  This function

+		will not actually cause the task to block, just place it on a blocked

+		list.  It will not block until the scheduler is unlocked - at which

+		time a yield will be performed.  If an item is added to the queue while

+		the queue is locked, and the calling task blocks on the queue, then the

+		calling task will be immediately unblocked when the queue is unlocked. */

+		prvLockQueue( pxQueue );

+		if( pxQueue->uxMessagesWaiting == ( unsigned portBASE_TYPE ) 0U )

+		{

+			/* There is nothing in the queue, block for the specified period. */

+			vTaskPlaceOnEventListRestricted( &( pxQueue->xTasksWaitingToReceive ), xTicksToWait );

+		}

+		prvUnlockQueue( pxQueue );

+	}

+

+#endif

+

diff --git a/FreeRTOS/Source/readme.txt b/FreeRTOS/Source/readme.txt
new file mode 100644
index 0000000..81518ec
--- /dev/null
+++ b/FreeRTOS/Source/readme.txt
@@ -0,0 +1,17 @@
+Each real time kernel port consists of three files that contain the core kernel

+components and are common to every port, and one or more files that are 

+specific to a particular microcontroller and or compiler.

+

++ The FreeRTOS/Source directory contains the three files that are common to 

+every port - list.c, queue.c and tasks.c.  The kernel is contained within these 

+three files.  croutine.c implements the optional co-routine functionality - which

+is normally only used on very memory limited systems.

+

++ The FreeRTOS/Source/Portable directory contains the files that are specific to 

+a particular microcontroller and or compiler.

+

++ The FreeRTOS/Source/include directory contains the real time kernel header 

+files.

+

+See the readme file in the FreeRTOS/Source/Portable directory for more 

+information.
\ No newline at end of file
diff --git a/FreeRTOS/Source/semphr.c b/FreeRTOS/Source/semphr.c
new file mode 100644
index 0000000..3604947
--- /dev/null
+++ b/FreeRTOS/Source/semphr.c
@@ -0,0 +1,3 @@
+
+#include "FreeRTOS.h"
+
diff --git a/FreeRTOS/Source/tasks.c b/FreeRTOS/Source/tasks.c
new file mode 100644
index 0000000..80e0b63
--- /dev/null
+++ b/FreeRTOS/Source/tasks.c
@@ -0,0 +1,2576 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+	

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+

+#include <stdio.h>

+#include <stdlib.h>

+#include <string.h>

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "timers.h"

+#include "StackMacros.h"

+#include "static-allocator.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/*

+ * Macro to define the amount of stack available to the idle task.

+ */

+#define tskIDLE_STACK_SIZE	(configMINIMAL_STACK_SIZE)

+portSTACK_TYPE sIdleStack[tskIDLE_STACK_SIZE];

+

+/*

+ * Task control block.  A task control block (TCB) is allocated to each task,

+ * and stores the context of the task.

+ */

+typedef struct tskTaskControlBlock

+{

+	volatile portSTACK_TYPE	*pxTopOfStack;		/*< Points to the location of the last item placed on the tasks stack.  THIS MUST BE THE FIRST MEMBER OF THE STRUCT. */

+

+	#if ( portUSING_MPU_WRAPPERS == 1 )

+		xMPU_SETTINGS xMPUSettings;				/*< The MPU settings are defined as part of the port layer.  THIS MUST BE THE SECOND MEMBER OF THE STRUCT. */

+	#endif	

+	

+	xListItem				xGenericListItem;	/*< List item used to place the TCB in ready and blocked queues. */

+	xListItem				xEventListItem;		/*< List item used to place the TCB in event lists. */

+	unsigned portBASE_TYPE	uxPriority;			/*< The priority of the task where 0 is the lowest priority. */

+	portSTACK_TYPE			*pxStack;			/*< Points to the start of the stack. */

+	signed char				pcTaskName[ configMAX_TASK_NAME_LEN ];/*< Descriptive name given to the task when created.  Facilitates debugging only. */

+

+	#if ( portSTACK_GROWTH > 0 )

+		portSTACK_TYPE *pxEndOfStack;			/*< Used for stack overflow checking on architectures where the stack grows up from low memory. */

+	#endif

+

+	#if ( portCRITICAL_NESTING_IN_TCB == 1 )

+		unsigned portBASE_TYPE uxCriticalNesting;

+	#endif

+

+	#if ( configUSE_TRACE_FACILITY == 1 )

+		unsigned portBASE_TYPE	uxTCBNumber;	/*< This stores a number that increments each time a TCB is created.  It allows debuggers to determine when a task has been deleted and then recreated. */

+		unsigned portBASE_TYPE  uxTaskNumber;	/*< This stores a number specifically for use by third party trace code. */

+	#endif

+

+	#if ( configUSE_MUTEXES == 1 )

+		unsigned portBASE_TYPE uxBasePriority;	/*< The priority last assigned to the task - used by the priority inheritance mechanism. */

+	#endif

+

+	#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+		pdTASK_HOOK_CODE pxTaskTag;

+	#endif

+

+	#if ( configGENERATE_RUN_TIME_STATS == 1 )

+		unsigned long ulRunTimeCounter;		/*< Used for calculating how much CPU time each task is utilising. */

+	#endif

+    signed char             stackIsStatic;

+

+} tskTCB;

+

+#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))

+#ifndef configMAX_NUM_OF_TASKS

+#define configMAX_NUM_OF_TASKS (32)

+#endif

+#define NUM_OF_TASKS_FLAGS ((configMAX_NUM_OF_TASKS+31)/32)

+static tskTCB sNlTCBs[configMAX_NUM_OF_TASKS];

+static uint32_t sNlTCBsFlags[NUM_OF_TASKS_FLAGS];

+static static_pool_t sTCBsPool;

+

+void xInitTCBs(void);

+

+void xInitTCBs(void)

+{

+    poolInit( &sTCBsPool,

+              sizeof(sNlTCBs[0]),

+              ARRAY_SIZE(sNlTCBs),

+              &sNlTCBs,

+              &sNlTCBsFlags);

+}

+

+/*

+ * Some kernel aware debuggers require data to be viewed to be global, rather

+ * than file scope.

+ */

+#ifdef portREMOVE_STATIC_QUALIFIER

+	#define static

+#endif

+

+/*lint -e956 */

+PRIVILEGED_DATA tskTCB * volatile pxCurrentTCB = NULL;

+

+/* Lists for ready and blocked tasks. --------------------*/

+

+PRIVILEGED_DATA xList pxReadyTasksLists[ configMAX_PRIORITIES ];	/*< Prioritised ready tasks. */

+PRIVILEGED_DATA xList xDelayedTaskList1;							/*< Delayed tasks. */

+PRIVILEGED_DATA xList xDelayedTaskList2;							/*< Delayed tasks (two lists are used - one for delays that have overflowed the current tick count. */

+PRIVILEGED_DATA xList * volatile pxDelayedTaskList ;				/*< Points to the delayed task list currently being used. */

+PRIVILEGED_DATA xList * volatile pxOverflowDelayedTaskList;		/*< Points to the delayed task list currently being used to hold tasks that have overflowed the current tick count. */

+PRIVILEGED_DATA xList xPendingReadyList;							/*< Tasks that have been readied while the scheduler was suspended.  They will be moved to the ready queue when the scheduler is resumed. */

+

+#if ( INCLUDE_vTaskDelete == 1 )

+

+	PRIVILEGED_DATA xList xTasksWaitingTermination;				/*< Tasks that have been deleted - but the their memory not yet freed. */

+	PRIVILEGED_DATA static volatile unsigned portBASE_TYPE uxTasksDeleted = ( unsigned portBASE_TYPE ) 0U;

+

+#endif

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+

+	PRIVILEGED_DATA xList xSuspendedTaskList;					/*< Tasks that are currently suspended. */

+

+#endif

+

+#if ( INCLUDE_xTaskGetIdleTaskHandle == 1 )

+	

+	PRIVILEGED_DATA static xTaskHandle xIdleTaskHandle = NULL;

+	

+#endif

+

+/* File private variables. --------------------------------*/

+PRIVILEGED_DATA volatile unsigned portBASE_TYPE uxCurrentNumberOfTasks 	= ( unsigned portBASE_TYPE ) 0U;

+PRIVILEGED_DATA static volatile portTickType xTickCount 						= ( portTickType ) 0U;

+PRIVILEGED_DATA unsigned portBASE_TYPE uxTopUsedPriority	 				= tskIDLE_PRIORITY;

+PRIVILEGED_DATA static volatile unsigned portBASE_TYPE uxTopReadyPriority 		= tskIDLE_PRIORITY;

+PRIVILEGED_DATA static volatile signed portBASE_TYPE xSchedulerRunning 			= pdFALSE;

+PRIVILEGED_DATA static volatile unsigned portBASE_TYPE uxSchedulerSuspended	 	= ( unsigned portBASE_TYPE ) pdFALSE;

+PRIVILEGED_DATA static volatile unsigned portBASE_TYPE uxMissedTicks 			= ( unsigned portBASE_TYPE ) 0U;

+PRIVILEGED_DATA static volatile portBASE_TYPE xMissedYield 						= ( portBASE_TYPE ) pdFALSE;

+PRIVILEGED_DATA static volatile portBASE_TYPE xNumOfOverflows 					= ( portBASE_TYPE ) 0;

+PRIVILEGED_DATA static unsigned portBASE_TYPE uxTaskNumber 						= ( unsigned portBASE_TYPE ) 0U;

+PRIVILEGED_DATA static portTickType xNextTaskUnblockTime						= ( portTickType ) portMAX_DELAY;

+

+#if ( configGENERATE_RUN_TIME_STATS == 1 )

+

+	PRIVILEGED_DATA static char pcStatsString[ 50 ] ;

+	PRIVILEGED_DATA static unsigned long ulTaskSwitchedInTime = 0UL;	/*< Holds the value of a timer/counter the last time a task was switched in. */

+	static void prvGenerateRunTimeStatsForTasksInList( const signed char *pcWriteBuffer, xList *pxList, unsigned long ulTotalRunTime ) PRIVILEGED_FUNCTION;

+

+#endif

+

+/* Debugging and trace facilities private variables and macros. ------------*/

+

+/*

+ * The value used to fill the stack of a task when the task is created.  This

+ * is used purely for checking the high water mark for tasks.

+ */

+#define tskSTACK_FILL_BYTE	( 0xa5U )

+

+/*

+ * Macros used by vListTask to indicate which state a task is in.

+ */

+#define tskBLOCKED_CHAR		( ( signed char ) 'B' )

+#define tskREADY_CHAR		( ( signed char ) 'R' )

+#define tskDELETED_CHAR		( ( signed char ) 'D' )

+#define tskSUSPENDED_CHAR	( ( signed char ) 'S' )

+

+/*-----------------------------------------------------------*/

+

+/*

+ * Place the task represented by pxTCB into the appropriate ready queue for

+ * the task.  It is inserted at the end of the list.  One quirk of this is

+ * that if the task being inserted is at the same priority as the currently

+ * executing task, then it will only be rescheduled after the currently

+ * executing task has been rescheduled.

+ */

+#define prvAddTaskToReadyQueue( pxTCB )																					\

+	traceMOVED_TASK_TO_READY_STATE( pxTCB )																				\

+	if( ( pxTCB )->uxPriority > uxTopReadyPriority )																	\

+	{																													\

+		uxTopReadyPriority = ( pxTCB )->uxPriority;																		\

+	}																													\

+	vListInsertEnd( ( xList * ) &( pxReadyTasksLists[ ( pxTCB )->uxPriority ] ), &( ( pxTCB )->xGenericListItem ) )

+/*-----------------------------------------------------------*/

+

+/*

+ * Macro that looks at the list of tasks that are currently delayed to see if

+ * any require waking.

+ *

+ * Tasks are stored in the queue in the order of their wake time - meaning

+ * once one tasks has been found whose timer has not expired we need not look

+ * any further down the list.

+ */

+#define prvCheckDelayedTasks()															\

+{																						\

+portTickType xItemValue;																\

+																						\

+	/* Is the tick count greater than or equal to the wake time of the first			\

+	task referenced from the delayed tasks list? */										\

+	if( xTickCount >= xNextTaskUnblockTime )											\

+	{																					\

+		for( ;; )																		\

+		{																				\

+			if( listLIST_IS_EMPTY( pxDelayedTaskList ) != pdFALSE )						\

+			{																			\

+				/* The delayed list is empty.  Set xNextTaskUnblockTime to the			\

+				maximum possible value so it is extremely unlikely that the				\

+				if( xTickCount >= xNextTaskUnblockTime ) test will pass next			\

+				time through. */														\

+				xNextTaskUnblockTime = portMAX_DELAY;									\

+				break;																	\

+			}																			\

+			else																		\

+			{																			\

+				/* The delayed list is not empty, get the value of the item at			\

+				the head of the delayed list.  This is the time at which the			\

+				task at the head of the delayed list should be removed from				\

+				the Blocked state. */													\

+				pxTCB = ( tskTCB * ) listGET_OWNER_OF_HEAD_ENTRY( pxDelayedTaskList );	\

+				xItemValue = listGET_LIST_ITEM_VALUE( &( pxTCB->xGenericListItem ) );	\

+																						\

+				if( xTickCount < xItemValue )											\

+				{																		\

+					/* It is not time to unblock this item yet, but the item			\

+					value is the time at which the task at the head of the				\

+					blocked list should be removed from the Blocked state -				\

+					so record the item value in xNextTaskUnblockTime. */				\

+					xNextTaskUnblockTime = xItemValue;									\

+					break;																\

+				}																		\

+																						\

+				/* It is time to remove the item from the Blocked state. */				\

+				vListRemove( &( pxTCB->xGenericListItem ) );							\

+																						\

+				/* Is the task waiting on an event also? */								\

+				if( pxTCB->xEventListItem.pvContainer != NULL )							\

+				{																		\

+					vListRemove( &( pxTCB->xEventListItem ) );							\

+				}																		\

+				prvAddTaskToReadyQueue( pxTCB );										\

+			}																			\

+		}																				\

+	}																					\

+}

+/*-----------------------------------------------------------*/

+

+/*

+ * Several functions take an xTaskHandle parameter that can optionally be NULL,

+ * where NULL is used to indicate that the handle of the currently executing

+ * task should be used in place of the parameter.  This macro simply checks to

+ * see if the parameter is NULL and returns a pointer to the appropriate TCB.

+ */

+#define prvGetTCBFromHandle( pxHandle ) ( ( ( pxHandle ) == NULL ) ? ( tskTCB * ) pxCurrentTCB : ( tskTCB * ) ( pxHandle ) )

+

+/* Callback function prototypes. --------------------------*/

+extern void vApplicationStackOverflowHook( xTaskHandle pxTask, signed char *pcTaskName );

+extern void vApplicationTickHook( void );

+		

+/* File private functions. --------------------------------*/

+

+/*

+ * Utility to ready a TCB for a given task.  Mainly just copies the parameters

+ * into the TCB structure.

+ */

+static void prvInitialiseTCBVariables( tskTCB *pxTCB, const signed char * const pcName, unsigned portBASE_TYPE uxPriority, const xMemoryRegion * const xRegions, unsigned short usStackDepth ) PRIVILEGED_FUNCTION;

+

+/*

+ * Utility to ready all the lists used by the scheduler.  This is called

+ * automatically upon the creation of the first task.

+ */

+static void prvInitialiseTaskLists( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * The idle task, which as all tasks is implemented as a never ending loop.

+ * The idle task is automatically created and added to the ready lists upon

+ * creation of the first user task.

+ *

+ * The portTASK_FUNCTION_PROTO() macro is used to allow port/compiler specific

+ * language extensions.  The equivalent prototype for this function is:

+ *

+ * void prvIdleTask( void *pvParameters );

+ *

+ */

+static portTASK_FUNCTION_PROTO( prvIdleTask, pvParameters );

+

+/*

+ * Utility to free all memory allocated by the scheduler to hold a TCB,

+ * including the stack pointed to by the TCB.

+ *

+ * This does not free memory allocated by the task itself (i.e. memory

+ * allocated by calls to pvPortMalloc from within the tasks application code).

+ */

+#if ( INCLUDE_vTaskDelete == 1 )

+

+	static void prvDeleteTCB( tskTCB *pxTCB ) PRIVILEGED_FUNCTION;

+

+#endif

+

+/*

+ * Used only by the idle task.  This checks to see if anything has been placed

+ * in the list of tasks waiting to be deleted.  If so the task is cleaned up

+ * and its TCB deleted.

+ */

+static void prvCheckTasksWaitingTermination( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * The currently executing task is entering the Blocked state.  Add the task to

+ * either the current or the overflow delayed task list.

+ */

+static void prvAddCurrentTaskToDelayedList( portTickType xTimeToWake ) PRIVILEGED_FUNCTION;

+

+/*

+ * Allocates memory from the heap for a TCB and associated stack.  Checks the

+ * allocation was successful.

+ */

+static tskTCB *prvAllocateTCBAndStack( unsigned short usStackDepth, portSTACK_TYPE *puxStackBuffer ) PRIVILEGED_FUNCTION;

+

+/*

+ * Called from vTaskList.  vListTasks details all the tasks currently under

+ * control of the scheduler.  The tasks may be in one of a number of lists.

+ * prvListTaskWithinSingleList accepts a list and details the tasks from

+ * within just that list.

+ *

+ * THIS FUNCTION IS INTENDED FOR DEBUGGING ONLY, AND SHOULD NOT BE CALLED FROM

+ * NORMAL APPLICATION CODE.

+ */

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+static void prvListTaskWithinSingleList( void (*pmCallback) (volatile void * pxNextTCB, signed char status), xList *pxList, signed char cStatus ) PRIVILEGED_FUNCTION;

+

+#endif

+

+/*

+ * When a task is created, the stack of the task is filled with a known value.

+ * This function determines the 'high water mark' of the task stack by

+ * determining how much of the stack remains at the original preset value.

+ */

+#if ( ( configUSE_TRACE_FACILITY == 1 ) || ( INCLUDE_uxTaskGetStackHighWaterMark == 1 ) )

+

+	static unsigned short usTaskCheckFreeStackSpace( const unsigned char * pucStackByte ) PRIVILEGED_FUNCTION;

+

+#endif

+

+

+/*lint +e956 */

+

+

+

+/*-----------------------------------------------------------

+ * TASK CREATION API documented in task.h

+ *----------------------------------------------------------*/

+

+signed portBASE_TYPE xTaskGenericCreate( pdTASK_CODE pxTaskCode, const signed char * const pcName, unsigned short usStackDepth, void *pvParameters, unsigned portBASE_TYPE uxPriority, xTaskHandle *pxCreatedTask, portSTACK_TYPE *puxStackBuffer, const xMemoryRegion * const xRegions )

+{

+signed portBASE_TYPE xReturn;

+tskTCB * pxNewTCB;

+

+	configASSERT( pxTaskCode );

+	configASSERT( ( ( uxPriority & ( ~portPRIVILEGE_BIT ) ) < configMAX_PRIORITIES ) );

+

+	/* Allocate the memory required by the TCB and stack for the new task,

+	checking that the allocation was successful. */

+	pxNewTCB = prvAllocateTCBAndStack( usStackDepth, puxStackBuffer );

+

+	if( pxNewTCB != NULL )

+	{

+		portSTACK_TYPE *pxTopOfStack;

+

+		#if( portUSING_MPU_WRAPPERS == 1 )

+			/* Should the task be created in privileged mode? */

+			portBASE_TYPE xRunPrivileged;

+			if( ( uxPriority & portPRIVILEGE_BIT ) != 0U )

+			{

+				xRunPrivileged = pdTRUE;

+			}

+			else

+			{

+				xRunPrivileged = pdFALSE;

+			}

+			uxPriority &= ~portPRIVILEGE_BIT;

+		#endif /* portUSING_MPU_WRAPPERS == 1 */

+

+		/* Calculate the top of stack address.  This depends on whether the

+		stack grows from high memory to low (as per the 80x86) or visa versa.

+		portSTACK_GROWTH is used to make the result positive or negative as

+		required by the port. */

+		#if( portSTACK_GROWTH < 0 )

+		{

+			pxTopOfStack = pxNewTCB->pxStack + ( usStackDepth - ( unsigned short ) 1 );

+			pxTopOfStack = ( portSTACK_TYPE * ) ( ( ( portPOINTER_SIZE_TYPE ) pxTopOfStack ) & ( ( portPOINTER_SIZE_TYPE ) ~portBYTE_ALIGNMENT_MASK  ) );

+

+			/* Check the alignment of the calculated top of stack is correct. */

+			configASSERT( ( ( ( unsigned long ) pxTopOfStack & ( unsigned long ) portBYTE_ALIGNMENT_MASK ) == 0UL ) );

+		}

+		#else

+		{

+			pxTopOfStack = pxNewTCB->pxStack;

+			

+			/* Check the alignment of the stack buffer is correct. */

+			configASSERT( ( ( ( unsigned long ) pxNewTCB->pxStack & ( unsigned long ) portBYTE_ALIGNMENT_MASK ) == 0UL ) );

+

+			/* If we want to use stack checking on architectures that use

+			a positive stack growth direction then we also need to store the

+			other extreme of the stack space. */

+			pxNewTCB->pxEndOfStack = pxNewTCB->pxStack + ( usStackDepth - 1 );

+		}

+		#endif

+

+		/* Setup the newly allocated TCB with the initial state of the task. */

+		prvInitialiseTCBVariables( pxNewTCB, pcName, uxPriority, xRegions, usStackDepth );

+

+		/* Initialize the TCB stack to look as if the task was already running,

+		but had been interrupted by the scheduler.  The return address is set

+		to the start of the task function. Once the stack has been initialised

+		the	top of stack variable is updated. */

+		#if( portUSING_MPU_WRAPPERS == 1 )

+		{

+			pxNewTCB->pxTopOfStack = pxPortInitialiseStack( pxTopOfStack, pxTaskCode, pvParameters, xRunPrivileged );

+		}

+		#else

+		{

+			pxNewTCB->pxTopOfStack = pxPortInitialiseStack( pxTopOfStack, pxTaskCode, pvParameters );

+		}

+		#endif

+

+		/* Check the alignment of the initialised stack. */

+		portALIGNMENT_ASSERT_pxCurrentTCB( ( ( ( unsigned long ) pxNewTCB->pxTopOfStack & ( unsigned long ) portBYTE_ALIGNMENT_MASK ) == 0UL ) );

+

+		if( ( void * ) pxCreatedTask != NULL )

+		{

+			/* Pass the TCB out - in an anonymous way.  The calling function/

+			task can use this as a handle to delete the task later if

+			required.*/

+			*pxCreatedTask = ( xTaskHandle ) pxNewTCB;

+		}

+		

+		/* We are going to manipulate the task queues to add this task to a

+		ready list, so must make sure no interrupts occur. */

+		taskENTER_CRITICAL();

+		{

+			uxCurrentNumberOfTasks++;

+			if( pxCurrentTCB == NULL )

+			{

+				/* There are no other tasks, or all the other tasks are in

+				the suspended state - make this the current task. */

+				pxCurrentTCB =  pxNewTCB;

+

+				if( uxCurrentNumberOfTasks == ( unsigned portBASE_TYPE ) 1 )

+				{

+					/* This is the first task to be created so do the preliminary

+					initialisation required.  We will not recover if this call

+					fails, but we will report the failure. */

+					prvInitialiseTaskLists();

+				}

+			}

+			else

+			{

+				/* If the scheduler is not already running, make this task the

+				current task if it is the highest priority task to be created

+				so far. */

+				if( xSchedulerRunning == pdFALSE )

+				{

+					if( pxCurrentTCB->uxPriority <= uxPriority )

+					{

+						pxCurrentTCB = pxNewTCB;

+					}

+				}

+			}

+

+			/* Remember the top priority to make context switching faster.  Use

+			the priority in pxNewTCB as this has been capped to a valid value. */

+			if( pxNewTCB->uxPriority > uxTopUsedPriority )

+			{

+				uxTopUsedPriority = pxNewTCB->uxPriority;

+			}

+

+			#if ( configUSE_TRACE_FACILITY == 1 )

+			{

+				/* Add a counter into the TCB for tracing only. */

+				pxNewTCB->uxTCBNumber = uxTaskNumber;

+			}

+			#endif

+			uxTaskNumber++;

+

+			prvAddTaskToReadyQueue( pxNewTCB );

+

+			xReturn = pdPASS;

+			portSETUP_TCB( pxNewTCB );

+			traceTASK_CREATE( pxNewTCB );

+		}

+		taskEXIT_CRITICAL();

+	}

+	else

+	{

+		xReturn = errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY;

+		traceTASK_CREATE_FAILED();

+	}

+

+	if( xReturn == pdPASS )

+	{

+		if( xSchedulerRunning != pdFALSE )

+		{

+			/* If the created task is of a higher priority than the current task

+			then it should run now. */

+			if( pxCurrentTCB->uxPriority < uxPriority )

+			{

+				portYIELD_WITHIN_API();

+			}

+		}

+	}

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelete == 1 )

+

+	void vTaskDelete( xTaskHandle pxTaskToDelete )

+	{

+	tskTCB *pxTCB;

+

+		taskENTER_CRITICAL();

+		{

+			/* Ensure a yield is performed if the current task is being

+			deleted. */

+			if( pxTaskToDelete == pxCurrentTCB )

+			{

+				pxTaskToDelete = NULL;

+			}

+

+			/* If null is passed in here then we are deleting ourselves. */

+			pxTCB = prvGetTCBFromHandle( pxTaskToDelete );

+

+			/* Remove task from the ready list and place in the	termination list.

+			This will stop the task from be scheduled.  The idle task will check

+			the termination list and free up any memory allocated by the

+			scheduler for the TCB and stack. */

+			vListRemove( &( pxTCB->xGenericListItem ) );

+

+			/* Is the task waiting on an event also? */

+			if( pxTCB->xEventListItem.pvContainer != NULL )

+			{

+				vListRemove( &( pxTCB->xEventListItem ) );

+			}

+

+			vListInsertEnd( ( xList * ) &xTasksWaitingTermination, &( pxTCB->xGenericListItem ) );

+

+			/* Increment the ucTasksDeleted variable so the idle task knows

+			there is a task that has been deleted and that it should therefore

+			check the xTasksWaitingTermination list. */

+			++uxTasksDeleted;

+

+			/* Increment the uxTaskNumberVariable also so kernel aware debuggers

+			can detect that the task lists need re-generating. */

+			uxTaskNumber++;

+

+			traceTASK_DELETE( pxTCB );

+		}

+		taskEXIT_CRITICAL();

+

+		/* Force a reschedule if we have just deleted the current task. */

+		if( xSchedulerRunning != pdFALSE )

+		{

+			if( ( void * ) pxTaskToDelete == NULL )

+			{

+				portYIELD_WITHIN_API();

+			}

+		}

+	}

+

+#endif

+

+

+

+

+

+

+/*-----------------------------------------------------------

+ * TASK CONTROL API documented in task.h

+ *----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelayUntil == 1 )

+

+	void vTaskDelayUntil( portTickType * const pxPreviousWakeTime, portTickType xTimeIncrement )

+	{

+	portTickType xTimeToWake;

+	portBASE_TYPE xAlreadyYielded, xShouldDelay = pdFALSE;

+

+		configASSERT( pxPreviousWakeTime );

+		configASSERT( ( xTimeIncrement > 0U ) );

+

+		vTaskSuspendAll();

+		{

+			/* Generate the tick time at which the task wants to wake. */

+			xTimeToWake = *pxPreviousWakeTime + xTimeIncrement;

+

+			if( xTickCount < *pxPreviousWakeTime )

+			{

+				/* The tick count has overflowed since this function was

+				lasted called.  In this case the only time we should ever

+				actually delay is if the wake time has also	overflowed,

+				and the wake time is greater than the tick time.  When this

+				is the case it is as if neither time had overflowed. */

+				if( ( xTimeToWake < *pxPreviousWakeTime ) && ( xTimeToWake > xTickCount ) )

+				{

+					xShouldDelay = pdTRUE;

+				}

+			}

+			else

+			{

+				/* The tick time has not overflowed.  In this case we will

+				delay if either the wake time has overflowed, and/or the

+				tick time is less than the wake time. */

+				if( ( xTimeToWake < *pxPreviousWakeTime ) || ( xTimeToWake > xTickCount ) )

+				{

+					xShouldDelay = pdTRUE;

+				}

+			}

+

+			/* Update the wake time ready for the next call. */

+			*pxPreviousWakeTime = xTimeToWake;

+

+			if( xShouldDelay != pdFALSE )

+			{

+				traceTASK_DELAY_UNTIL();

+

+				/* We must remove ourselves from the ready list before adding

+				ourselves to the blocked list as the same list item is used for

+				both lists. */

+				vListRemove( ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+				prvAddCurrentTaskToDelayedList( xTimeToWake );

+			}

+		}

+		xAlreadyYielded = xTaskResumeAll();

+

+		/* Force a reschedule if xTaskResumeAll has not already done so, we may

+		have put ourselves to sleep. */

+		if( xAlreadyYielded == pdFALSE )

+		{

+			portYIELD_WITHIN_API();

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelay == 1 )

+

+	void vTaskDelay( portTickType xTicksToDelay )

+	{

+	portTickType xTimeToWake;

+	signed portBASE_TYPE xAlreadyYielded = pdFALSE;

+

+		/* A delay time of zero just forces a reschedule. */

+		if( xTicksToDelay > ( portTickType ) 0U )

+		{

+			vTaskSuspendAll();

+			{

+				traceTASK_DELAY();

+

+				/* A task that is removed from the event list while the

+				scheduler is suspended will not get placed in the ready

+				list or removed from the blocked list until the scheduler

+				is resumed.

+

+				This task cannot be in an event list as it is the currently

+				executing task. */

+

+				/* Calculate the time to wake - this may overflow but this is

+				not a problem. */

+				xTimeToWake = xTickCount + xTicksToDelay;

+

+				/* We must remove ourselves from the ready list before adding

+				ourselves to the blocked list as the same list item is used for

+				both lists. */

+				vListRemove( ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+				prvAddCurrentTaskToDelayedList( xTimeToWake );

+			}

+			xAlreadyYielded = xTaskResumeAll();

+		}

+

+		/* Force a reschedule if xTaskResumeAll has not already done so, we may

+		have put ourselves to sleep. */

+		if( xAlreadyYielded == pdFALSE )

+		{

+			portYIELD_WITHIN_API();

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_uxTaskPriorityGet == 1 )

+

+	unsigned portBASE_TYPE uxTaskPriorityGet( xTaskHandle pxTask )

+	{

+	tskTCB *pxTCB;

+	unsigned portBASE_TYPE uxReturn;

+

+		taskENTER_CRITICAL();

+		{

+			/* If null is passed in here then we are changing the

+			priority of the calling function. */

+			pxTCB = prvGetTCBFromHandle( pxTask );

+			uxReturn = pxTCB->uxPriority;

+		}

+		taskEXIT_CRITICAL();

+

+		return uxReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskPrioritySet == 1 )

+

+	void vTaskPrioritySet( xTaskHandle pxTask, unsigned portBASE_TYPE uxNewPriority )

+	{

+	tskTCB *pxTCB;

+	unsigned portBASE_TYPE uxCurrentPriority;

+	portBASE_TYPE xYieldRequired = pdFALSE;

+

+		configASSERT( ( uxNewPriority < configMAX_PRIORITIES ) );

+

+		/* Ensure the new priority is valid. */

+		if( uxNewPriority >= configMAX_PRIORITIES )

+		{

+			uxNewPriority = configMAX_PRIORITIES - ( unsigned portBASE_TYPE ) 1U;

+		}

+

+		taskENTER_CRITICAL();

+		{

+			if( pxTask == pxCurrentTCB )

+			{

+				pxTask = NULL;

+			}

+

+			/* If null is passed in here then we are changing the

+			priority of the calling function. */

+			pxTCB = prvGetTCBFromHandle( pxTask );

+

+			traceTASK_PRIORITY_SET( pxTCB, uxNewPriority );

+

+			#if ( configUSE_MUTEXES == 1 )

+			{

+				uxCurrentPriority = pxTCB->uxBasePriority;

+			}

+			#else

+			{

+				uxCurrentPriority = pxTCB->uxPriority;

+			}

+			#endif

+

+			if( uxCurrentPriority != uxNewPriority )

+			{

+				/* The priority change may have readied a task of higher

+				priority than the calling task. */

+				if( uxNewPriority > uxCurrentPriority )

+				{

+					if( pxTask != NULL )

+					{

+						/* The priority of another task is being raised.  If we

+						were raising the priority of the currently running task

+						there would be no need to switch as it must have already

+						been the highest priority task. */

+						xYieldRequired = pdTRUE;

+					}

+				}

+				else if( pxTask == NULL )

+				{

+					/* Setting our own priority down means there may now be another

+					task of higher priority that is ready to execute. */

+					xYieldRequired = pdTRUE;

+				}

+

+

+

+				#if ( configUSE_MUTEXES == 1 )

+				{

+					/* Only change the priority being used if the task is not

+					currently using an inherited priority. */

+					if( pxTCB->uxBasePriority == pxTCB->uxPriority )

+					{

+						pxTCB->uxPriority = uxNewPriority;

+					}

+

+					/* The base priority gets set whatever. */

+					pxTCB->uxBasePriority = uxNewPriority;

+				}

+				#else

+				{

+					pxTCB->uxPriority = uxNewPriority;

+				}

+				#endif

+

+				listSET_LIST_ITEM_VALUE( &( pxTCB->xEventListItem ), ( configMAX_PRIORITIES - ( portTickType ) uxNewPriority ) );

+

+				/* If the task is in the blocked or suspended list we need do

+				nothing more than change it's priority variable. However, if

+				the task is in a ready list it needs to be removed and placed

+				in the queue appropriate to its new priority. */

+				if( listIS_CONTAINED_WITHIN( &( pxReadyTasksLists[ uxCurrentPriority ] ), &( pxTCB->xGenericListItem ) ) )

+				{

+					/* The task is currently in its ready list - remove before adding

+					it to it's new ready list.  As we are in a critical section we

+					can do this even if the scheduler is suspended. */

+					vListRemove( &( pxTCB->xGenericListItem ) );

+					prvAddTaskToReadyQueue( pxTCB );

+				}

+

+				if( xYieldRequired == pdTRUE )

+				{

+					portYIELD_WITHIN_API();

+				}

+			}

+		}

+		taskEXIT_CRITICAL();

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+

+	void vTaskSuspend( xTaskHandle pxTaskToSuspend )

+	{

+	tskTCB *pxTCB;

+

+		taskENTER_CRITICAL();

+		{

+			/* Ensure a yield is performed if the current task is being

+			suspended. */

+			if( pxTaskToSuspend == pxCurrentTCB )

+			{

+				pxTaskToSuspend = NULL;

+			}

+

+			/* If null is passed in here then we are suspending ourselves. */

+			pxTCB = prvGetTCBFromHandle( pxTaskToSuspend );

+

+			traceTASK_SUSPEND( pxTCB );

+

+			/* Remove task from the ready/delayed list and place in the	suspended list. */

+			vListRemove( &( pxTCB->xGenericListItem ) );

+

+			/* Is the task waiting on an event also? */

+			if( pxTCB->xEventListItem.pvContainer != NULL )

+			{

+				vListRemove( &( pxTCB->xEventListItem ) );

+			}

+

+			vListInsertEnd( ( xList * ) &xSuspendedTaskList, &( pxTCB->xGenericListItem ) );

+		}

+		taskEXIT_CRITICAL();

+

+		if( ( void * ) pxTaskToSuspend == NULL )

+		{

+			if( xSchedulerRunning != pdFALSE )

+			{

+				/* We have just suspended the current task. */

+				portYIELD_WITHIN_API();

+			}

+			else

+			{

+				/* The scheduler is not running, but the task that was pointed

+				to by pxCurrentTCB has just been suspended and pxCurrentTCB

+				must be adjusted to point to a different task. */

+				if( listCURRENT_LIST_LENGTH( &xSuspendedTaskList ) == uxCurrentNumberOfTasks )

+				{

+					/* No other tasks are ready, so set pxCurrentTCB back to

+					NULL so when the next task is created pxCurrentTCB will

+					be set to point to it no matter what its relative priority

+					is. */

+					pxCurrentTCB = NULL;

+				}

+				else

+				{

+					vTaskSwitchContext();

+				}

+			}

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+

+	signed portBASE_TYPE xTaskIsTaskSuspended( xTaskHandle xTask )

+	{

+	portBASE_TYPE xReturn = pdFALSE;

+	const tskTCB * const pxTCB = ( tskTCB * ) xTask;

+

+		/* It does not make sense to check if the calling task is suspended. */

+		configASSERT( xTask );

+

+		/* Is the task we are attempting to resume actually in the

+		suspended list? */

+		if( listIS_CONTAINED_WITHIN( &xSuspendedTaskList, &( pxTCB->xGenericListItem ) ) != pdFALSE )

+		{

+			/* Has the task already been resumed from within an ISR? */

+			if( listIS_CONTAINED_WITHIN( &xPendingReadyList, &( pxTCB->xEventListItem ) ) != pdTRUE )

+			{

+				/* Is it in the suspended list because it is in the

+				Suspended state?  It is possible to be in the suspended

+				list because it is blocked on a task with no timeout

+				specified. */

+				if( listIS_CONTAINED_WITHIN( NULL, &( pxTCB->xEventListItem ) ) == pdTRUE )

+				{

+					xReturn = pdTRUE;

+				}

+			}

+		}

+

+		return xReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskSuspend == 1 )

+

+	void vTaskResume( xTaskHandle pxTaskToResume )

+	{

+	tskTCB *pxTCB;

+

+		/* It does not make sense to resume the calling task. */

+		configASSERT( pxTaskToResume );

+

+		/* Remove the task from whichever list it is currently in, and place

+		it in the ready list. */

+		pxTCB = ( tskTCB * ) pxTaskToResume;

+

+		/* The parameter cannot be NULL as it is impossible to resume the

+		currently executing task. */

+		if( ( pxTCB != NULL ) && ( pxTCB != pxCurrentTCB ) )

+		{

+			taskENTER_CRITICAL();

+			{

+				if( xTaskIsTaskSuspended( pxTCB ) == pdTRUE )

+				{

+					traceTASK_RESUME( pxTCB );

+

+					/* As we are in a critical section we can access the ready

+					lists even if the scheduler is suspended. */

+					vListRemove(  &( pxTCB->xGenericListItem ) );

+					prvAddTaskToReadyQueue( pxTCB );

+

+					/* We may have just resumed a higher priority task. */

+					if( pxTCB->uxPriority >= pxCurrentTCB->uxPriority )

+					{

+						/* This yield may not cause the task just resumed to run, but

+						will leave the lists in the correct state for the next yield. */

+						portYIELD_WITHIN_API();

+					}

+				}

+			}

+			taskEXIT_CRITICAL();

+		}

+	}

+

+#endif

+

+/*-----------------------------------------------------------*/

+

+#if ( ( INCLUDE_xTaskResumeFromISR == 1 ) && ( INCLUDE_vTaskSuspend == 1 ) )

+

+	portBASE_TYPE xTaskResumeFromISR( xTaskHandle pxTaskToResume )

+	{

+	portBASE_TYPE xYieldRequired = pdFALSE;

+	tskTCB *pxTCB;

+	unsigned portBASE_TYPE uxSavedInterruptStatus;

+

+		configASSERT( pxTaskToResume );

+

+		pxTCB = ( tskTCB * ) pxTaskToResume;

+

+		uxSavedInterruptStatus = portSET_INTERRUPT_MASK_FROM_ISR();

+		{

+			if( xTaskIsTaskSuspended( pxTCB ) == pdTRUE )

+			{

+				traceTASK_RESUME_FROM_ISR( pxTCB );

+

+				if( uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE )

+				{

+					xYieldRequired = ( pxTCB->uxPriority >= pxCurrentTCB->uxPriority );

+					vListRemove(  &( pxTCB->xGenericListItem ) );

+					prvAddTaskToReadyQueue( pxTCB );

+				}

+				else

+				{

+					/* We cannot access the delayed or ready lists, so will hold this

+					task pending until the scheduler is resumed, at which point a

+					yield will be performed if necessary. */

+					vListInsertEnd( ( xList * ) &( xPendingReadyList ), &( pxTCB->xEventListItem ) );

+				}

+			}

+		}

+		portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus );

+

+		return xYieldRequired;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskFinish == 1 )

+

+	signed portBASE_TYPE xTaskIsTaskFinished( xTaskHandle xTask )

+	{

+		int i;

+		const tskTCB * const pxTCB = ( tskTCB * ) xTask;

+

+		/* It does not make sense to check if the calling task is suspended. */

+		configASSERT( xTask );

+

+		/* Is the task we are attempting to resume actually in the

+		suspended list? */

+		if ( pxCurrentTCB == pxTCB )

+		{

+			return pdFALSE;

+		}

+		taskENTER_CRITICAL();

+

+		if ( ( listIS_CONTAINED_WITHIN( &xSuspendedTaskList, &( pxTCB->xGenericListItem ) ) != pdFALSE ) ||

+			 ( listIS_CONTAINED_WITHIN( &xDelayedTaskList1, &( pxTCB->xGenericListItem ) ) != pdFALSE ) ||

+			 ( listIS_CONTAINED_WITHIN( &xDelayedTaskList2, &( pxTCB->xGenericListItem ) ) != pdFALSE ) ||

+			 ( listIS_CONTAINED_WITHIN( &xPendingReadyList, &( pxTCB->xGenericListItem ) ) != pdFALSE ) )

+		{

+			taskEXIT_CRITICAL();

+			return pdFALSE;

+		}

+		for ( i = 0; i < configMAX_PRIORITIES; i++ )

+		{

+			if ( listIS_CONTAINED_WITHIN( &pxReadyTasksLists[ i ], &( pxTCB->xGenericListItem ) ) != pdFALSE )

+			{

+				taskEXIT_CRITICAL();

+				return pdFALSE;

+			}

+		}

+		taskEXIT_CRITICAL();

+		return pdTRUE;

+	}

+

+#endif /* INCLUDE_vTaskFinish */

+/*-----------------------------------------------------------*/

+

+

+

+/*-----------------------------------------------------------

+ * PUBLIC SCHEDULER CONTROL documented in task.h

+ *----------------------------------------------------------*/

+

+

+void vTaskStartScheduler( void )

+{

+portBASE_TYPE xReturn;

+

+	/* Add the idle task at the lowest priority. */

+	#if ( INCLUDE_xTaskGetIdleTaskHandle == 1 )

+	{

+		/* Create the idle task, storing its handle in xIdleTaskHandle so it can

+		be returned by the xTaskGetIdleTaskHandle() function. */

+		xReturn = xTaskGenericCreate( prvIdleTask, ( signed char * ) "IDLE", tskIDLE_STACK_SIZE, ( void * ) NULL, ( tskIDLE_PRIORITY | portPRIVILEGE_BIT ), &xIdleTaskHandle, (void*)&sIdleStack, NULL );

+	}

+	#else

+	{

+		/* Create the idle task without storing its handle. */

+		xReturn = xTaskGenericCreate( prvIdleTask, ( signed char * ) "IDLE", tskIDLE_STACK_SIZE, ( void * ) NULL, ( tskIDLE_PRIORITY | portPRIVILEGE_BIT ), NULL, (void*)&sIdleStack, NULL );

+	}

+	#endif

+

+	#if ( configUSE_TIMERS == 1 )

+	{

+		if( xReturn == pdPASS )

+		{

+			xReturn = xTimerCreateTimerTask();

+		}

+	}

+	#endif

+

+	if( xReturn == pdPASS )

+	{

+		/* Interrupts are turned off here, to ensure a tick does not occur

+		before or during the call to xPortStartScheduler().  The stacks of

+		the created tasks contain a status word with interrupts switched on

+		so interrupts will automatically get re-enabled when the first task

+		starts to run.

+

+		STEPPING THROUGH HERE USING A DEBUGGER CAN CAUSE BIG PROBLEMS IF THE

+		DEBUGGER ALLOWS INTERRUPTS TO BE PROCESSED. */

+		portDISABLE_INTERRUPTS();

+

+		xSchedulerRunning = pdTRUE;

+		xTickCount = ( portTickType ) 0U;

+

+		/* If configGENERATE_RUN_TIME_STATS is defined then the following

+		macro must be defined to configure the timer/counter used to generate

+		the run time counter time base. */

+		portCONFIGURE_TIMER_FOR_RUN_TIME_STATS();

+		

+		/* Setting up the timer tick is hardware specific and thus in the

+		portable interface. */

+		if( xPortStartScheduler() != pdFALSE )

+		{

+			/* Should not reach here as if the scheduler is running the

+			function will not return. */

+		}

+		else

+		{

+			/* Should only reach here if a task calls xTaskEndScheduler(). */

+		}

+	}

+

+	/* This line will only be reached if the kernel could not be started. */

+	configASSERT( xReturn );

+}

+/*-----------------------------------------------------------*/

+

+void vTaskEndScheduler( void )

+{

+	/* Stop the scheduler interrupts and call the portable scheduler end

+	routine so the original ISRs can be restored if necessary.  The port

+	layer must ensure interrupts enable	bit is left in the correct state. */

+	portDISABLE_INTERRUPTS();

+	xSchedulerRunning = pdFALSE;

+	vPortEndScheduler();

+}

+/*----------------------------------------------------------*/

+

+void vTaskSuspendAll( void )

+{

+	/* A critical section is not required as the variable is of type

+	portBASE_TYPE. */

+    taskENTER_CRITICAL();

+	++uxSchedulerSuspended;

+    taskEXIT_CRITICAL();

+}

+/*----------------------------------------------------------*/

+

+signed portBASE_TYPE xTaskResumeAll( void )

+{

+register tskTCB *pxTCB;

+signed portBASE_TYPE xAlreadyYielded = pdFALSE;

+

+	/* If uxSchedulerSuspended is zero then this function does not match a

+	previous call to vTaskSuspendAll(). */

+	configASSERT( uxSchedulerSuspended );

+

+	/* It is possible that an ISR caused a task to be removed from an event

+	list while the scheduler was suspended.  If this was the case then the

+	removed task will have been added to the xPendingReadyList.  Once the

+	scheduler has been resumed it is safe to move all the pending ready

+	tasks from this list into their appropriate ready list. */

+	taskENTER_CRITICAL();

+	{

+		--uxSchedulerSuspended;

+

+		if( uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE )

+		{

+			if( uxCurrentNumberOfTasks > ( unsigned portBASE_TYPE ) 0U )

+			{

+				portBASE_TYPE xYieldRequired = pdFALSE;

+

+				/* Move any readied tasks from the pending list into the

+				appropriate ready list. */

+				while( listLIST_IS_EMPTY( ( xList * ) &xPendingReadyList ) == pdFALSE )

+				{

+					pxTCB = ( tskTCB * ) listGET_OWNER_OF_HEAD_ENTRY(  ( ( xList * ) &xPendingReadyList ) );

+					vListRemove( &( pxTCB->xEventListItem ) );

+					vListRemove( &( pxTCB->xGenericListItem ) );

+					prvAddTaskToReadyQueue( pxTCB );

+

+					/* If we have moved a task that has a priority higher than

+					the current task then we should yield. */

+					if( pxTCB->uxPriority >= pxCurrentTCB->uxPriority )

+					{

+						xYieldRequired = pdTRUE;

+					}

+				}

+

+				/* If any ticks occurred while the scheduler was suspended then

+				they should be processed now.  This ensures the tick count does not

+				slip, and that any delayed tasks are resumed at the correct time. */

+				if( uxMissedTicks > ( unsigned portBASE_TYPE ) 0U )

+				{

+					while( uxMissedTicks > ( unsigned portBASE_TYPE ) 0U )

+					{

+						vTaskIncrementTick();

+						--uxMissedTicks;

+					}

+

+					/* As we have processed some ticks it is appropriate to yield

+					to ensure the highest priority task that is ready to run is

+					the task actually running. */

+					#if configUSE_PREEMPTION == 1

+					{

+						xYieldRequired = pdTRUE;

+					}

+					#endif

+				}

+

+				if( ( xYieldRequired == pdTRUE ) || ( xMissedYield == pdTRUE ) )

+				{

+					xAlreadyYielded = pdTRUE;

+					xMissedYield = pdFALSE;

+					portYIELD_WITHIN_API();

+				}

+			}

+		}

+	}

+	taskEXIT_CRITICAL();

+

+	return xAlreadyYielded;

+}

+

+

+

+

+

+

+/*-----------------------------------------------------------

+ * PUBLIC TASK UTILITIES documented in task.h

+ *----------------------------------------------------------*/

+

+

+

+portTickType xTaskGetTickCount( void )

+{

+portTickType xTicks;

+

+	/* Critical section required if running on a 16 bit processor. */

+	taskENTER_CRITICAL();

+	{

+		xTicks = xTickCount;

+	}

+	taskEXIT_CRITICAL();

+

+	return xTicks;

+}

+/*-----------------------------------------------------------*/

+

+portTickType xTaskGetTickCountFromISR( void )

+{

+portTickType xReturn;

+unsigned portBASE_TYPE uxSavedInterruptStatus;

+

+	uxSavedInterruptStatus = portSET_INTERRUPT_MASK_FROM_ISR();

+	xReturn = xTickCount;

+	portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus );

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+unsigned portBASE_TYPE uxTaskGetNumberOfTasks( void )

+{

+	/* A critical section is not required because the variables are of type

+	portBASE_TYPE. */

+	return uxCurrentNumberOfTasks;

+}

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_pcTaskGetTaskName == 1 )

+

+	signed char *pcTaskGetTaskName( xTaskHandle xTaskToQuery )

+	{

+	tskTCB *pxTCB;

+

+		/* If null is passed in here then the name of the calling task is being queried. */

+		pxTCB = prvGetTCBFromHandle( xTaskToQuery );

+		configASSERT( pxTCB );

+		return &( pxTCB->pcTaskName[ 0 ] );

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+static signed char *prvTaskWriteBuffer;

+

+static void prvDefaultTaskListCallback(volatile void *pxPCB,  signed char cStatus);

+

+void vTaskList( signed char *pcWriteBuffer ) {

+        prvTaskWriteBuffer = pcWriteBuffer;

+        *pcWriteBuffer = ( signed char ) 0x00;

+        strcat( ( char * ) pcWriteBuffer, ( const char * ) "\r\n" );

+        vTaskList1(prvDefaultTaskListCallback);

+}

+

+void vTaskList1(void (*pmCallback)(volatile void *pxPCB, signed char cStatus) )

+	{

+	unsigned portBASE_TYPE uxQueue;

+

+		/* This is a VERY costly function that should be used for debug only.

+		It leaves interrupts disabled for a LONG time. */

+

+		vTaskSuspendAll();

+		{

+			/* Run through all the lists that could potentially contain a TCB and

+			report the task name, state and stack high water mark. */

+

+			uxQueue = uxTopUsedPriority + ( unsigned portBASE_TYPE ) 1U;

+

+			do

+			{

+				uxQueue--;

+

+				if( listLIST_IS_EMPTY( &( pxReadyTasksLists[ uxQueue ] ) ) == pdFALSE )

+				{

+					prvListTaskWithinSingleList( pmCallback, ( xList * ) &( pxReadyTasksLists[ uxQueue ] ), tskREADY_CHAR );

+				}

+			}while( uxQueue > ( unsigned short ) tskIDLE_PRIORITY );

+

+			if( listLIST_IS_EMPTY( pxDelayedTaskList ) == pdFALSE )

+			{

+				prvListTaskWithinSingleList( pmCallback, ( xList * ) pxDelayedTaskList, tskBLOCKED_CHAR );

+			}

+

+			if( listLIST_IS_EMPTY( pxOverflowDelayedTaskList ) == pdFALSE )

+			{

+				prvListTaskWithinSingleList( pmCallback, ( xList * ) pxOverflowDelayedTaskList, tskBLOCKED_CHAR );

+			}

+

+			#if( INCLUDE_vTaskDelete == 1 )

+			{

+				if( listLIST_IS_EMPTY( &xTasksWaitingTermination ) == pdFALSE )

+				{

+					prvListTaskWithinSingleList( pmCallback, &xTasksWaitingTermination, tskDELETED_CHAR );

+				}

+			}

+			#endif

+

+			#if ( INCLUDE_vTaskSuspend == 1 )

+			{

+				if( listLIST_IS_EMPTY( &xSuspendedTaskList ) == pdFALSE )

+				{

+					prvListTaskWithinSingleList( pmCallback, &xSuspendedTaskList, tskSUSPENDED_CHAR );

+				}

+			}

+			#endif

+		}

+		xTaskResumeAll();

+	}

+

+#endif

+/*----------------------------------------------------------*/

+

+#if ( configGENERATE_RUN_TIME_STATS == 1 )

+

+	void vTaskGetRunTimeStats( signed char *pcWriteBuffer )

+	{

+	unsigned portBASE_TYPE uxQueue;

+	unsigned long ulTotalRunTime;

+    unsigned long currentTime;

+    static unsigned long sLastTime = 0;

+

+		/* This is a VERY costly function that should be used for debug only.

+		It leaves interrupts disabled for a LONG time. */

+

+		vTaskSuspendAll();

+		{

+#ifdef portALT_GET_RUN_TIME_COUNTER_VALUE

+            portALT_GET_RUN_TIME_COUNTER_VALUE( currentTime );

+#else

+            currentTime = portGET_RUN_TIME_COUNTER_VALUE();

+#endif

+

+            ulTotalRunTime = (currentTime - sLastTime);

+

+			/* Divide ulTotalRunTime by 100 to make the percentage caluclations

+			simpler in the prvGenerateRunTimeStatsForTasksInList() function. */            

+			ulTotalRunTime /= 100UL;

+

+            sLastTime = currentTime;

+			

+			/* Run through all the lists that could potentially contain a TCB,

+			generating a table of run timer percentages in the provided

+			buffer. */

+

+			*pcWriteBuffer = ( signed char ) 0x00;

+			strcat( ( char * ) pcWriteBuffer, ( const char * ) "\r\n" );

+

+			uxQueue = uxTopUsedPriority + ( unsigned portBASE_TYPE ) 1U;

+

+			do

+			{

+				uxQueue--;

+

+				if( listLIST_IS_EMPTY( &( pxReadyTasksLists[ uxQueue ] ) ) == pdFALSE )

+				{

+					prvGenerateRunTimeStatsForTasksInList( pcWriteBuffer, ( xList * ) &( pxReadyTasksLists[ uxQueue ] ), ulTotalRunTime );

+				}

+			}while( uxQueue > ( unsigned short ) tskIDLE_PRIORITY );

+

+			if( listLIST_IS_EMPTY( pxDelayedTaskList ) == pdFALSE )

+			{

+				prvGenerateRunTimeStatsForTasksInList( pcWriteBuffer, ( xList * ) pxDelayedTaskList, ulTotalRunTime );

+			}

+

+			if( listLIST_IS_EMPTY( pxOverflowDelayedTaskList ) == pdFALSE )

+			{

+				prvGenerateRunTimeStatsForTasksInList( pcWriteBuffer, ( xList * ) pxOverflowDelayedTaskList, ulTotalRunTime );

+			}

+

+			#if ( INCLUDE_vTaskDelete == 1 )

+			{

+				if( listLIST_IS_EMPTY( &xTasksWaitingTermination ) == pdFALSE )

+				{

+					prvGenerateRunTimeStatsForTasksInList( pcWriteBuffer, &xTasksWaitingTermination, ulTotalRunTime );

+				}

+			}

+			#endif

+

+			#if ( INCLUDE_vTaskSuspend == 1 )

+			{

+				if( listLIST_IS_EMPTY( &xSuspendedTaskList ) == pdFALSE )

+				{

+					prvGenerateRunTimeStatsForTasksInList( pcWriteBuffer, &xSuspendedTaskList, ulTotalRunTime );

+				}

+			}

+			#endif

+		}

+		xTaskResumeAll();

+	}

+

+#endif

+/*----------------------------------------------------------*/

+

+#if ( INCLUDE_xTaskGetIdleTaskHandle == 1 )

+

+	xTaskHandle xTaskGetIdleTaskHandle( void )

+	{

+		/* If xTaskGetIdleTaskHandle() is called before the scheduler has been

+		started, then xIdleTaskHandle will be NULL. */

+		configASSERT( ( xIdleTaskHandle != NULL ) );

+		return xIdleTaskHandle;

+	}

+	

+#endif

+

+/*-----------------------------------------------------------

+ * SCHEDULER INTERNALS AVAILABLE FOR PORTING PURPOSES

+ * documented in task.h

+ *----------------------------------------------------------*/

+

+void vTaskIncrementTick( void )

+{

+tskTCB * pxTCB;

+

+	/* Called by the portable layer each time a tick interrupt occurs.

+	Increments the tick then checks to see if the new tick value will cause any

+	tasks to be unblocked. */

+	if( uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE )

+	{

+		++xTickCount;

+		if( xTickCount == ( portTickType ) 0U )

+		{

+			xList *pxTemp;

+

+			/* Tick count has overflowed so we need to swap the delay lists.

+			If there are any items in pxDelayedTaskList here then there is

+			an error! */

+			configASSERT( ( listLIST_IS_EMPTY( pxDelayedTaskList ) ) );

+			

+			pxTemp = pxDelayedTaskList;

+			pxDelayedTaskList = pxOverflowDelayedTaskList;

+			pxOverflowDelayedTaskList = pxTemp;

+			xNumOfOverflows++;

+	

+			if( listLIST_IS_EMPTY( pxDelayedTaskList ) != pdFALSE )

+			{

+				/* The new current delayed list is empty.  Set

+				xNextTaskUnblockTime to the maximum possible value so it is

+				extremely unlikely that the	

+				if( xTickCount >= xNextTaskUnblockTime ) test will pass until

+				there is an item in the delayed list. */

+				xNextTaskUnblockTime = portMAX_DELAY;

+			}

+			else

+			{

+				/* The new current delayed list is not empty, get the value of

+				the item at the head of the delayed list.  This is the time at

+				which the task at the head of the delayed list should be removed

+				from the Blocked state. */

+				pxTCB = ( tskTCB * ) listGET_OWNER_OF_HEAD_ENTRY( pxDelayedTaskList );

+				xNextTaskUnblockTime = listGET_LIST_ITEM_VALUE( &( pxTCB->xGenericListItem ) );

+			}

+		}

+

+		/* See if this tick has made a timeout expire. */

+		prvCheckDelayedTasks();

+	}

+	else

+	{

+		++uxMissedTicks;

+

+		/* The tick hook gets called at regular intervals, even if the

+		scheduler is locked. */

+		#if ( configUSE_TICK_HOOK == 1 )

+		{

+			vApplicationTickHook();

+		}

+		#endif

+	}

+

+	#if ( configUSE_TICK_HOOK == 1 )

+	{

+		/* Guard against the tick hook being called when the missed tick

+		count is being unwound (when the scheduler is being unlocked. */

+		if( uxMissedTicks == ( unsigned portBASE_TYPE ) 0U )

+		{

+			vApplicationTickHook();

+		}

+	}

+	#endif

+

+	traceTASK_INCREMENT_TICK( xTickCount );

+}

+/*-----------------------------------------------------------*/

+

+void vTaskStepTick( const portTickType xTicksToJump )

+{

+    /* Correct the tick count value after a period during which the tick

+    was suppressed.  Note this does *not* call the tick hook function for

+    each stepped tick. */

+    configASSERT( ( xTickCount + xTicksToJump ) <= xNextTaskUnblockTime );

+    xTickCount += xTicksToJump;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+

+	void vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction )

+	{

+	tskTCB *xTCB;

+

+		/* If xTask is NULL then we are setting our own task hook. */

+		if( xTask == NULL )

+		{

+			xTCB = ( tskTCB * ) pxCurrentTCB;

+		}

+		else

+		{

+			xTCB = ( tskTCB * ) xTask;

+		}

+

+		/* Save the hook function in the TCB.  A critical section is required as

+		the value can be accessed from an interrupt. */

+		taskENTER_CRITICAL();

+			xTCB->pxTaskTag = pxHookFunction;

+		taskEXIT_CRITICAL();

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+

+	pdTASK_HOOK_CODE xTaskGetApplicationTaskTag( xTaskHandle xTask )

+	{

+	tskTCB *xTCB;

+	pdTASK_HOOK_CODE xReturn;

+

+		/* If xTask is NULL then we are setting our own task hook. */

+		if( xTask == NULL )

+		{

+			xTCB = ( tskTCB * ) pxCurrentTCB;

+		}

+		else

+		{

+			xTCB = ( tskTCB * ) xTask;

+		}

+

+		/* Save the hook function in the TCB.  A critical section is required as

+		the value can be accessed from an interrupt. */

+		taskENTER_CRITICAL();

+			xReturn = xTCB->pxTaskTag;

+		taskEXIT_CRITICAL();

+

+		return xReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+

+	portBASE_TYPE xTaskCallApplicationTaskHook( xTaskHandle xTask, void *pvParameter )

+	{

+	tskTCB *xTCB;

+	portBASE_TYPE xReturn;

+

+		/* If xTask is NULL then we are calling our own task hook. */

+		if( xTask == NULL )

+		{

+			xTCB = ( tskTCB * ) pxCurrentTCB;

+		}

+		else

+		{

+			xTCB = ( tskTCB * ) xTask;

+		}

+

+		if( xTCB->pxTaskTag != NULL )

+		{

+			xReturn = xTCB->pxTaskTag( pvParameter );

+		}

+		else

+		{

+			xReturn = pdFAIL;

+		}

+

+		return xReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+void vTaskSwitchContext( void )

+{

+	if( uxSchedulerSuspended != ( unsigned portBASE_TYPE ) pdFALSE )

+	{

+		/* The scheduler is currently suspended - do not allow a context

+		switch. */

+		xMissedYield = pdTRUE;

+	}

+	else

+	{

+		traceTASK_SWITCHED_OUT();

+	

+		#if ( configGENERATE_RUN_TIME_STATS == 1 )

+		{

+			unsigned long ulTempCounter;

+			

+				#ifdef portALT_GET_RUN_TIME_COUNTER_VALUE

+					portALT_GET_RUN_TIME_COUNTER_VALUE( ulTempCounter );

+				#else

+					ulTempCounter = portGET_RUN_TIME_COUNTER_VALUE();

+				#endif

+	

+				/* Add the amount of time the task has been running to the accumulated

+				time so far.  The time the task started running was stored in

+				ulTaskSwitchedInTime.  Note that there is no overflow protection here

+				so count values are only valid until the timer overflows.  Generally

+				this will be about 1 hour assuming a 1uS timer increment. */

+				pxCurrentTCB->ulRunTimeCounter += ( ulTempCounter - ulTaskSwitchedInTime );

+				ulTaskSwitchedInTime = ulTempCounter;

+		}

+		#endif

+	

+		taskFIRST_CHECK_FOR_STACK_OVERFLOW();

+		taskSECOND_CHECK_FOR_STACK_OVERFLOW();

+	

+		/* Find the highest priority queue that contains ready tasks. */

+		while( listLIST_IS_EMPTY( &( pxReadyTasksLists[ uxTopReadyPriority ] ) ) )

+		{

+			configASSERT( uxTopReadyPriority );

+			--uxTopReadyPriority;

+		}

+	

+		/* listGET_OWNER_OF_NEXT_ENTRY walks through the list, so the tasks of the

+		same priority get an equal share of the processor time. */

+		listGET_OWNER_OF_NEXT_ENTRY( pxCurrentTCB, &( pxReadyTasksLists[ uxTopReadyPriority ] ) );

+	

+		traceTASK_SWITCHED_IN();

+	}

+}

+/*-----------------------------------------------------------*/

+

+void vTaskPlaceOnEventList( const xList * const pxEventList, portTickType xTicksToWait )

+{

+portTickType xTimeToWake;

+

+	configASSERT( pxEventList );

+

+	/* THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED OR THE

+	SCHEDULER SUSPENDED. */

+

+	/* Place the event list item of the TCB in the appropriate event list.

+	This is placed in the list in priority order so the highest priority task

+	is the first to be woken by the event. */

+	vListInsert( ( xList * ) pxEventList, ( xListItem * ) &( pxCurrentTCB->xEventListItem ) );

+

+	/* We must remove ourselves from the ready list before adding ourselves

+	to the blocked list as the same list item is used for both lists.  We have

+	exclusive access to the ready lists as the scheduler is locked. */

+	vListRemove( ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+

+

+	#if ( INCLUDE_vTaskSuspend == 1 )

+	{

+		if( xTicksToWait == portMAX_DELAY )

+		{

+			/* Add ourselves to the suspended task list instead of a delayed task

+			list to ensure we are not woken by a timing event.  We will block

+			indefinitely. */

+			vListInsertEnd( ( xList * ) &xSuspendedTaskList, ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+		}

+		else

+		{

+			/* Calculate the time at which the task should be woken if the event does

+			not occur.  This may overflow but this doesn't matter. */

+			xTimeToWake = xTickCount + xTicksToWait;

+			prvAddCurrentTaskToDelayedList( xTimeToWake );

+		}

+	}

+	#else

+	{

+			/* Calculate the time at which the task should be woken if the event does

+			not occur.  This may overflow but this doesn't matter. */

+			xTimeToWake = xTickCount + xTicksToWait;

+			prvAddCurrentTaskToDelayedList( xTimeToWake );

+	}

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+#if configUSE_TIMERS == 1

+

+	void vTaskPlaceOnEventListRestricted( const xList * const pxEventList, portTickType xTicksToWait )

+	{

+	portTickType xTimeToWake;

+

+		configASSERT( pxEventList );

+

+		/* This function should not be called by application code hence the

+		'Restricted' in its name.  It is not part of the public API.  It is

+		designed for use by kernel code, and has special calling requirements -

+		it should be called from a critical section. */

+

+	

+		/* Place the event list item of the TCB in the appropriate event list.

+		In this case it is assume that this is the only task that is going to

+		be waiting on this event list, so the faster vListInsertEnd() function

+		can be used in place of vListInsert. */

+		vListInsertEnd( ( xList * ) pxEventList, ( xListItem * ) &( pxCurrentTCB->xEventListItem ) );

+

+		/* We must remove this task from the ready list before adding it to the

+		blocked list as the same list item is used for both lists.  This

+		function is called form a critical section. */

+		vListRemove( ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+

+		/* Calculate the time at which the task should be woken if the event does

+		not occur.  This may overflow but this doesn't matter. */

+		xTimeToWake = xTickCount + xTicksToWait;

+		prvAddCurrentTaskToDelayedList( xTimeToWake );

+	}

+	

+#endif /* configUSE_TIMERS */

+/*-----------------------------------------------------------*/

+

+signed portBASE_TYPE xTaskRemoveFromEventList( const xList * const pxEventList )

+{

+tskTCB *pxUnblockedTCB;

+portBASE_TYPE xReturn;

+

+	/* THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED OR THE

+	SCHEDULER SUSPENDED.  It can also be called from within an ISR. */

+

+	/* The event list is sorted in priority order, so we can remove the

+	first in the list, remove the TCB from the delayed list, and add

+	it to the ready list.

+

+	If an event is for a queue that is locked then this function will never

+	get called - the lock count on the queue will get modified instead.  This

+	means we can always expect exclusive access to the event list here.

+	

+	This function assumes that a check has already been made to ensure that

+	pxEventList is not empty. */

+	pxUnblockedTCB = ( tskTCB * ) listGET_OWNER_OF_HEAD_ENTRY( pxEventList );

+	configASSERT( pxUnblockedTCB );

+	vListRemove( &( pxUnblockedTCB->xEventListItem ) );

+

+	if( uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE )

+	{

+		vListRemove( &( pxUnblockedTCB->xGenericListItem ) );

+		prvAddTaskToReadyQueue( pxUnblockedTCB );

+	}

+	else

+	{

+		/* We cannot access the delayed or ready lists, so will hold this

+		task pending until the scheduler is resumed. */

+		vListInsertEnd( ( xList * ) &( xPendingReadyList ), &( pxUnblockedTCB->xEventListItem ) );

+	}

+

+	if( pxUnblockedTCB->uxPriority >= pxCurrentTCB->uxPriority )

+	{

+		/* Return true if the task removed from the event list has

+		a higher priority than the calling task.  This allows

+		the calling task to know if it should force a context

+		switch now. */

+		xReturn = pdTRUE;

+	}

+	else

+	{

+		xReturn = pdFALSE;

+	}

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vTaskSetTimeOutState( xTimeOutType * const pxTimeOut )

+{

+	configASSERT( pxTimeOut );

+	pxTimeOut->xOverflowCount = xNumOfOverflows;

+	pxTimeOut->xTimeOnEntering = xTickCount;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xTaskCheckForTimeOut( xTimeOutType * const pxTimeOut, portTickType * const pxTicksToWait )

+{

+portBASE_TYPE xReturn;

+

+	configASSERT( pxTimeOut );

+	configASSERT( pxTicksToWait );

+

+	taskENTER_CRITICAL();

+	{

+		#if ( INCLUDE_vTaskSuspend == 1 )

+			/* If INCLUDE_vTaskSuspend is set to 1 and the block time specified is

+			the maximum block time then the task should block indefinitely, and

+			therefore never time out. */

+			if( *pxTicksToWait == portMAX_DELAY )

+			{

+				xReturn = pdFALSE;

+			}

+			else /* We are not blocking indefinitely, perform the checks below. */

+		#endif

+

+		if( ( xNumOfOverflows != pxTimeOut->xOverflowCount ) && ( ( portTickType ) xTickCount >= ( portTickType ) pxTimeOut->xTimeOnEntering ) )

+		{

+			/* The tick count is greater than the time at which vTaskSetTimeout()

+			was called, but has also overflowed since vTaskSetTimeOut() was called.

+			It must have wrapped all the way around and gone past us again. This

+			passed since vTaskSetTimeout() was called. */

+			xReturn = pdTRUE;

+		}

+		else if( ( ( portTickType ) ( ( portTickType ) xTickCount - ( portTickType ) pxTimeOut->xTimeOnEntering ) ) < ( portTickType ) *pxTicksToWait )

+		{

+			/* Not a genuine timeout. Adjust parameters for time remaining. */

+			*pxTicksToWait -= ( ( portTickType ) xTickCount - ( portTickType ) pxTimeOut->xTimeOnEntering );

+			vTaskSetTimeOutState( pxTimeOut );

+			xReturn = pdFALSE;

+		}

+		else

+		{

+			xReturn = pdTRUE;

+		}

+	}

+	taskEXIT_CRITICAL();

+

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+void vTaskMissedYield( void )

+{

+	xMissedYield = pdTRUE;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+	unsigned portBASE_TYPE uxTaskGetTaskNumber( xTaskHandle xTask )

+	{

+	unsigned portBASE_TYPE uxReturn;

+	tskTCB *pxTCB;

+	

+		if( xTask != NULL )

+		{

+			pxTCB = ( tskTCB * ) xTask;

+			uxReturn = pxTCB->uxTaskNumber;

+		}

+		else

+		{

+			uxReturn = 0U;

+		}

+		

+		return uxReturn;

+	}

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+	void vTaskSetTaskNumber( xTaskHandle xTask, unsigned portBASE_TYPE uxHandle )

+	{

+	tskTCB *pxTCB;

+	

+		if( xTask != NULL )

+		{

+			pxTCB = ( tskTCB * ) xTask;

+			pxTCB->uxTaskNumber = uxHandle;

+		}

+	}

+#endif

+

+

+/*

+ * -----------------------------------------------------------

+ * The Idle task.

+ * ----------------------------------------------------------

+ *

+ * The portTASK_FUNCTION() macro is used to allow port/compiler specific

+ * language extensions.  The equivalent prototype for this function is:

+ *

+ * void prvIdleTask( void *pvParameters );

+ *

+ */

+static portTASK_FUNCTION( prvIdleTask, pvParameters )

+{

+	/* Stop warnings. */

+	( void ) pvParameters;

+

+	for( ;; )

+	{

+		/* See if any tasks have been deleted. */

+		prvCheckTasksWaitingTermination();

+

+		#if ( configUSE_PREEMPTION == 0 )

+		{

+			/* If we are not using preemption we keep forcing a task switch to

+			see if any other task has become available.  If we are using

+			preemption we don't need to do this as any task becoming available

+			will automatically get the processor anyway. */

+			taskYIELD();

+		}

+		#endif

+

+		#if ( ( configUSE_PREEMPTION == 1 ) && ( configIDLE_SHOULD_YIELD == 1 ) )

+		{

+			/* When using preemption tasks of equal priority will be

+			timesliced.  If a task that is sharing the idle priority is ready

+			to run then the idle task should yield before the end of the

+			timeslice.

+

+			A critical region is not required here as we are just reading from

+			the list, and an occasional incorrect value will not matter.  If

+			the ready list at the idle priority contains more than one task

+			then a task other than the idle task is ready to execute. */

+			if( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ tskIDLE_PRIORITY ] ) ) > ( unsigned portBASE_TYPE ) 1 )

+			{

+				taskYIELD();

+			}

+		}

+		#endif

+

+		#if ( configUSE_IDLE_HOOK == 1 )

+		{

+			extern void vApplicationIdleHook( void );

+

+			/* Call the user defined function from within the idle task.  This

+			allows the application designer to add background functionality

+			without the overhead of a separate task.

+			NOTE: vApplicationIdleHook() MUST NOT, UNDER ANY CIRCUMSTANCES,

+			CALL A FUNCTION THAT MIGHT BLOCK. */

+			vApplicationIdleHook();

+		}

+		#endif

+	}

+} /*lint !e715 pvParameters is not accessed but all task functions require the same prototype. */

+

+

+

+

+

+

+

+/*-----------------------------------------------------------

+ * File private functions documented at the top of the file.

+ *----------------------------------------------------------*/

+

+

+

+static void prvInitialiseTCBVariables( tskTCB *pxTCB, const signed char * const pcName, unsigned portBASE_TYPE uxPriority, const xMemoryRegion * const xRegions, unsigned short usStackDepth )

+{

+	/* Store the function name in the TCB. */

+	#if configMAX_TASK_NAME_LEN > 1

+	{

+		/* Don't bring strncpy into the build unnecessarily. */

+		strncpy( ( char * ) pxTCB->pcTaskName, ( const char * ) pcName, ( unsigned short ) configMAX_TASK_NAME_LEN );

+	}

+	#endif

+	pxTCB->pcTaskName[ ( unsigned short ) configMAX_TASK_NAME_LEN - ( unsigned short ) 1 ] = ( signed char ) '\0';

+

+	/* This is used as an array index so must ensure it's not too large.  First

+	remove the privilege bit if one is present. */

+	if( uxPriority >= configMAX_PRIORITIES )

+	{

+		uxPriority = configMAX_PRIORITIES - ( unsigned portBASE_TYPE ) 1U;

+	}

+

+	pxTCB->uxPriority = uxPriority;

+	#if ( configUSE_MUTEXES == 1 )

+	{

+		pxTCB->uxBasePriority = uxPriority;

+	}

+	#endif

+

+	vListInitialiseItem( &( pxTCB->xGenericListItem ) );

+	vListInitialiseItem( &( pxTCB->xEventListItem ) );

+

+	/* Set the pxTCB as a link back from the xListItem.  This is so we can get

+	back to	the containing TCB from a generic item in a list. */

+	listSET_LIST_ITEM_OWNER( &( pxTCB->xGenericListItem ), pxTCB );

+

+	/* Event lists are always in priority order. */

+	listSET_LIST_ITEM_VALUE( &( pxTCB->xEventListItem ), configMAX_PRIORITIES - ( portTickType ) uxPriority );

+	listSET_LIST_ITEM_OWNER( &( pxTCB->xEventListItem ), pxTCB );

+

+	#if ( portCRITICAL_NESTING_IN_TCB == 1 )

+	{

+		pxTCB->uxCriticalNesting = ( unsigned portBASE_TYPE ) 0U;

+	}

+	#endif

+

+	#if ( configUSE_APPLICATION_TASK_TAG == 1 )

+	{

+		pxTCB->pxTaskTag = NULL;

+	}

+	#endif

+

+	#if ( configGENERATE_RUN_TIME_STATS == 1 )

+	{

+		pxTCB->ulRunTimeCounter = 0UL;

+	}

+	#endif

+

+	#if ( portUSING_MPU_WRAPPERS == 1 )

+	{

+		vPortStoreTaskMPUSettings( &( pxTCB->xMPUSettings ), xRegions, pxTCB->pxStack, usStackDepth );

+	}

+	#else

+	{

+		( void ) xRegions;

+		( void ) usStackDepth;

+	}

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+#if ( portUSING_MPU_WRAPPERS == 1 )

+

+	void vTaskAllocateMPURegions( xTaskHandle xTaskToModify, const xMemoryRegion * const xRegions )

+	{

+	tskTCB *pxTCB;

+	

+		if( xTaskToModify == pxCurrentTCB )

+		{

+			xTaskToModify = NULL;

+		}

+

+		/* If null is passed in here then we are deleting ourselves. */

+		pxTCB = prvGetTCBFromHandle( xTaskToModify );

+

+        vPortStoreTaskMPUSettings( &( pxTCB->xMPUSettings ), xRegions, NULL, 0 );

+	}

+	/*-----------------------------------------------------------*/

+#endif

+

+static void prvInitialiseTaskLists( void )

+{

+unsigned portBASE_TYPE uxPriority;

+

+	for( uxPriority = ( unsigned portBASE_TYPE ) 0U; uxPriority < configMAX_PRIORITIES; uxPriority++ )

+	{

+		vListInitialise( ( xList * ) &( pxReadyTasksLists[ uxPriority ] ) );

+	}

+

+	vListInitialise( ( xList * ) &xDelayedTaskList1 );

+	vListInitialise( ( xList * ) &xDelayedTaskList2 );

+	vListInitialise( ( xList * ) &xPendingReadyList );

+

+	#if ( INCLUDE_vTaskDelete == 1 )

+	{

+		vListInitialise( ( xList * ) &xTasksWaitingTermination );

+	}

+	#endif

+

+	#if ( INCLUDE_vTaskSuspend == 1 )

+	{

+		vListInitialise( ( xList * ) &xSuspendedTaskList );

+	}

+	#endif

+

+	/* Start with pxDelayedTaskList using list1 and the pxOverflowDelayedTaskList

+	using list2. */

+	pxDelayedTaskList = &xDelayedTaskList1;

+	pxOverflowDelayedTaskList = &xDelayedTaskList2;

+}

+/*-----------------------------------------------------------*/

+

+static void prvCheckTasksWaitingTermination( void )

+{

+	#if ( INCLUDE_vTaskDelete == 1 )

+	{

+		portBASE_TYPE xListIsEmpty;

+

+		/* ucTasksDeleted is used to prevent vTaskSuspendAll() being called

+		too often in the idle task. */

+		if( uxTasksDeleted > ( unsigned portBASE_TYPE ) 0U )

+		{

+			vTaskSuspendAll();

+				xListIsEmpty = listLIST_IS_EMPTY( &xTasksWaitingTermination );

+			xTaskResumeAll();

+

+			if( xListIsEmpty == pdFALSE )

+			{

+				tskTCB *pxTCB;

+

+				taskENTER_CRITICAL();

+				{

+					pxTCB = ( tskTCB * ) listGET_OWNER_OF_HEAD_ENTRY( ( ( xList * ) &xTasksWaitingTermination ) );

+					vListRemove( &( pxTCB->xGenericListItem ) );

+					--uxCurrentNumberOfTasks;

+					--uxTasksDeleted;

+				}

+				taskEXIT_CRITICAL();

+

+				prvDeleteTCB( pxTCB );

+			}

+		}

+	}

+	#endif

+}

+/*-----------------------------------------------------------*/

+

+static void prvAddCurrentTaskToDelayedList( portTickType xTimeToWake )

+{

+	/* The list item will be inserted in wake time order. */

+	listSET_LIST_ITEM_VALUE( &( pxCurrentTCB->xGenericListItem ), xTimeToWake );

+

+	if( xTimeToWake < xTickCount )

+	{

+		/* Wake time has overflowed.  Place this item in the overflow list. */

+		vListInsert( ( xList * ) pxOverflowDelayedTaskList, ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+	}

+	else

+	{

+		/* The wake time has not overflowed, so we can use the current block list. */

+		vListInsert( ( xList * ) pxDelayedTaskList, ( xListItem * ) &( pxCurrentTCB->xGenericListItem ) );

+

+		/* If the task entering the blocked state was placed at the head of the

+		list of blocked tasks then xNextTaskUnblockTime needs to be updated

+		too. */

+		if( xTimeToWake < xNextTaskUnblockTime )

+		{

+			xNextTaskUnblockTime = xTimeToWake;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+static tskTCB *prvAllocateTCBAndStack( unsigned short usStackDepth, portSTACK_TYPE *puxStackBuffer )

+{

+tskTCB *pxNewTCB;

+

+    pxNewTCB = ( tskTCB * ) poolAllocateBuffer( &sTCBsPool );

+	if( pxNewTCB != NULL )

+	{

+		/* Allocate space for the stack used by the task being created.

+		The base of the stack memory stored in the TCB so the task can

+		be deleted later if required. */

+		pxNewTCB->pxStack = ( portSTACK_TYPE * ) pvPortMallocAligned( ( ( ( size_t )usStackDepth ) * sizeof( portSTACK_TYPE ) ), puxStackBuffer );

+        pxNewTCB->stackIsStatic = (puxStackBuffer != NULL) ? 1 : 0;

+		if( pxNewTCB->pxStack == NULL )

+		{

+			/* Could not allocate the stack.  Delete the allocated TCB. */

+			poolFreeBuffer( &sTCBsPool, pxNewTCB );

+			pxNewTCB = NULL;

+		}

+		else

+		{

+			/* Just to help debugging. */

+			memset( pxNewTCB->pxStack, ( int ) tskSTACK_FILL_BYTE, ( size_t ) usStackDepth * sizeof( portSTACK_TYPE ) );

+		}

+	}

+

+	return pxNewTCB;

+}

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_TRACE_FACILITY == 1 )

+

+static void prvDefaultTaskListCallback(volatile void *pxTCB, signed char cStatus) {

+        volatile tskTCB * pxNextTCB = (volatile tskTCB*) pxTCB;

+	unsigned short usStackRemaining;

+	PRIVILEGED_DATA static char pcStatusString[ configMAX_TASK_NAME_LEN + 30 ];

+			#if ( portSTACK_GROWTH > 0 )

+			{

+				usStackRemaining = usTaskCheckFreeStackSpace( ( unsigned char * ) pxNextTCB->pxEndOfStack );

+			}

+			#else

+			{

+				usStackRemaining = usTaskCheckFreeStackSpace( ( unsigned char * ) pxNextTCB->pxStack );

+			}

+			#endif

+                        

+			

+			sprintf( pcStatusString, ( char * ) "%-*s\t%c\t%u\t%u\t%u\r\n", configMAX_TASK_NAME_LEN, pxNextTCB->pcTaskName, cStatus, ( unsigned int ) pxNextTCB->uxPriority, usStackRemaining, ( unsigned int ) pxNextTCB->uxTCBNumber );

+			strcat( ( char * ) prvTaskWriteBuffer, ( char * ) pcStatusString );

+

+}

+

+static void prvListTaskWithinSingleList( void (*pmCallback)(volatile void*pxTCB, signed char cStatus), xList *pxList, signed char cStatus )

+	{

+	volatile tskTCB *pxNextTCB, *pxFirstTCB;

+

+		/* Write the details of all the TCB's in pxList into the buffer. */

+		listGET_OWNER_OF_NEXT_ENTRY( pxFirstTCB, pxList );

+		do

+		{

+			listGET_OWNER_OF_NEXT_ENTRY( pxNextTCB, pxList );

+                        pmCallback(pxNextTCB, cStatus);

+		} while( pxNextTCB != pxFirstTCB );

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configGENERATE_RUN_TIME_STATS == 1 )

+

+	static void prvGenerateRunTimeStatsForTasksInList( const signed char *pcWriteBuffer, xList *pxList, unsigned long ulTotalRunTime )

+	{

+	volatile tskTCB *pxNextTCB, *pxFirstTCB;

+	unsigned long ulStatsAsPercentage;

+

+		/* Write the run time stats of all the TCB's in pxList into the buffer. */

+		listGET_OWNER_OF_NEXT_ENTRY( pxFirstTCB, pxList );

+		do

+		{

+			/* Get next TCB in from the list. */

+			listGET_OWNER_OF_NEXT_ENTRY( pxNextTCB, pxList );

+

+			/* Divide by zero check. */

+			if( ulTotalRunTime > 0UL )

+			{

+				/* Has the task run at all? */

+				if( pxNextTCB->ulRunTimeCounter == 0UL )

+				{

+					/* The task has used no CPU time at all. */

+					sprintf( pcStatsString, ( char * ) "%s\t\t0\t\t0%%\r\n", pxNextTCB->pcTaskName );

+				}

+				else

+				{

+					/* What percentage of the total run time has the task used?

+					This will always be rounded down to the nearest integer.

+					ulTotalRunTime has already been divided by 100. */

+					ulStatsAsPercentage = pxNextTCB->ulRunTimeCounter / ulTotalRunTime;

+

+					if( ulStatsAsPercentage > 0UL )

+					{

+						#ifdef portLU_PRINTF_SPECIFIER_REQUIRED

+						{

+							sprintf( pcStatsString, ( char * ) "%s\t\t%lu\t\t%lu%%\r\n", pxNextTCB->pcTaskName, pxNextTCB->ulRunTimeCounter, ulStatsAsPercentage );							

+						}

+						#else

+						{

+							/* sizeof( int ) == sizeof( long ) so a smaller

+							printf() library can be used. */

+							sprintf( pcStatsString, ( char * ) "%s\t\t%u\t\t%u%%\r\n", pxNextTCB->pcTaskName, ( unsigned int ) pxNextTCB->ulRunTimeCounter, ( unsigned int ) ulStatsAsPercentage );

+						}

+						#endif

+					}

+					else

+					{

+						/* If the percentage is zero here then the task has

+						consumed less than 1% of the total run time. */

+						#ifdef portLU_PRINTF_SPECIFIER_REQUIRED

+						{

+							sprintf( pcStatsString, ( char * ) "%s\t\t%lu\t\t<1%%\r\n", pxNextTCB->pcTaskName, pxNextTCB->ulRunTimeCounter );							

+						}

+						#else

+						{

+							/* sizeof( int ) == sizeof( long ) so a smaller

+							printf() library can be used. */

+							sprintf( pcStatsString, ( char * ) "%s\t\t%u\t\t<1%%\r\n", pxNextTCB->pcTaskName, ( unsigned int ) pxNextTCB->ulRunTimeCounter );

+						}

+						#endif

+					}

+				}

+

+				strcat( ( char * ) pcWriteBuffer, ( char * ) pcStatsString );

+			}

+            

+            // I want to clear the stats every time i call this function

+            pxNextTCB->ulRunTimeCounter = 0;

+

+		} while( pxNextTCB != pxFirstTCB );

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( ( configUSE_TRACE_FACILITY == 1 ) || ( INCLUDE_uxTaskGetStackHighWaterMark == 1 ) )

+

+	static unsigned short usTaskCheckFreeStackSpace( const unsigned char * pucStackByte )

+	{

+	register unsigned short usCount = 0U;

+

+		while( *pucStackByte == tskSTACK_FILL_BYTE )

+		{

+			pucStackByte -= portSTACK_GROWTH;

+			usCount++;

+		}

+

+		usCount /= sizeof( portSTACK_TYPE );

+

+		return usCount;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_uxTaskGetStackHighWaterMark == 1 )

+

+	unsigned portBASE_TYPE uxTaskGetStackHighWaterMark( xTaskHandle xTask )

+	{

+	tskTCB *pxTCB;

+	unsigned char *pcEndOfStack;

+	unsigned portBASE_TYPE uxReturn;

+

+		pxTCB = prvGetTCBFromHandle( xTask );

+

+		#if portSTACK_GROWTH < 0

+		{

+			pcEndOfStack = ( unsigned char * ) pxTCB->pxStack;

+		}

+		#else

+		{

+			pcEndOfStack = ( unsigned char * ) pxTCB->pxEndOfStack;

+		}

+		#endif

+

+		uxReturn = ( unsigned portBASE_TYPE ) usTaskCheckFreeStackSpace( pcEndOfStack );

+

+		return uxReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_vTaskDelete == 1 )

+

+	static void prvDeleteTCB( tskTCB *pxTCB )

+	{

+		/* This call is required specifically for the TriCore port.  It must be

+		above the vPortFree() calls.  The call is also used by ports/demos that

+		want to allocate and clean RAM statically. */

+		portCLEAN_UP_TCB( pxTCB );

+

+		/* Free up the memory allocated by the scheduler for the task.  It is up to

+		the task to free any memory allocated at the application level. */

+        if(!pxTCB->stackIsStatic)

+            vPortFreeAligned( pxTCB->pxStack );

+		poolFreeBuffer( &sTCBsPool, pxTCB );

+	}

+

+#endif

+

+

+/*-----------------------------------------------------------*/

+

+#if ( ( INCLUDE_xTaskGetCurrentTaskHandle == 1 ) || ( configUSE_MUTEXES == 1 ) )

+

+	xTaskHandle xTaskGetCurrentTaskHandle( void )

+	{

+	xTaskHandle xReturn;

+

+		/* A critical section is not required as this is not called from

+		an interrupt and the current TCB will always be the same for any

+		individual execution thread. */

+		xReturn = pxCurrentTCB;

+

+		return xReturn;

+	}

+

+#endif

+

+/*-----------------------------------------------------------*/

+

+#if ( ( INCLUDE_xTaskGetSchedulerState == 1 ) || ( configUSE_TIMERS == 1 ) )

+

+	portBASE_TYPE xTaskGetSchedulerState( void )

+	{

+	portBASE_TYPE xReturn;

+

+		if( xSchedulerRunning == pdFALSE )

+		{

+			xReturn = taskSCHEDULER_NOT_STARTED;

+		}

+		else

+		{

+			if( uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE )

+			{

+				xReturn = taskSCHEDULER_RUNNING;

+			}

+			else

+			{

+				xReturn = taskSCHEDULER_SUSPENDED;

+			}

+		}

+

+		return xReturn;

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+

+	void vTaskPriorityInherit( xTaskHandle * const pxMutexHolder )

+	{

+	tskTCB * const pxTCB = ( tskTCB * ) pxMutexHolder;

+

+		configASSERT( pxMutexHolder );

+

+		if( pxTCB->uxPriority < pxCurrentTCB->uxPriority )

+		{

+			/* Adjust the mutex holder state to account for its new priority. */

+			listSET_LIST_ITEM_VALUE( &( pxTCB->xEventListItem ), configMAX_PRIORITIES - ( portTickType ) pxCurrentTCB->uxPriority );

+

+			/* If the task being modified is in the ready state it will need to

+			be moved in to a new list. */

+			if( listIS_CONTAINED_WITHIN( &( pxReadyTasksLists[ pxTCB->uxPriority ] ), &( pxTCB->xGenericListItem ) ) != pdFALSE )

+			{

+				vListRemove( &( pxTCB->xGenericListItem ) );

+

+				/* Inherit the priority before being moved into the new list. */

+				pxTCB->uxPriority = pxCurrentTCB->uxPriority;

+				prvAddTaskToReadyQueue( pxTCB );

+			}

+			else

+			{

+				/* Just inherit the priority. */

+				pxTCB->uxPriority = pxCurrentTCB->uxPriority;

+			}

+

+			traceTASK_PRIORITY_INHERIT( pxTCB, pxCurrentTCB->uxPriority );

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( configUSE_MUTEXES == 1 )

+

+	void vTaskPriorityDisinherit( xTaskHandle * const pxMutexHolder )

+	{

+	tskTCB * const pxTCB = ( tskTCB * ) pxMutexHolder;

+

+		if( pxMutexHolder != NULL )

+		{

+			if( pxTCB->uxPriority != pxTCB->uxBasePriority )

+			{

+				/* We must be the running task to be able to give the mutex back.

+				Remove ourselves from the ready list we currently appear in. */

+				vListRemove( &( pxTCB->xGenericListItem ) );

+

+				/* Disinherit the priority before adding the task into the new

+				ready list. */

+				traceTASK_PRIORITY_DISINHERIT( pxTCB, pxTCB->uxBasePriority );

+				pxTCB->uxPriority = pxTCB->uxBasePriority;

+				listSET_LIST_ITEM_VALUE( &( pxTCB->xEventListItem ), configMAX_PRIORITIES - ( portTickType ) pxTCB->uxPriority );

+				prvAddTaskToReadyQueue( pxTCB );

+			}

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( portCRITICAL_NESTING_IN_TCB == 1 )

+

+	void vTaskEnterCritical( void )

+	{

+		portDISABLE_INTERRUPTS();

+

+		if( xSchedulerRunning != pdFALSE )

+		{

+			( pxCurrentTCB->uxCriticalNesting )++;

+		}

+	}

+

+#endif

+/*-----------------------------------------------------------*/

+

+#if ( portCRITICAL_NESTING_IN_TCB == 1 )

+

+void vTaskExitCritical( void )

+{

+	if( xSchedulerRunning != pdFALSE )

+	{

+		if( pxCurrentTCB->uxCriticalNesting > 0U )

+		{

+			( pxCurrentTCB->uxCriticalNesting )--;

+

+			if( pxCurrentTCB->uxCriticalNesting == 0U )

+			{

+				portENABLE_INTERRUPTS();

+			}

+		}

+	}

+}

+

+#endif

+/*-----------------------------------------------------------*/

+

+

+

+

diff --git a/FreeRTOS/Source/timers.c b/FreeRTOS/Source/timers.c
new file mode 100644
index 0000000..b9ad6cb
--- /dev/null
+++ b/FreeRTOS/Source/timers.c
@@ -0,0 +1,721 @@
+/*

+    FreeRTOS V7.2.0 - Copyright (C) 2012 Real Time Engineers Ltd.

+

+

+    ***************************************************************************

+     *                                                                       *

+     *    FreeRTOS tutorial books are available in pdf and paperback.        *

+     *    Complete, revised, and edited pdf reference manuals are also       *

+     *    available.                                                         *

+     *                                                                       *

+     *    Purchasing FreeRTOS documentation will not only help you, by       *

+     *    ensuring you get running as quickly as possible and with an        *

+     *    in-depth knowledge of how to use FreeRTOS, it will also help       *

+     *    the FreeRTOS project to continue with its mission of providing     *

+     *    professional grade, cross platform, de facto standard solutions    *

+     *    for microcontrollers - completely free of charge!                  *

+     *                                                                       *

+     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *

+     *                                                                       *

+     *    Thank you for using FreeRTOS, and thank you for your support!      *

+     *                                                                       *

+    ***************************************************************************

+

+

+    This file is part of the FreeRTOS distribution.

+

+    FreeRTOS is free software; you can redistribute it and/or modify it under

+    the terms of the GNU General Public License (version 2) as published by the

+    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.

+    >>>NOTE<<< The modification to the GPL is included to allow you to

+    distribute a combined work that includes FreeRTOS without being obliged to

+    provide the source code for proprietary components outside of the FreeRTOS

+    kernel.  FreeRTOS is distributed in the hope that it will be useful, but

+    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY

+    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for

+    more details. You should have received a copy of the GNU General Public

+    License and the FreeRTOS license exception along with FreeRTOS; if not it

+    can be viewed here: http://www.freertos.org/a00114.html and also obtained

+    by writing to Richard Barry, contact details for whom are available on the

+    FreeRTOS WEB site.

+

+    1 tab == 4 spaces!

+    

+    ***************************************************************************

+     *                                                                       *

+     *    Having a problem?  Start by reading the FAQ "My application does   *

+     *    not run, what could be wrong?                                      *

+     *                                                                       *

+     *    http://www.FreeRTOS.org/FAQHelp.html                               *

+     *                                                                       *

+    ***************************************************************************

+

+    

+    http://www.FreeRTOS.org - Documentation, training, latest information, 

+    license and contact details.

+    

+    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,

+    including FreeRTOS+Trace - an indispensable productivity tool.

+

+    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell 

+    the code with commercial support, indemnification, and middleware, under 

+    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also

+    provide a safety engineered and independently SIL3 certified version under 

+    the SafeRTOS brand: http://www.SafeRTOS.com.

+*/

+

+/* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining

+all the API functions to use the MPU wrappers.  That should only be done when

+task.h is included from an application file. */

+#define MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+#include "FreeRTOS.h"

+#include "task.h"

+#include "queue.h"

+#include "timers.h"

+#include "static-allocator.h"

+

+#undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE

+

+/* This entire source file will be skipped if the application is not configured

+to include software timer functionality.  This #if is closed at the very bottom

+of this file.  If you want to include software timer functionality then ensure

+configUSE_TIMERS is set to 1 in FreeRTOSConfig.h. */

+#if ( configUSE_TIMERS == 1 )

+

+/* Misc definitions. */

+#define tmrNO_DELAY		( portTickType ) 0U

+

+/* The definition of the timers themselves. */

+typedef struct tmrTimerControl

+{

+	const signed char		*pcTimerName;		/*<< Text name.  This is not used by the kernel, it is included simply to make debugging easier. */

+	xListItem				xTimerListItem;		/*<< Standard linked list item as used by all kernel features for event management. */

+	portTickType			xTimerPeriodInTicks;/*<< How quickly and often the timer expires. */

+	unsigned portBASE_TYPE	uxAutoReload;		/*<< Set to pdTRUE if the timer should be automatically restarted once expired.  Set to pdFALSE if the timer is, in effect, a one shot timer. */

+	void 					*pvTimerID;			/*<< An ID to identify the timer.  This allows the timer to be identified when the same callback is used for multiple timers. */

+	tmrTIMER_CALLBACK		pxCallbackFunction;	/*<< The function that will be called when the timer expires. */

+} xTIMER;

+

+#ifndef configMAX_NUM_OF_TIMERS

+#define configMAX_NUM_OF_TIMERS (32)

+#endif

+#define NUM_OF_TIMER_FLAGS ((configMAX_NUM_OF_TIMERS+31)/32)

+static xTIMER sNlTimers[configMAX_NUM_OF_TIMERS];

+static uint32_t sNlTimersFlags[NUM_OF_TIMER_FLAGS];

+static static_pool_t sTimersPool;

+

+/* The definition of messages that can be sent and received on the timer

+queue. */

+typedef struct tmrTimerQueueMessage

+{

+	portBASE_TYPE			xMessageID;			/*<< The command being sent to the timer service task. */

+	portTickType			xMessageValue;		/*<< An optional value used by a subset of commands, for example, when changing the period of a timer. */

+	xTIMER *				pxTimer;			/*<< The timer to which the command will be applied. */

+} xTIMER_MESSAGE;

+

+

+/* The list in which active timers are stored.  Timers are referenced in expire

+time order, with the nearest expiry time at the front of the list.  Only the

+timer service task is allowed to access xActiveTimerList. */

+PRIVILEGED_DATA static xList xActiveTimerList1;

+PRIVILEGED_DATA static xList xActiveTimerList2;

+PRIVILEGED_DATA static xList *pxCurrentTimerList;

+PRIVILEGED_DATA static xList *pxOverflowTimerList;

+

+/* A queue that is used to send commands to the timer service task. */

+PRIVILEGED_DATA static xQueueHandle xTimerQueue = NULL;

+

+#if ( INCLUDE_xTimerGetTimerDaemonTaskHandle == 1 )

+	

+	PRIVILEGED_DATA static xTaskHandle xTimerTaskHandle = NULL;

+	

+#endif

+

+/*-----------------------------------------------------------*/

+

+void xInitTimers(void);

+

+

+/*

+ * Initialise the infrastructure used by the timer service task if it has not

+ * been initialised already.

+ */

+static void prvCheckForValidListAndQueue( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * The timer service task (daemon).  Timer functionality is controlled by this

+ * task.  Other tasks communicate with the timer service task using the

+ * xTimerQueue queue.

+ */

+static void prvTimerTask( void *pvParameters ) PRIVILEGED_FUNCTION;

+

+/*

+ * Called by the timer service task to interpret and process a command it

+ * received on the timer queue.

+ */

+static void	prvProcessReceivedCommands( void ) PRIVILEGED_FUNCTION;

+

+/*

+ * Insert the timer into either xActiveTimerList1, or xActiveTimerList2,

+ * depending on if the expire time causes a timer counter overflow.

+ */

+static portBASE_TYPE prvInsertTimerInActiveList( xTIMER *pxTimer, portTickType xNextExpiryTime, portTickType xTimeNow, portTickType xCommandTime ) PRIVILEGED_FUNCTION;

+

+/*

+ * An active timer has reached its expire time.  Reload the timer if it is an

+ * auto reload timer, then call its callback.

+ */

+static void prvProcessExpiredTimer( portTickType xNextExpireTime, portTickType xTimeNow ) PRIVILEGED_FUNCTION;

+

+/*

+ * The tick count has overflowed.  Switch the timer lists after ensuring the

+ * current timer list does not still reference some timers.

+ */

+static void prvSwitchTimerLists( portTickType xLastTime ) PRIVILEGED_FUNCTION;

+

+/*

+ * Obtain the current tick count, setting *pxTimerListsWereSwitched to pdTRUE

+ * if a tick count overflow occurred since prvSampleTimeNow() was last called.

+ */

+static portTickType prvSampleTimeNow( portBASE_TYPE *pxTimerListsWereSwitched ) PRIVILEGED_FUNCTION;

+

+/*

+ * If the timer list contains any active timers then return the expire time of

+ * the timer that will expire first and set *pxListWasEmpty to false.  If the

+ * timer list does not contain any timers then return 0 and set *pxListWasEmpty

+ * to pdTRUE.

+ */

+static portTickType prvGetNextExpireTime( portBASE_TYPE *pxListWasEmpty ) PRIVILEGED_FUNCTION;

+

+/*

+ * If a timer has expired, process it.  Otherwise, block the timer service task

+ * until either a timer does expire or a command is received.

+ */

+static void prvProcessTimerOrBlockTask( portTickType xNextExpireTime, portBASE_TYPE xListWasEmpty ) PRIVILEGED_FUNCTION;

+

+/*-----------------------------------------------------------*/

+

+#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))

+

+void xInitTimers(void)

+{

+    poolInit( &sTimersPool,

+              sizeof(sNlTimers[0]),

+              ARRAY_SIZE(sNlTimers),

+              &sNlTimers,

+              &sNlTimersFlags);

+}

+

+static portSTACK_TYPE sTimerStack[configTIMER_TASK_STACK_DEPTH];

+

+portBASE_TYPE xTimerCreateTimerTask( void )

+{

+portBASE_TYPE xReturn = pdFAIL;

+

+	/* This function is called when the scheduler is started if

+	configUSE_TIMERS is set to 1.  Check that the infrastructure used by the

+	timer service task has been created/initialised.  If timers have already

+	been created then the initialisation will already have been performed. */

+	prvCheckForValidListAndQueue();

+

+	if( xTimerQueue != NULL )

+	{

+		#if ( INCLUDE_xTimerGetTimerDaemonTaskHandle == 1 )

+		{

+			/* Create the timer task, storing its handle in xTimerTaskHandle so

+			it can be returned by the xTimerGetTimerDaemonTaskHandle() function. */

+			xReturn = xTaskGenericCreate( prvTimerTask, ( const signed char * ) "Tmr Svc", ( unsigned short ) configTIMER_TASK_STACK_DEPTH, NULL, ( ( unsigned portBASE_TYPE ) configTIMER_TASK_PRIORITY ) | portPRIVILEGE_BIT, &xTimerTaskHandle, (portSTACK_TYPE*)&sTimerStack, NULL );	

+		}

+		#else

+		{

+			/* Create the timer task without storing its handle. */

+			xReturn = xTaskGenericCreate( prvTimerTask, ( const signed char * ) "Tmr Svc", ( unsigned short ) configTIMER_TASK_STACK_DEPTH, NULL, ( ( unsigned portBASE_TYPE ) configTIMER_TASK_PRIORITY ) | portPRIVILEGE_BIT, NULL, (portSTACK_TYPE*)&sTimerStack, NULL);

+		}

+		#endif

+	}

+

+	configASSERT( xReturn );

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+xTimerHandle xTimerCreate( const signed char *pcTimerName, portTickType xTimerPeriodInTicks, unsigned portBASE_TYPE uxAutoReload, void *pvTimerID, tmrTIMER_CALLBACK pxCallbackFunction )

+{

+xTIMER *pxNewTimer;

+

+	/* Allocate the timer structure. */

+	if( xTimerPeriodInTicks == ( portTickType ) 0U )

+	{

+		pxNewTimer = NULL;

+		configASSERT( ( xTimerPeriodInTicks > 0 ) );

+	}

+	else

+	{

+		pxNewTimer = ( xTIMER * ) poolAllocateBuffer(&sTimersPool);

+		if( pxNewTimer != NULL )

+		{

+			/* Ensure the infrastructure used by the timer service task has been

+			created/initialised. */

+			prvCheckForValidListAndQueue();

+	

+			/* Initialise the timer structure members using the function parameters. */

+			pxNewTimer->pcTimerName = pcTimerName;

+			pxNewTimer->xTimerPeriodInTicks = xTimerPeriodInTicks;

+			pxNewTimer->uxAutoReload = uxAutoReload;

+			pxNewTimer->pvTimerID = pvTimerID;

+			pxNewTimer->pxCallbackFunction = pxCallbackFunction;

+			vListInitialiseItem( &( pxNewTimer->xTimerListItem ) );

+			

+			traceTIMER_CREATE( pxNewTimer );

+		}

+		else

+		{

+			traceTIMER_CREATE_FAILED();

+		}

+	}

+	

+	return ( xTimerHandle ) pxNewTimer;

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xTimerGenericCommand( xTimerHandle xTimer, portBASE_TYPE xCommandID, portTickType xOptionalValue, signed portBASE_TYPE *pxHigherPriorityTaskWoken, portTickType xBlockTime )

+{

+portBASE_TYPE xReturn = pdFAIL;

+xTIMER_MESSAGE xMessage;

+

+	/* Send a message to the timer service task to perform a particular action

+	on a particular timer definition. */

+	if( xTimerQueue != NULL )

+	{

+		/* Send a command to the timer service task to start the xTimer timer. */

+		xMessage.xMessageID = xCommandID;

+		xMessage.xMessageValue = xOptionalValue;

+		xMessage.pxTimer = ( xTIMER * ) xTimer;

+

+		if( pxHigherPriorityTaskWoken == NULL )

+		{

+			if( xTaskGetSchedulerState() == taskSCHEDULER_RUNNING )

+			{

+				xReturn = xQueueSendToBack( xTimerQueue, &xMessage, xBlockTime );

+			}

+			else

+			{

+				xReturn = xQueueSendToBack( xTimerQueue, &xMessage, tmrNO_DELAY );

+			}

+		}

+		else

+		{

+			xReturn = xQueueSendToBackFromISR( xTimerQueue, &xMessage, pxHigherPriorityTaskWoken );

+		}

+		

+		traceTIMER_COMMAND_SEND( xTimer, xCommandID, xOptionalValue, xReturn );

+	}

+	

+	return xReturn;

+}

+/*-----------------------------------------------------------*/

+

+#if ( INCLUDE_xTimerGetTimerDaemonTaskHandle == 1 )

+

+	xTaskHandle xTimerGetTimerDaemonTaskHandle( void )

+	{

+		/* If xTimerGetTimerDaemonTaskHandle() is called before the scheduler has been

+		started, then xTimerTaskHandle will be NULL. */

+		configASSERT( ( xTimerTaskHandle != NULL ) );

+		return xTimerTaskHandle;

+	}

+	

+#endif

+/*-----------------------------------------------------------*/

+

+static void prvProcessExpiredTimer( portTickType xNextExpireTime, portTickType xTimeNow )

+{

+xTIMER *pxTimer;

+portBASE_TYPE xResult;

+

+	/* Remove the timer from the list of active timers.  A check has already

+	been performed to ensure the list is not empty. */

+	pxTimer = ( xTIMER * ) listGET_OWNER_OF_HEAD_ENTRY( pxCurrentTimerList );

+	vListRemove( &( pxTimer->xTimerListItem ) );

+	traceTIMER_EXPIRED( pxTimer );

+

+	/* If the timer is an auto reload timer then calculate the next

+	expiry time and re-insert the timer in the list of active timers. */

+	if( pxTimer->uxAutoReload == ( unsigned portBASE_TYPE ) pdTRUE )

+	{

+		/* This is the only time a timer is inserted into a list using

+		a time relative to anything other than the current time.  It

+		will therefore be inserted into the correct list relative to

+		the time this task thinks it is now, even if a command to

+		switch lists due to a tick count overflow is already waiting in

+		the timer queue. */

+		if( prvInsertTimerInActiveList( pxTimer, ( xNextExpireTime + pxTimer->xTimerPeriodInTicks ), xTimeNow, xNextExpireTime ) == pdTRUE )

+		{

+			/* The timer expired before it was added to the active timer

+			list.  Reload it now.  */

+			xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START, xNextExpireTime, NULL, tmrNO_DELAY );

+			configASSERT( xResult );

+			( void ) xResult;

+		}

+	}

+

+	/* Call the timer callback. */

+	pxTimer->pxCallbackFunction( ( xTimerHandle ) pxTimer );

+}

+/*-----------------------------------------------------------*/

+

+static void prvTimerTask( void *pvParameters )

+{

+portTickType xNextExpireTime;

+portBASE_TYPE xListWasEmpty;

+

+	/* Just to avoid compiler warnings. */

+	( void ) pvParameters;

+

+	for( ;; )

+	{

+		/* Query the timers list to see if it contains any timers, and if so,

+		obtain the time at which the next timer will expire. */

+		xNextExpireTime = prvGetNextExpireTime( &xListWasEmpty );

+

+		/* If a timer has expired, process it.  Otherwise, block this task

+		until either a timer does expire, or a command is received. */

+		prvProcessTimerOrBlockTask( xNextExpireTime, xListWasEmpty );

+		

+		/* Empty the command queue. */

+		prvProcessReceivedCommands();		

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvProcessTimerOrBlockTask( portTickType xNextExpireTime, portBASE_TYPE xListWasEmpty )

+{

+portTickType xTimeNow;

+portBASE_TYPE xTimerListsWereSwitched;

+

+	vTaskSuspendAll();

+	{

+		/* Obtain the time now to make an assessment as to whether the timer

+		has expired or not.  If obtaining the time causes the lists to switch

+		then don't process this timer as any timers that remained in the list

+		when the lists were switched will have been processed within the

+		prvSampelTimeNow() function. */

+		xTimeNow = prvSampleTimeNow( &xTimerListsWereSwitched );

+		if( xTimerListsWereSwitched == pdFALSE )

+		{

+			/* The tick count has not overflowed, has the timer expired? */

+			if( ( xListWasEmpty == pdFALSE ) && ( xNextExpireTime <= xTimeNow ) )

+			{

+				xTaskResumeAll();

+				prvProcessExpiredTimer( xNextExpireTime, xTimeNow );

+			}

+			else

+			{

+				/* The tick count has not overflowed, and the next expire

+				time has not been reached yet.  This task should therefore

+				block to wait for the next expire time or a command to be

+				received - whichever comes first.  The following line cannot

+				be reached unless xNextExpireTime > xTimeNow, except in the

+				case when the current timer list is empty. */

+				vQueueWaitForMessageRestricted( xTimerQueue, ( xNextExpireTime - xTimeNow ) );

+

+				if( xTaskResumeAll() == pdFALSE )

+				{

+					/* Yield to wait for either a command to arrive, or the block time

+					to expire.  If a command arrived between the critical section being

+					exited and this yield then the yield will not cause the task

+					to block. */

+					portYIELD_WITHIN_API();

+				}

+			}

+		}

+		else

+		{

+			xTaskResumeAll();

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+static portTickType prvGetNextExpireTime( portBASE_TYPE *pxListWasEmpty )

+{

+portTickType xNextExpireTime;

+

+	/* Timers are listed in expiry time order, with the head of the list

+	referencing the task that will expire first.  Obtain the time at which

+	the timer with the nearest expiry time will expire.  If there are no

+	active timers then just set the next expire time to 0.  That will cause

+	this task to unblock when the tick count overflows, at which point the

+	timer lists will be switched and the next expiry time can be

+	re-assessed.  */

+	*pxListWasEmpty = listLIST_IS_EMPTY( pxCurrentTimerList );

+	if( *pxListWasEmpty == pdFALSE )

+	{

+		xNextExpireTime = listGET_ITEM_VALUE_OF_HEAD_ENTRY( pxCurrentTimerList );

+	}

+	else

+	{

+		/* Ensure the task unblocks when the tick count rolls over. */

+		xNextExpireTime = ( portTickType ) 0U;

+	}

+

+	return xNextExpireTime;

+}

+/*-----------------------------------------------------------*/

+

+static portTickType prvSampleTimeNow( portBASE_TYPE *pxTimerListsWereSwitched )

+{

+portTickType xTimeNow;

+PRIVILEGED_DATA static portTickType xLastTime = ( portTickType ) 0U;

+

+	xTimeNow = xTaskGetTickCount();

+	

+	if( xTimeNow < xLastTime )

+	{

+		prvSwitchTimerLists( xLastTime );

+		*pxTimerListsWereSwitched = pdTRUE;

+	}

+	else

+	{

+		*pxTimerListsWereSwitched = pdFALSE;

+	}

+	

+	xLastTime = xTimeNow;

+	

+	return xTimeNow;

+}

+/*-----------------------------------------------------------*/

+

+static portBASE_TYPE prvInsertTimerInActiveList( xTIMER *pxTimer, portTickType xNextExpiryTime, portTickType xTimeNow, portTickType xCommandTime )

+{

+portBASE_TYPE xProcessTimerNow = pdFALSE;

+

+	listSET_LIST_ITEM_VALUE( &( pxTimer->xTimerListItem ), xNextExpiryTime );

+	listSET_LIST_ITEM_OWNER( &( pxTimer->xTimerListItem ), pxTimer );

+	

+	if( xNextExpiryTime <= xTimeNow )

+	{

+		/* Has the expiry time elapsed between the command to start/reset a

+		timer was issued, and the time the command was processed? */

+		if( ( ( portTickType ) ( xTimeNow - xCommandTime ) ) >= pxTimer->xTimerPeriodInTicks )

+		{

+			/* The time between a command being issued and the command being

+			processed actually exceeds the timers period.  */

+			xProcessTimerNow = pdTRUE;

+		}

+		else

+		{

+			vListInsert( pxOverflowTimerList, &( pxTimer->xTimerListItem ) );

+		}

+	}

+	else

+	{

+		if( ( xTimeNow < xCommandTime ) && ( xNextExpiryTime >= xCommandTime ) )

+		{

+			/* If, since the command was issued, the tick count has overflowed

+			but the expiry time has not, then the timer must have already passed

+			its expiry time and should be processed immediately. */

+			xProcessTimerNow = pdTRUE;

+		}

+		else

+		{

+			vListInsert( pxCurrentTimerList, &( pxTimer->xTimerListItem ) );

+		}

+	}

+

+	return xProcessTimerNow;

+}

+/*-----------------------------------------------------------*/

+

+static void	prvProcessReceivedCommands( void )

+{

+xTIMER_MESSAGE xMessage;

+xTIMER *pxTimer;

+portBASE_TYPE xTimerListsWereSwitched, xResult;

+portTickType xTimeNow;

+

+	while( xQueueReceive( xTimerQueue, &xMessage, tmrNO_DELAY ) != pdFAIL )

+	{

+		pxTimer = xMessage.pxTimer;

+

+		/* Is the timer already in a list of active timers?  When the command

+		is trmCOMMAND_PROCESS_TIMER_OVERFLOW, the timer will be NULL as the

+		command is to the task rather than to an individual timer. */

+		if( pxTimer != NULL )

+		{

+			if( listIS_CONTAINED_WITHIN( NULL, &( pxTimer->xTimerListItem ) ) == pdFALSE )

+			{

+				/* The timer is in a list, remove it. */

+				vListRemove( &( pxTimer->xTimerListItem ) );

+			}

+		}

+

+		traceTIMER_COMMAND_RECEIVED( pxTimer, xMessage.xMessageID, xMessage.xMessageValue );

+		

+       /* In this case the xTimerListsWereSwitched parameter is not used, but

+		  it must be present in the function call.  prvSampleTimeNow() must be

+          called after the message is received from xTimerQueue so there is no

+          possibility of a higher priority task adding a message to the message

+          queue with a time that is ahead of the timer daemon task (because it

+          pre-empted the timer daemon task after the xTimeNow value was set). */

+

+        xTimeNow = prvSampleTimeNow( &xTimerListsWereSwitched );

+

+		switch( xMessage.xMessageID )

+		{

+			case tmrCOMMAND_START :	

+				/* Start or restart a timer. */

+				if( prvInsertTimerInActiveList( pxTimer,  xMessage.xMessageValue + pxTimer->xTimerPeriodInTicks, xTimeNow, xMessage.xMessageValue ) == pdTRUE )

+				{

+					/* The timer expired before it was added to the active timer

+					list.  Process it now. */

+					pxTimer->pxCallbackFunction( ( xTimerHandle ) pxTimer );

+

+					if( pxTimer->uxAutoReload == ( unsigned portBASE_TYPE ) pdTRUE )

+					{

+						xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START, xMessage.xMessageValue + pxTimer->xTimerPeriodInTicks, NULL, tmrNO_DELAY );

+						configASSERT( xResult );

+						( void ) xResult;

+					}

+				}

+				break;

+

+			case tmrCOMMAND_STOP :	

+				/* The timer has already been removed from the active list.

+				There is nothing to do here. */

+				break;

+

+			case tmrCOMMAND_CHANGE_PERIOD :

+				pxTimer->xTimerPeriodInTicks = xMessage.xMessageValue;

+				configASSERT( ( pxTimer->xTimerPeriodInTicks > 0 ) );

+				prvInsertTimerInActiveList( pxTimer, ( xTimeNow + pxTimer->xTimerPeriodInTicks ), xTimeNow, xTimeNow );

+				break;

+

+			case tmrCOMMAND_DELETE :

+				/* The timer has already been removed from the active list,

+				just free up the memory. */

+                poolFreeBuffer(&sTimersPool, pxTimer);

+				break;

+

+			default	:			

+				/* Don't expect to get here. */

+				break;

+		}

+	}

+}

+/*-----------------------------------------------------------*/

+

+static void prvSwitchTimerLists( portTickType xLastTime )

+{

+portTickType xNextExpireTime, xReloadTime;

+xList *pxTemp;

+xTIMER *pxTimer;

+portBASE_TYPE xResult;

+

+	/* Remove compiler warnings if configASSERT() is not defined. */

+	( void ) xLastTime;

+	

+	/* The tick count has overflowed.  The timer lists must be switched.

+	If there are any timers still referenced from the current timer list

+	then they must have expired and should be processed before the lists

+	are switched. */

+	while( listLIST_IS_EMPTY( pxCurrentTimerList ) == pdFALSE )

+	{

+		xNextExpireTime = listGET_ITEM_VALUE_OF_HEAD_ENTRY( pxCurrentTimerList );

+

+		/* Remove the timer from the list. */

+		pxTimer = ( xTIMER * ) listGET_OWNER_OF_HEAD_ENTRY( pxCurrentTimerList );

+		vListRemove( &( pxTimer->xTimerListItem ) );

+

+		/* Execute its callback, then send a command to restart the timer if

+		it is an auto-reload timer.  It cannot be restarted here as the lists

+		have not yet been switched. */

+		pxTimer->pxCallbackFunction( ( xTimerHandle ) pxTimer );

+

+		if( pxTimer->uxAutoReload == ( unsigned portBASE_TYPE ) pdTRUE )

+		{

+			/* Calculate the reload value, and if the reload value results in

+			the timer going into the same timer list then it has already expired

+			and the timer should be re-inserted into the current list so it is

+			processed again within this loop.  Otherwise a command should be sent

+			to restart the timer to ensure it is only inserted into a list after

+			the lists have been swapped. */

+			xReloadTime = ( xNextExpireTime + pxTimer->xTimerPeriodInTicks );

+			if( xReloadTime > xNextExpireTime )

+			{

+				listSET_LIST_ITEM_VALUE( &( pxTimer->xTimerListItem ), xReloadTime );

+				listSET_LIST_ITEM_OWNER( &( pxTimer->xTimerListItem ), pxTimer );

+				vListInsert( pxCurrentTimerList, &( pxTimer->xTimerListItem ) );

+			}

+			else

+			{

+				xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START, xNextExpireTime, NULL, tmrNO_DELAY );

+				configASSERT( xResult );

+				( void ) xResult;

+			}

+		}

+	}

+

+	pxTemp = pxCurrentTimerList;

+	pxCurrentTimerList = pxOverflowTimerList;

+	pxOverflowTimerList = pxTemp;

+}

+/*-----------------------------------------------------------*/

+

+static struct {

+    xTIMER_MESSAGE messages[configTIMER_QUEUE_LENGTH];

+    uint8_t extra;

+} timersQueue;

+

+static void prvCheckForValidListAndQueue( void )

+{

+	/* Check that the list from which active timers are referenced, and the

+	queue used to communicate with the timer service, have been

+	initialised. */

+	taskENTER_CRITICAL();

+	{

+		if( xTimerQueue == NULL )

+		{

+			vListInitialise( &xActiveTimerList1 );

+			vListInitialise( &xActiveTimerList2 );

+			pxCurrentTimerList = &xActiveTimerList1;

+			pxOverflowTimerList = &xActiveTimerList2;

+			xTimerQueue = xQueueCreate( (void*) &timersQueue, ( unsigned portBASE_TYPE ) configTIMER_QUEUE_LENGTH, sizeof( xTIMER_MESSAGE ) );

+		}

+	}

+	taskEXIT_CRITICAL();

+}

+/*-----------------------------------------------------------*/

+

+portBASE_TYPE xTimerIsTimerActive( xTimerHandle xTimer )

+{

+portBASE_TYPE xTimerIsInActiveList;

+xTIMER *pxTimer = ( xTIMER * ) xTimer;

+

+	/* Is the timer in the list of active timers? */

+	taskENTER_CRITICAL();

+	{

+		/* Checking to see if it is in the NULL list in effect checks to see if

+		it is referenced from either the current or the overflow timer lists in

+		one go, but the logic has to be reversed, hence the '!'. */

+		xTimerIsInActiveList = !( listIS_CONTAINED_WITHIN( NULL, &( pxTimer->xTimerListItem ) ) );

+	}

+	taskEXIT_CRITICAL();

+

+	return xTimerIsInActiveList;

+}

+/*-----------------------------------------------------------*/

+

+void *pvTimerGetTimerID( xTimerHandle xTimer )

+{

+xTIMER *pxTimer = ( xTIMER * ) xTimer;

+

+	return pxTimer->pvTimerID;

+}

+/*-----------------------------------------------------------*/

+

+/* This entire source file will be skipped if the application is not configured

+to include software timer functionality.  If you want to include software timer

+functionality then ensure configUSE_TIMERS is set to 1 in FreeRTOSConfig.h. */

+#endif /* configUSE_TIMERS == 1 */

diff --git a/FreeRTOS/readme.txt b/FreeRTOS/readme.txt
new file mode 100644
index 0000000..13ddc51
--- /dev/null
+++ b/FreeRTOS/readme.txt
@@ -0,0 +1,21 @@
+Directories:

+

++ The FreeRTOS/Source directory contains the FreeRTOS source code, and contains

+  its own readme file.

+

++ The FreeRTOS/Demo directory contains a demo application for every official

+FreeRTOS port, and contains its own readme file.

+

++ See http://www.freertos.org/a00017.html for full details of the directory 

+  structure and information on locating the files you require.

+

+The easiest way to use FreeRTOS is to start with one of the pre-configured demo 

+application projects (found in the FreeRTOS/Demo directory).  That way you will

+have the correct FreeRTOS source files included, and the correct include paths

+configured.  Once a demo application is building and executing you can remove

+the demo application file, and start to add in your own application source

+files.

+

+See also -

+http://www.freertos.org/FreeRTOS-quick-start-guide.html

+http://www.freertos.org/FAQHelp.html

diff --git a/readme.txt b/readme.txt
new file mode 100644
index 0000000..720332d
--- /dev/null
+++ b/readme.txt
@@ -0,0 +1,32 @@
+Directories:

+

++ FreeRTOS/source contains the FreeRTOS real time kernel source code.

+

++ FreeRTOS/demo contains a pre-configured demo project for every official 

+  FreeRTOS port.

+  

++ FreeRTOS-Plus contains additional FreeRTOS components and third party 

+  complementary products.  THESE ARE LICENSED SEPARATELY FROM FreeRTOS although

+  all contain open source options.  See the license files in each respective

+  directory for information.

+  

++ FreeRTOS-Plus/Demo_Projects_Using_FreeRTOS_Simulator contains pre-configured

+  demo projects for the FreeRTOS-Plus components.  The demo projects run in

+  a Windows environment using the FreeRTOS windows simulator.  These are 

+  documented on the FreeRTOS web site http://www.FreeRTOS.org/plus

+

++ See http://www.freertos.org/a00017.html for full details of the directory 

+  structure and information on locating the files you require.

+

+Further readme files are contains in sub-directories as appropriate.

+  

+The easiest way to use FreeRTOS is to start with one of the pre-configured demo 

+application projects (found in the FreeRTOS/Demo directory).  That way you will

+have the correct FreeRTOS source files included, and the correct include paths

+configured.  Once a demo application is building and executing you can remove

+the demo application file, and start to add in your own application source

+files.

+

+See also -

+http://www.freertos.org/FreeRTOS-quick-start-guide.html

+http://www.freertos.org/FAQHelp.html