From 6cd7146804757bd8671da85a0a475874b143d0a4 Mon Sep 17 00:00:00 2001
From: Razvalyaev <wot890089@mail.ru>
Date: Thu, 16 Jan 2025 15:39:04 +0300
Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?=
 =?UTF-8?q?=D0=BD=D1=8B=20=D0=B1=D0=B8=D0=B1=D0=BB=D0=B8=D0=BE=D1=82=D0=B5?=
 =?UTF-8?q?=D0=BA=D0=B8=20DSP281x?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 Inu/{ => main_matlab}/def.h                   |    2 +-
 Inu/main_matlab/device_support/ReadMe.txt     |    1 +
 .../device_support/include/C28x_FPU_FastRTS.h |   69 +
 .../device_support/include/DSP281x_Adc.h      |  225 ++++
 .../include/DSP281x_CpuTimers.h               |  185 +++
 .../include/DSP281x_DefaultISR.h              |  124 ++
 .../device_support/include/DSP281x_DevEmu.h   |  104 ++
 .../device_support/include/DSP281x_Device.h   |  145 ++
 .../device_support/include/DSP281x_ECan.h     | 1164 +++++++++++++++++
 .../device_support/include/DSP281x_Ev.h       |  655 ++++++++++
 .../device_support/include/DSP281x_Examples.h |    1 +
 .../include/DSP281x_GlobalPrototypes.h        |    0
 .../device_support/include/DSP281x_Gpio.h     | 1035 +++++++++++++++
 .../device_support/include/DSP281x_Mcbsp.h    |  778 +++++++++++
 .../device_support/include/DSP281x_PieCtrl.h  |  154 +++
 .../device_support/include/DSP281x_PieVect.h  |  210 +++
 .../include/DSP281x_SWPrioritizedIsrLevels.h  |    1 +
 .../device_support/include/DSP281x_Sci.h      |  234 ++++
 .../device_support/include/DSP281x_Spi.h      |  184 +++
 .../device_support/include/DSP281x_SysCtrl.h  |  326 +++++
 .../device_support/include/DSP281x_XIntrupt.h |   79 ++
 .../device_support/include/DSP281x_Xintf.h    |  112 ++
 .../device_support/include/DSP2833x_Adc.h     |  258 ++++
 .../include/DSP2833x_CpuTimers.h              |  184 +++
 .../device_support/include/DSP2833x_DMA.h     |  290 ++++
 .../device_support/include/DSP2833x_DevEmu.h  |   88 ++
 .../device_support/include/DSP2833x_Device.h  |  203 +++
 .../device_support/include/DSP2833x_ECan.h    | 1155 ++++++++++++++++
 .../device_support/include/DSP2833x_ECap.h    |  145 ++
 .../device_support/include/DSP2833x_EPwm.h    |  424 ++++++
 .../device_support/include/DSP2833x_EQep.h    |  236 ++++
 .../device_support/include/DSP2833x_Gpio.h    |  385 ++++++
 .../device_support/include/DSP2833x_I2c.h     |  187 +++
 .../device_support/include/DSP2833x_Mcbsp.h   |  709 ++++++++++
 .../device_support/include/DSP2833x_PieCtrl.h |  148 +++
 .../device_support/include/DSP2833x_PieVect.h |  202 +++
 .../device_support/include/DSP2833x_Sci.h     |  229 ++++
 .../device_support/include/DSP2833x_Spi.h     |  177 +++
 .../device_support/include/DSP2833x_SysCtrl.h |  376 ++++++
 .../include/DSP2833x_XIntrupt.h               |   76 ++
 .../device_support/include/DSP2833x_Xintf.h   |  114 ++
 .../device_support/include/IQmathLib.h        |  687 ++++++++++
 .../include/SimSupport_GlobalPrototypes.h     |    5 +
 .../device_support/include/dmctype.h          |   32 +
 .../device_support/source/C28x_FPU_FastRTS.c  |   52 +
 .../source/C28x_FPU_FastRTS.obj               |  Bin 0 -> 1685 bytes
 .../source/DSP281x_GlobalVariableDefs.c       |  265 ++++
 .../source/DSP2833x_GlobalVariableDefs.c      |  198 +++
 .../source/DSP2833x_GlobalVariableDefs.obj    |  Bin 0 -> 2096 bytes
 .../device_support/source/IQmathLib_matlab.c  |  237 ++++
 inu_23550.slx                                 |  Bin 85858 -> 86465 bytes
 run_mex.bat                                   |   11 +-
 52 files changed, 12855 insertions(+), 6 deletions(-)
 rename Inu/{ => main_matlab}/def.h (99%)
 create mode 100644 Inu/main_matlab/device_support/ReadMe.txt
 create mode 100644 Inu/main_matlab/device_support/include/C28x_FPU_FastRTS.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Adc.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_CpuTimers.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_DefaultISR.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_DevEmu.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Device.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_ECan.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Ev.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Examples.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_GlobalPrototypes.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Gpio.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Mcbsp.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_PieCtrl.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_PieVect.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_SWPrioritizedIsrLevels.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Sci.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Spi.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_SysCtrl.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_XIntrupt.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP281x_Xintf.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Adc.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_CpuTimers.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_DMA.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_DevEmu.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Device.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_ECan.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_ECap.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_EPwm.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_EQep.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Gpio.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_I2c.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Mcbsp.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_PieCtrl.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_PieVect.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Sci.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Spi.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_SysCtrl.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_XIntrupt.h
 create mode 100644 Inu/main_matlab/device_support/include/DSP2833x_Xintf.h
 create mode 100644 Inu/main_matlab/device_support/include/IQmathLib.h
 create mode 100644 Inu/main_matlab/device_support/include/SimSupport_GlobalPrototypes.h
 create mode 100644 Inu/main_matlab/device_support/include/dmctype.h
 create mode 100644 Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.c
 create mode 100644 Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.obj
 create mode 100644 Inu/main_matlab/device_support/source/DSP281x_GlobalVariableDefs.c
 create mode 100644 Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.c
 create mode 100644 Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.obj
 create mode 100644 Inu/main_matlab/device_support/source/IQmathLib_matlab.c

diff --git a/Inu/def.h b/Inu/main_matlab/def.h
similarity index 99%
rename from Inu/def.h
rename to Inu/main_matlab/def.h
index d0a2d3a..6e1786f 100644
--- a/Inu/def.h
+++ b/Inu/main_matlab/def.h
@@ -207,7 +207,7 @@
 // ���������� �����/������ (end)
 
 
-#include "DSP2833x_Device.h"
+#include "DSP281x_Device.h"
 #include "math.h"
 #include "C28x_FPU_FastRTS.h"
 
diff --git a/Inu/main_matlab/device_support/ReadMe.txt b/Inu/main_matlab/device_support/ReadMe.txt
new file mode 100644
index 0000000..5fbccf6
--- /dev/null
+++ b/Inu/main_matlab/device_support/ReadMe.txt
@@ -0,0 +1 @@
+������ ��� ���������� S-function � MATLAB.
diff --git a/Inu/main_matlab/device_support/include/C28x_FPU_FastRTS.h b/Inu/main_matlab/device_support/include/C28x_FPU_FastRTS.h
new file mode 100644
index 0000000..03f921e
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/C28x_FPU_FastRTS.h
@@ -0,0 +1,69 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: July 10, 2008   16:11:44 $
+//###########################################################################
+//  This software is licensed for use with Texas Instruments C28x
+//  family DSCs.  This license was provided to you prior to installing
+//  the software.  You may review this license by consulting a copy of
+//  the agreement in the doc directory of this library.
+// ------------------------------------------------------------------------
+//          Copyright (C) 2007 Texas Instruments, Incorporated.
+//                          All Rights Reserved.
+// ==========================================================================
+//
+// FILE:   C28x_FPU_FastRTS.h
+//
+// TITLE:  Prototypes and Definitions for the C28x Fast RTS Library
+//
+// DESCRIPTION:
+//
+//         These prototypes are for functions not found in the standard
+//         RTS library.
+//
+//         For standard functions, include the appropriate header file as
+//         usual.  For example: math.h
+//
+//###########################################################################
+// $TI Release: C28x FPU fastRTS Library V1.00 $
+// $Release Date: August 6, 2008 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef C28X_FPU_FAST_RTS_H
+#define C28X_FPU_FAST_RTS_H
+
+
+//-----------------------------------------------------------------------------
+// Standard C28x Data Types
+//-----------------------------------------------------------------------------
+
+
+#ifndef DSP28_DATA_TYPES
+#define DSP28_DATA_TYPES
+typedef int                 int16;
+typedef long                int32;
+typedef long long           int64;
+typedef unsigned int        Uint16;
+typedef unsigned long       Uint32;
+typedef unsigned long long  Uint64;
+typedef float               float32;
+typedef long double         float64;
+#endif
+
+
+//-----------------------------------------------------------------------------
+// Function Prototypes
+//-----------------------------------------------------------------------------
+
+float32 isqrt(float32 X);
+void sincos(float32 radian, float32* PtrSin, float32* PtrCos);
+
+//-----------------------------------------------------------------------------
+//
+//-----------------------------------------------------------------------------
+
+
+#endif   // - end of C28X_FPU_FAST_RTS_H
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Adc.h b/Inu/main_matlab/device_support/include/DSP281x_Adc.h
new file mode 100644
index 0000000..63cfdf9
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Adc.h
@@ -0,0 +1,225 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: March 19, 2007   15:09:18 $
+//###########################################################################
+//
+// FILE:   DSP281x_Adc.h
+//
+// TITLE:  DSP281x Device ADC Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+
+#ifndef DSP281x_ADC_H
+#define DSP281x_ADC_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// ADC Individual Register Bit Definitions:
+
+struct ADCTRL1_BITS {     // bits  description
+    Uint16  rsvd1:4;      // 3:0   reserved
+    Uint16  SEQ_CASC:1;   // 4     Cascaded sequencer mode
+    Uint16  SEQ_OVRD:1;   // 5     Sequencer override
+    Uint16  CONT_RUN:1;   // 6     Continuous run
+    Uint16  CPS:1;        // 7     ADC core clock pre-scalar
+    Uint16  ACQ_PS:4;     // 11:8  Acquisition window size
+    Uint16  SUSMOD:2;     // 13:12 Emulation suspend mode
+    Uint16  RESET:1;      // 14    ADC reset
+    Uint16  rsvd2:1;      // 15    reserved
+};
+
+
+union ADCTRL1_REG {
+   Uint16                all;
+   struct ADCTRL1_BITS   bit;
+};
+
+
+struct ADCTRL2_BITS {         // bits  description
+    Uint16  EVB_SOC_SEQ2:1;   // 0     Event manager B SOC mask for SEQ2
+    Uint16  rsvd1:1;          // 1     reserved
+    Uint16  INT_MOD_SEQ2:1;   // 2     SEQ2 Interrupt mode
+    Uint16  INT_ENA_SEQ2:1;   // 3     SEQ2 Interrupt enable
+    Uint16  rsvd2:1;          // 4     reserved
+    Uint16  SOC_SEQ2:1;       // 5     Start of conversion for SEQ2
+    Uint16  RST_SEQ2:1;       // 6     Reset SEQ2
+    Uint16  EXT_SOC_SEQ1:1;   // 7     External start of conversion for SEQ1
+    Uint16  EVA_SOC_SEQ1:1;   // 8     Event manager A SOC mask for SEQ1
+    Uint16  rsvd3:1;          // 9     reserved
+    Uint16  INT_MOD_SEQ1:1;   // 10    SEQ1 Interrupt mode
+    Uint16  INT_ENA_SEQ1:1;   // 11    SEQ1 Interrupt enable
+    Uint16  rsvd4:1;          // 12    reserved
+    Uint16  SOC_SEQ1:1;       // 13    Start of conversion trigger for SEQ1
+    Uint16  RST_SEQ1:1;       // 14    Restart sequencer 1
+    Uint16  EVB_SOC_SEQ:1;    // 15    EVB SOC enable
+};
+
+
+union ADCTRL2_REG {
+   Uint16                all;
+   struct ADCTRL2_BITS   bit;
+};
+
+
+struct ADCASEQSR_BITS {       // bits   description
+    Uint16  SEQ1_STATE:4;     // 3:0    SEQ1 state
+    Uint16  SEQ2_STATE:3;     // 6:4    SEQ2 state
+    Uint16  rsvd1:1;          // 7      reserved
+    Uint16  SEQ_CNTR:4;       // 11:8   Sequencing counter status
+    Uint16  rsvd2:4;          // 15:12  reserved
+};
+
+union ADCASEQSR_REG {
+   Uint16                 all;
+   struct ADCASEQSR_BITS  bit;
+};
+
+
+struct ADCMAXCONV_BITS {      // bits  description
+    Uint16  MAX_CONV1:4;      // 3:0   Max number of conversions
+    Uint16  MAX_CONV2:3;      // 6:4   Max number of conversions
+    Uint16  rsvd1:9;          // 15:7  reserved
+};
+
+union ADCMAXCONV_REG {
+   Uint16                  all;
+   struct ADCMAXCONV_BITS  bit;
+};
+
+
+struct ADCCHSELSEQ1_BITS {    // bits   description
+    Uint16  CONV00:4;         // 3:0    Conversion selection 00
+    Uint16  CONV01:4;         // 7:4    Conversion selection 01
+    Uint16  CONV02:4;         // 11:8   Conversion selection 02
+    Uint16  CONV03:4;         // 15:12  Conversion selection 03
+};
+
+union  ADCCHSELSEQ1_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ1_BITS  bit;
+};
+
+struct ADCCHSELSEQ2_BITS {    // bits   description
+    Uint16  CONV04:4;         // 3:0    Conversion selection 04
+    Uint16  CONV05:4;         // 7:4    Conversion selection 05
+    Uint16  CONV06:4;         // 11:8   Conversion selection 06
+    Uint16  CONV07:4;         // 15:12  Conversion selection 07
+};
+
+union  ADCCHSELSEQ2_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ2_BITS  bit;
+};
+
+struct ADCCHSELSEQ3_BITS {    // bits   description
+    Uint16  CONV08:4;         // 3:0    Conversion selection 08
+    Uint16  CONV09:4;         // 7:4    Conversion selection 09
+    Uint16  CONV10:4;         // 11:8   Conversion selection 10
+    Uint16  CONV11:4;         // 15:12  Conversion selection 11
+};
+
+union  ADCCHSELSEQ3_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ3_BITS  bit;
+};
+
+struct ADCCHSELSEQ4_BITS {    // bits   description
+    Uint16  CONV12:4;         // 3:0    Conversion selection 12
+    Uint16  CONV13:4;         // 7:4    Conversion selection 13
+    Uint16  CONV14:4;         // 11:8   Conversion selection 14
+    Uint16  CONV15:4;         // 15:12  Conversion selection 15
+};
+
+union  ADCCHSELSEQ4_REG {
+   Uint16                    all;
+   struct ADCCHSELSEQ4_BITS  bit;
+};
+
+struct ADCTRL3_BITS {         // bits   description
+    Uint16   SMODE_SEL:1;     // 0      Sampling mode select
+    Uint16   ADCCLKPS:4;      // 4:1    ADC core clock divider
+    Uint16   ADCPWDN:1;       // 5      ADC powerdown
+    Uint16   ADCBGRFDN:2;     // 7:6    ADC bandgap/ref power down
+    Uint16   ADCEXTREF:1;     // 8      ADC external reference
+    Uint16   rsvd1:7;         // 15:9   reserved
+};
+
+union  ADCTRL3_REG {
+   Uint16                all;
+   struct ADCTRL3_BITS   bit;
+};
+
+
+struct ADCST_BITS {           // bits   description
+    Uint16   INT_SEQ1:1;      // 0      SEQ1 Interrupt flag
+    Uint16   INT_SEQ2:1;      // 1      SEQ2 Interrupt flag
+    Uint16   SEQ1_BSY:1;      // 2      SEQ1 busy status
+    Uint16   SEQ2_BSY:1;      // 3      SEQ2 busy status
+    Uint16   INT_SEQ1_CLR:1;  // 4      SEQ1 Interrupt clear
+    Uint16   INT_SEQ2_CLR:1;  // 5      SEQ2 Interrupt clear
+    Uint16   EOS_BUF1:1;      // 6      End of sequence buffer1
+    Uint16   EOS_BUF2:1;      // 7      End of sequence buffer2
+    Uint16   rsvd1:8;         // 15:8   reserved
+};
+
+
+union  ADCST_REG {
+   Uint16             all;
+   struct ADCST_BITS  bit;
+};
+
+
+struct ADC_REGS {
+    union ADCTRL1_REG      ADCTRL1;       // ADC Control 1
+    union ADCTRL2_REG      ADCTRL2;       // ADC Control 2
+    union ADCMAXCONV_REG   ADCMAXCONV;    // Max conversions
+    union ADCCHSELSEQ1_REG ADCCHSELSEQ1;  // Channel select sequencing control 1
+    union ADCCHSELSEQ2_REG ADCCHSELSEQ2;  // Channel select sequencing control 2
+    union ADCCHSELSEQ3_REG ADCCHSELSEQ3;  // Channel select sequencing control 3
+    union ADCCHSELSEQ4_REG ADCCHSELSEQ4;  // Channel select sequencing control 4
+    union ADCASEQSR_REG    ADCASEQSR;     // Autosequence status register
+    Uint16                 ADCRESULT0;    // Conversion Result Buffer 0
+    Uint16                 ADCRESULT1;    // Conversion Result Buffer 1
+    Uint16                 ADCRESULT2;    // Conversion Result Buffer 2
+    Uint16                 ADCRESULT3;    // Conversion Result Buffer 3
+    Uint16                 ADCRESULT4;    // Conversion Result Buffer 4
+    Uint16                 ADCRESULT5;    // Conversion Result Buffer 5
+    Uint16                 ADCRESULT6;    // Conversion Result Buffer 6
+    Uint16                 ADCRESULT7;    // Conversion Result Buffer 7
+    Uint16                 ADCRESULT8;    // Conversion Result Buffer 8
+    Uint16                 ADCRESULT9;    // Conversion Result Buffer 9
+    Uint16                 ADCRESULT10;   // Conversion Result Buffer 10
+    Uint16                 ADCRESULT11;   // Conversion Result Buffer 11
+    Uint16                 ADCRESULT12;   // Conversion Result Buffer 12
+    Uint16                 ADCRESULT13;   // Conversion Result Buffer 13
+    Uint16                 ADCRESULT14;   // Conversion Result Buffer 14
+    Uint16                 ADCRESULT15;   // Conversion Result Buffer 15
+    union ADCTRL3_REG      ADCTRL3;       // ADC Control 3
+    union ADCST_REG        ADCST;         // ADC Status Register
+};
+
+
+//---------------------------------------------------------------------------
+// ADC External References & Function Declarations:
+//
+extern struct ADC_REGS AdcRegs;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+
+#endif  // end of DSP281x_ADC_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_CpuTimers.h b/Inu/main_matlab/device_support/include/DSP281x_CpuTimers.h
new file mode 100644
index 0000000..871bd1f
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_CpuTimers.h
@@ -0,0 +1,185 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: July 9, 2009   17:08:54 $
+//###########################################################################
+//
+// FILE:    DSP281x_CpuTimers.h
+//
+// TITLE:   DSP281x CPU 32-bit Timers Register Definitions.
+//
+// NOTES:   CpuTimer2 is reserved for use with DSP BIOS and
+//          other realtime operating systems.
+//
+//          Do not use this timer in your application if you ever plan
+//          on integrating DSP-BIOS or another realtime OS.
+//
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_CPU_TIMERS_H
+#define DSP281x_CPU_TIMERS_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//---------------------------------------------------------------------------
+// CPU Timer Register Bit Definitions:
+//
+//
+// TCR: Control register bit definitions:
+struct  TCR_BITS {          // bits  description
+   Uint16    rsvd1:4;       // 3:0   reserved
+   Uint16    TSS:1;         // 4     Timer Start/Stop
+   Uint16    TRB:1;         // 5     Timer reload
+   Uint16    rsvd2:4;       // 9:6   reserved
+   Uint16    SOFT:1;        // 10    Emulation modes
+   Uint16    FREE:1;        // 11
+   Uint16    rsvd3:2;       // 12:13 reserved
+   Uint16    TIE:1;         // 14    Output enable
+   Uint16    TIF:1;         // 15    Interrupt flag
+};
+
+union TCR_REG {
+   Uint16           all;
+   struct TCR_BITS  bit;
+};
+
+// TPR: Pre-scale low bit definitions:
+struct  TPR_BITS {        // bits  description
+   Uint16     TDDR:8;     // 7:0   Divide-down low
+   Uint16     PSC:8;      // 15:8  Prescale counter low
+};
+
+union TPR_REG {
+   Uint16           all;
+   struct TPR_BITS  bit;
+};
+
+// TPRH: Pre-scale high bit definitions:
+struct  TPRH_BITS {       // bits  description
+   Uint16     TDDRH:8;      // 7:0   Divide-down high
+   Uint16     PSCH:8;       // 15:8  Prescale counter high
+};
+
+union TPRH_REG {
+   Uint16           all;
+   struct TPRH_BITS bit;
+};
+
+// TIM, TIMH: Timer register definitions:
+struct TIM_REG {
+   Uint16  LSW;
+   Uint16  MSW;
+};
+
+union TIM_GROUP {
+   Uint32          all;
+   struct TIM_REG  half;
+};
+
+// PRD, PRDH: Period register definitions:
+struct PRD_REG {
+   Uint16  LSW;
+   Uint16  MSW;
+};
+
+union PRD_GROUP {
+   Uint32          all;
+   struct PRD_REG  half;
+};
+
+//---------------------------------------------------------------------------
+// CPU Timer Register File:
+//
+struct CPUTIMER_REGS {
+   union TIM_GROUP TIM;   // Timer counter register
+   union PRD_GROUP PRD;   // Period register
+   union TCR_REG   TCR;   // Timer control register
+   Uint16          rsvd1; // reserved
+   union TPR_REG   TPR;   // Timer pre-scale low
+   union TPRH_REG  TPRH;  // Timer pre-scale high
+};
+
+//---------------------------------------------------------------------------
+// CPU Timer Support Variables:
+//
+struct CPUTIMER_VARS {
+   struct  CPUTIMER_REGS  *RegsAddr;
+   Uint32    InterruptCount;
+   float   CPUFreqInMHz;
+   float   PeriodInUSec;
+};
+
+//---------------------------------------------------------------------------
+// Function prototypes and external definitions:
+//
+void InitCpuTimers(void);
+void ConfigCpuTimer(struct CPUTIMER_VARS *Timer, float Freq, float Period);
+
+extern struct CPUTIMER_REGS CpuTimer0Regs;
+extern struct CPUTIMER_VARS CpuTimer0;
+
+// CpuTimer2 is reserved when using DSP BIOS & other RTOS
+extern struct CPUTIMER_REGS CpuTimer1Regs;
+extern struct CPUTIMER_REGS CpuTimer2Regs;
+
+extern struct CPUTIMER_VARS CpuTimer1;
+extern struct CPUTIMER_VARS CpuTimer2;
+
+//---------------------------------------------------------------------------
+// Usefull Timer Operations:
+//
+// Start Timer:
+#define StartCpuTimer0()  CpuTimer0Regs.TCR.bit.TSS = 0
+
+// Stop Timer:
+#define StopCpuTimer0()   CpuTimer0Regs.TCR.bit.TSS = 1
+
+// Reload Timer With period Value:
+#define ReloadCpuTimer0() CpuTimer0Regs.TCR.bit.TRB = 1
+
+// Read 32-Bit Timer Value:
+#define ReadCpuTimer0Counter() CpuTimer0Regs.TIM.all
+
+// Read 32-Bit Period Value:
+#define ReadCpuTimer0Period() CpuTimer0Regs.PRD.all
+
+// CpuTimer2 is reserved by DSP BIOS & other RTOS
+// Do not use this timer if you ever plan on integrating
+// DSP-BIOS or another realtime OS.
+
+// Start Timer:
+#define StartCpuTimer1()  CpuTimer1Regs.TCR.bit.TSS = 0
+#define StartCpuTimer2()  CpuTimer2Regs.TCR.bit.TSS = 0
+
+// Stop Timer:
+#define StopCpuTimer1()   CpuTimer1Regs.TCR.bit.TSS = 1
+#define StopCpuTimer2()   CpuTimer2Regs.TCR.bit.TSS = 1
+
+// Reload Timer With period Value:
+#define ReloadCpuTimer1() CpuTimer1Regs.TCR.bit.TRB = 1
+#define ReloadCpuTimer2() CpuTimer2Regs.TCR.bit.TRB = 1
+
+// Read 32-Bit Timer Value:
+#define ReadCpuTimer1Counter() CpuTimer1Regs.TIM.all
+#define ReadCpuTimer2Counter() CpuTimer2Regs.TIM.all
+
+// Read 32-Bit Period Value:
+#define ReadCpuTimer1Period() CpuTimer1Regs.PRD.all
+#define ReadCpuTimer2Period() CpuTimer2Regs.PRD.all
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_CPU_TIMERS_H definition
+
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_DefaultISR.h b/Inu/main_matlab/device_support/include/DSP281x_DefaultISR.h
new file mode 100644
index 0000000..cab42ec
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_DefaultISR.h
@@ -0,0 +1,124 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:38 $
+//###########################################################################
+//
+// FILE:    DSP281x_DefaultIsr.h
+//
+// TITLE:   DSP281x Devices Default Interrupt Service Routines Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_DEFAULT_ISR_H
+#define DSP281x_DEFAULT_ISR_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// Default Interrupt Service Routine Declarations:
+// 
+// The following function prototypes are for the 
+// default ISR routines used with the default PIE vector table.
+// This default vector table is found in the DSP281x_PieVect.h 
+// file.  
+//
+
+// Non-Peripheral Interrupts:
+interrupt void INT13_ISR(void);     // XINT13 or CPU-Timer 1
+interrupt void INT14_ISR(void);     // CPU-Timer2
+interrupt void DATALOG_ISR(void);   // Datalogging interrupt
+interrupt void RTOSINT_ISR(void);   // RTOS interrupt
+interrupt void EMUINT_ISR(void);    // Emulation interrupt
+interrupt void NMI_ISR(void);       // Non-maskable interrupt
+interrupt void ILLEGAL_ISR(void);   // Illegal operation TRAP
+interrupt void USER1_ISR(void);     // User Defined trap 1
+interrupt void USER2_ISR(void);     // User Defined trap 2
+interrupt void USER3_ISR(void);     // User Defined trap 3
+interrupt void USER4_ISR(void);     // User Defined trap 4
+interrupt void USER5_ISR(void);     // User Defined trap 5
+interrupt void USER6_ISR(void);     // User Defined trap 6
+interrupt void USER7_ISR(void);     // User Defined trap 7
+interrupt void USER8_ISR(void);     // User Defined trap 8
+interrupt void USER9_ISR(void);     // User Defined trap 9
+interrupt void USER10_ISR(void);    // User Defined trap 10
+interrupt void USER11_ISR(void);    // User Defined trap 11
+interrupt void USER12_ISR(void);    // User Defined trap 12
+
+// Group 1 PIE Interrupt Service Routines:
+interrupt void  PDPINTA_ISR(void);   // EV-A
+interrupt void  PDPINTB_ISR(void);   // EV-B
+interrupt void  XINT1_ISR(void);     
+interrupt void  XINT2_ISR(void);
+interrupt void  ADCINT_ISR(void);    // ADC
+interrupt void  TINT0_ISR(void);     // Timer 0
+interrupt void  WAKEINT_ISR(void);   // WD
+
+// Group 2 PIE Interrupt Service Routines:
+interrupt void CMP1INT_ISR(void);   // EV-A
+interrupt void CMP2INT_ISR(void);   // EV-A
+interrupt void CMP3INT_ISR(void);   // EV-A
+interrupt void T1PINT_ISR(void);    // EV-A
+interrupt void T1CINT_ISR(void);    // EV-A
+interrupt void T1UFINT_ISR(void);   // EV-A
+interrupt void T1OFINT_ISR(void);   // EV-A
+      
+// Group 3 PIE Interrupt Service Routines:
+interrupt void T2PINT_ISR(void);    // EV-A
+interrupt void T2CINT_ISR(void);    // EV-A
+interrupt void T2UFINT_ISR(void);   // EV-A
+interrupt void T2OFINT_ISR(void);   // EV-A
+interrupt void CAPINT1_ISR(void);   // EV-A
+interrupt void CAPINT2_ISR(void);   // EV-A
+interrupt void CAPINT3_ISR(void);   // EV-A
+      
+// Group 4 PIE Interrupt Service Routines:
+interrupt void CMP4INT_ISR(void);   // EV-B
+interrupt void CMP5INT_ISR(void);   // EV-B
+interrupt void CMP6INT_ISR(void);   // EV-B
+interrupt void T3PINT_ISR(void);    // EV-B
+interrupt void T3CINT_ISR(void);    // EV-B
+interrupt void T3UFINT_ISR(void);   // EV-B
+interrupt void T3OFINT_ISR(void);   // EV-B
+     
+// Group 5 PIE Interrupt Service Routines:
+interrupt void T4PINT_ISR(void);    // EV-B
+interrupt void T4CINT_ISR(void);    // EV-B
+interrupt void T4UFINT_ISR(void);   // EV-B
+interrupt void T4OFINT_ISR(void);   // EV-B
+interrupt void CAPINT4_ISR(void);   // EV-B
+interrupt void CAPINT5_ISR(void);   // EV-B
+interrupt void CAPINT6_ISR(void);   // EV-B
+
+// Group 6 PIE Interrupt Service Routines:
+interrupt void SPIRXINTA_ISR(void);   // SPI
+interrupt void SPITXINTA_ISR(void);    // SPI
+interrupt void MRINTA_ISR(void);    // McBSP
+interrupt void MXINTA_ISR(void);    // McBSP
+ 
+   
+// Group 9 PIE Interrupt Service Routines:
+interrupt void SCIRXINTA_ISR(void); // SCI-A
+interrupt void SCITXINTA_ISR(void); // SCI-A
+interrupt void SCIRXINTB_ISR(void); // SCI-B
+interrupt void SCITXINTB_ISR(void); // SCI-B
+interrupt void ECAN0INTA_ISR(void); // eCAN
+interrupt void ECAN1INTA_ISR(void); // eCAN
+
+
+// Catch-all for Reserved Locations For testing purposes:
+interrupt void PIE_RESERVED(void);       // Reserved for test
+interrupt void rsvd_ISR(void);           // for test
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif    // end of DSP281x_DEFAULT_ISR_H definition
+
diff --git a/Inu/main_matlab/device_support/include/DSP281x_DevEmu.h b/Inu/main_matlab/device_support/include/DSP281x_DevEmu.h
new file mode 100644
index 0000000..fb0489f
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_DevEmu.h
@@ -0,0 +1,104 @@
+//###########################################################################
+//
+// FILE:   DSP281x_DevEmu.h
+//
+// TITLE:  DSP281x Device Emulation Register Definitions.
+//
+//###########################################################################
+//
+//  Ver | dd mmm yyyy | Who  | Description of changes
+// =====|=============|======|===============================================
+//  1.00| 11 Sep 2003 | L.H. | Changes since previous version (v.58 Alpha)
+//      |             |      | As of Rev C silicon, DEVICEID is a 16-bit
+//      |             |      |    register
+//      |             |      | Commented out the DFT test registers.  These
+//      |             |      |    are not needed as of Rev C silicon.
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_DEV_EMU_H
+#define DSP281x_DEV_EMU_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//---------------------------------------------------------------------------
+// Device Emulation Register Bit Definitions:
+//
+// Device Configuration Register Bit Definitions
+struct DEVICECNF_BITS  {     // bits  description
+   Uint16 rsvd1:3;           // 2:0   reserved
+   Uint16 VMAPS:1;           // 3     VMAP Status
+   Uint16 rsvd2:1;           // 4     reserved
+   Uint16 XRSn:1;            // 5     XRSn Signal Status
+   Uint16 rsvd3:10;          // 15:6
+   Uint16 rsvd4:3;           // 18:6
+   Uint16 ENPROT:1;          // 19    Enable/Disable pipeline protection
+   Uint16 rsvd5:12;          // 31:20 reserved
+};
+
+union DEVICECNF_REG {
+   Uint32                 all;
+   struct DEVICECNF_BITS  bit;
+};
+
+
+// Device ID Register Bit Definitions
+struct DEVICEID_BITS  {      // bits  description
+   Uint16 REVID:16;          // 15:0  Silicon revision
+};
+
+union DEVICEID_REG {
+   Uint16                all;
+   struct DEVICEID_BITS  bit;
+};
+
+// PARTID Register Bit Definitions
+struct PARTID_BITS   {  // bits  description
+   Uint16 PARTNO:8;     // 7:0   Part Number
+   Uint16 PARTTYPE:8;   // 15:8  Part Type
+};
+
+union PARTID_REG {
+   Uint16              all;
+   struct PARTID_BITS  bit;
+};
+
+struct DEV_EMU_REGS {
+   union DEVICECNF_REG DEVICECNF;  // device configuration
+   union PARTID_REG    PARTID;     // Part ID
+   union DEVICEID_REG  DEVICEID;   // Device ID
+   Uint16              PROTSTART;  // Write-Read protection start
+   Uint16              PROTRANGE;  // Write-Read protection range
+   Uint16              rsvd2[202];
+// These registers are no longer needed for Rev C and beyond
+// Uint16              M0RAMDFT;
+// Uint16              M1RAMDFT;
+// Uint16              L0RAMDFT;
+// Uint16              L1RAMDFT;
+// Uint16              H0RAMDFT;
+};
+
+#define REVID          DEVICEID   // REVID replaces DEVICEID starting 281x header files v1.10
+                                  // use #define to maintain code compatibility with v1.00 and older
+
+
+
+//---------------------------------------------------------------------------
+// Device Emulation Register References & Function Declarations:
+//
+extern struct DEV_EMU_REGS DevEmuRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_DEV_EMU_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Device.h b/Inu/main_matlab/device_support/include/DSP281x_Device.h
new file mode 100644
index 0000000..0423872
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Device.h
@@ -0,0 +1,145 @@
+// TI File $Revision: /main/5 $
+// Checkin $Date: December 17, 2007   13:36:09 $
+//###########################################################################
+//
+// FILE:   DSP281x_Device.h
+//
+// TITLE:  DSP281x Device Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_DEVICE_H
+#define DSP281x_DEVICE_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+#define   TARGET   1
+//---------------------------------------------------------------------------
+// User To Select Target Device:
+
+#define   DSP28_F2812   TARGET
+#define   DSP28_F2811   0
+#define   DSP28_F2810   0
+
+//---------------------------------------------------------------------------
+// Common CPU Definitions:
+//
+
+extern cregister unsigned int IFR;
+extern cregister unsigned int IER;
+
+#define  EINT   asm(" clrc INTM")
+#define  DINT   asm(" setc INTM")
+#define  ERTM   asm(" clrc DBGM")
+#define  DRTM   asm(" setc DBGM")
+#define  EALLOW asm(" EALLOW")
+#define  EDIS   asm(" EDIS")
+#define  ESTOP0 asm(" ESTOP0")
+
+#define M_INT1  0x0001
+#define M_INT2  0x0002
+#define M_INT3  0x0004
+#define M_INT4  0x0008
+#define M_INT5  0x0010
+#define M_INT6  0x0020
+#define M_INT7  0x0040
+#define M_INT8  0x0080
+#define M_INT9  0x0100
+#define M_INT10 0x0200
+#define M_INT11 0x0400
+#define M_INT12 0x0800
+#define M_INT13 0x1000
+#define M_INT14 0x2000
+#define M_DLOG  0x4000
+#define M_RTOS  0x8000
+
+#define BIT0    0x0001
+#define BIT1    0x0002
+#define BIT2    0x0004
+#define BIT3    0x0008
+#define BIT4    0x0010
+#define BIT5    0x0020
+#define BIT6    0x0040
+#define BIT7    0x0080
+#define BIT8    0x0100
+#define BIT9    0x0200
+#define BIT10   0x0400
+#define BIT11   0x0800
+#define BIT12   0x1000
+#define BIT13   0x2000
+#define BIT14   0x4000
+#define BIT15   0x8000
+
+#ifndef NULL
+	#define NULL		0
+#endif 
+
+
+//---------------------------------------------------------------------------
+// For Portability, User Is Recommended To Use Following Data Type Size
+// Definitions For 16-bit and 32-Bit Signed/Unsigned Integers:
+//
+
+#ifndef DSP28_DATA_TYPES
+#define DSP28_DATA_TYPES
+typedef int                 int16;
+typedef long                int32;
+typedef long long           int64;
+typedef unsigned int        Uint16;
+typedef unsigned long       Uint32;
+typedef unsigned long long  Uint64;
+typedef float               float32;
+typedef long double         float64;
+#endif
+
+#define LOWORD(l)((short int)( (long int)(l)     &0xFFFF))
+#define HIWORD(l)((short int)(((long int)(l)>>16)&0xFFFF))
+
+#define LOBYTE(w)((char)( (short int)(w)    &0xFF))
+#define HIBYTE(w)((char)(((short int)(w)>>8)&0xFF))
+
+#define BYTE3(l)((char)(((long int)(l)>>24)&0xFF))
+#define BYTE2(l)((char)(((long int)(l)>>16)&0xFF))
+#define BYTE1(l)((char)(((long int)(l)>> 8)&0xFF))
+#define BYTE0(l)((char)( (long int)(l)     &0xFF))
+
+//---------------------------------------------------------------------------
+// Include All Peripheral Header Files:
+//
+
+#include "DSP281x_SysCtrl.h"            // System Control/Power Modes
+#include "DSP281x_DevEmu.h"             // Device Emulation Registers
+#include "DSP281x_Xintf.h"              // External Interface Registers
+#include "DSP281x_CpuTimers.h"          // 32-bit CPU Timers
+#include "DSP281x_PieCtrl.h"            // PIE Control Registers
+#include "DSP281x_PieVect.h"            // PIE Vector Table
+#include "DSP281x_Spi.h"                // SPI Registers
+#include "DSP281x_Sci.h"                // SCI Registers
+#include "DSP281x_Mcbsp.h"              // McBSP Registers
+#include "DSP281x_ECan.h"               // Enhanced eCAN Registers
+#include "DSP281x_Gpio.h"               // General Purpose I/O Registers
+#include "DSP281x_Ev.h"                 // Event Manager Registers
+#include "DSP281x_Adc.h"                // ADC Registers
+#include "DSP281x_XIntrupt.h"           // External Interrupts
+
+#define XCLKIN 24000000	// external oscillator frequency
+extern float SYSCLKOUT, LSPCLK, HSPCLK;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_DEVICE_H definition
+
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_ECan.h b/Inu/main_matlab/device_support/include/DSP281x_ECan.h
new file mode 100644
index 0000000..4999fce
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_ECan.h
@@ -0,0 +1,1164 @@
+//###########################################################################
+//
+// FILE:   DSP281x_ECan.h
+//
+// TITLE:  DSP281x Device eCAN Register Definitions.
+//
+//###########################################################################
+//
+//  Ver | dd mmm yyyy | Who  | Description of changes
+// =====|=============|======|===============================================
+//  1.00a| 07/21/2004 | H.J. |(i) Support for errata (as explained in SPRZ193E and above) incorporated
+//			                 |(ii) Changed the byte ordering to make it easy to use with the
+//                           | default value of DBO bit (0).
+
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_ECAN_H
+#define DSP281x_ECAN_H
+
+/* These 2 lines have been added to support the C callable assembly workaround */
+/* This is to support the workaround for errata (as explained in SPRZ193E and above) */
+
+extern void CanDoubleRead(Uint32 *StorePtr, Uint32 *RegPtr);
+extern void CanDoubleWrite(Uint32 *RegPtr, Uint32 *LoadPtr);
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/* --------------------------------------------------- */
+/* eCAN Control & Status Registers                     */
+/* ----------------------------------------------------*/
+
+/* eCAN Mailbox enable register (CANME) bit definitions */
+struct  CANME_BITS {      // bit  description
+   Uint16      ME0:1;     // 0   Enable Mailbox 0
+   Uint16      ME1:1;     // 1   Enable Mailbox 1
+   Uint16      ME2:1;     // 2   Enable Mailbox 2
+   Uint16      ME3:1;     // 3   Enable Mailbox 3
+   Uint16      ME4:1;     // 4   Enable Mailbox 4
+   Uint16      ME5:1;     // 5   Enable Mailbox 5
+   Uint16      ME6:1;     // 6   Enable Mailbox 6
+   Uint16      ME7:1;     // 7   Enable Mailbox 7
+   Uint16      ME8:1;     // 8   Enable Mailbox 8
+   Uint16      ME9:1;     // 9   Enable Mailbox 9
+   Uint16      ME10:1;    // 10  Enable Mailbox 10
+   Uint16      ME11:1;    // 11  Enable Mailbox 11
+   Uint16      ME12:1;    // 12  Enable Mailbox 12
+   Uint16      ME13:1;    // 13  Enable Mailbox 13
+   Uint16      ME14:1;    // 14  Enable Mailbox 14
+   Uint16      ME15:1;    // 15  Enable Mailbox 15
+   Uint16      ME16:1;    // 16  Enable Mailbox 16
+   Uint16      ME17:1;    // 17  Enable Mailbox 17
+   Uint16      ME18:1;    // 18  Enable Mailbox 18
+   Uint16      ME19:1;    // 19  Enable Mailbox 19
+   Uint16      ME20:1;    // 20  Enable Mailbox 20
+   Uint16      ME21:1;    // 21  Enable Mailbox 21
+   Uint16      ME22:1;    // 22  Enable Mailbox 22
+   Uint16      ME23:1;    // 23  Enable Mailbox 23
+   Uint16      ME24:1;    // 24  Enable Mailbox 24
+   Uint16      ME25:1;    // 25  Enable Mailbox 25
+   Uint16      ME26:1;    // 26  Enable Mailbox 26
+   Uint16      ME27:1;    // 27  Enable Mailbox 27
+   Uint16      ME28:1;    // 28  Enable Mailbox 28
+   Uint16      ME29:1;    // 29  Enable Mailbox 29
+   Uint16      ME30:1;    // 30  Enable Mailbox 30
+   Uint16      ME31:1;    // 31  Enable Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANME_REG {
+   Uint32             all;
+   struct CANME_BITS  bit;
+};
+
+/* eCAN Mailbox direction register (CANMD) bit definitions */
+struct  CANMD_BITS {      // bit  description
+   Uint16      MD0:1;     // 0   0 -> Tx 1 -> Rx
+   Uint16      MD1:1;     // 1   0 -> Tx 1 -> Rx
+   Uint16      MD2:1;     // 2   0 -> Tx 1 -> Rx
+   Uint16      MD3:1;     // 3   0 -> Tx 1 -> Rx
+   Uint16      MD4:1;     // 4   0 -> Tx 1 -> Rx
+   Uint16      MD5:1;     // 5   0 -> Tx 1 -> Rx
+   Uint16      MD6:1;     // 6   0 -> Tx 1 -> Rx
+   Uint16      MD7:1;     // 7   0 -> Tx 1 -> Rx
+   Uint16      MD8:1;     // 8   0 -> Tx 1 -> Rx
+   Uint16      MD9:1;     // 9   0 -> Tx 1 -> Rx
+   Uint16      MD10:1;    // 10  0 -> Tx 1 -> Rx
+   Uint16      MD11:1;    // 11  0 -> Tx 1 -> Rx
+   Uint16      MD12:1;    // 12  0 -> Tx 1 -> Rx
+   Uint16      MD13:1;    // 13  0 -> Tx 1 -> Rx
+   Uint16      MD14:1;    // 14  0 -> Tx 1 -> Rx
+   Uint16      MD15:1;    // 15  0 -> Tx 1 -> Rx
+   Uint16      MD16:1;    // 16  0 -> Tx 1 -> Rx
+   Uint16      MD17:1;    // 17  0 -> Tx 1 -> Rx
+   Uint16      MD18:1;    // 18  0 -> Tx 1 -> Rx
+   Uint16      MD19:1;    // 19  0 -> Tx 1 -> Rx
+   Uint16      MD20:1;    // 20  0 -> Tx 1 -> Rx
+   Uint16      MD21:1;    // 21  0 -> Tx 1 -> Rx
+   Uint16      MD22:1;    // 22  0 -> Tx 1 -> Rx
+   Uint16      MD23:1;    // 23  0 -> Tx 1 -> Rx
+   Uint16      MD24:1;    // 24  0 -> Tx 1 -> Rx
+   Uint16      MD25:1;    // 25  0 -> Tx 1 -> Rx
+   Uint16      MD26:1;    // 26  0 -> Tx 1 -> Rx
+   Uint16      MD27:1;    // 27  0 -> Tx 1 -> Rx
+   Uint16      MD28:1;    // 28  0 -> Tx 1 -> Rx
+   Uint16      MD29:1;    // 29  0 -> Tx 1 -> Rx
+   Uint16      MD30:1;    // 30  0 -> Tx 1 -> Rx
+   Uint16      MD31:1;    // 31  0 -> Tx 1 -> Rx
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMD_REG {
+   Uint32             all;
+   struct CANMD_BITS  bit;
+};
+
+/* eCAN Transmit Request Set register (CANTRS) bit definitions */
+struct  CANTRS_BITS {      // bit  description
+   Uint16      TRS0:1;     // 0   TRS for Mailbox 0
+   Uint16      TRS1:1;     // 1   TRS for Mailbox 1
+   Uint16      TRS2:1;     // 2   TRS for Mailbox 2
+   Uint16      TRS3:1;     // 3   TRS for Mailbox 3
+   Uint16      TRS4:1;     // 4   TRS for Mailbox 4
+   Uint16      TRS5:1;     // 5   TRS for Mailbox 5
+   Uint16      TRS6:1;     // 6   TRS for Mailbox 6
+   Uint16      TRS7:1;     // 7   TRS for Mailbox 7
+   Uint16      TRS8:1;     // 8   TRS for Mailbox 8
+   Uint16      TRS9:1;     // 9   TRS for Mailbox 9
+   Uint16      TRS10:1;    // 10  TRS for Mailbox 10
+   Uint16      TRS11:1;    // 11  TRS for Mailbox 11
+   Uint16      TRS12:1;    // 12  TRS for Mailbox 12
+   Uint16      TRS13:1;    // 13  TRS for Mailbox 13
+   Uint16      TRS14:1;    // 14  TRS for Mailbox 14
+   Uint16      TRS15:1;    // 15  TRS for Mailbox 15
+   Uint16      TRS16:1;    // 16  TRS for Mailbox 16
+   Uint16      TRS17:1;    // 17  TRS for Mailbox 17
+   Uint16      TRS18:1;    // 18  TRS for Mailbox 18
+   Uint16      TRS19:1;    // 19  TRS for Mailbox 19
+   Uint16      TRS20:1;    // 20  TRS for Mailbox 20
+   Uint16      TRS21:1;    // 21  TRS for Mailbox 21
+   Uint16      TRS22:1;    // 22  TRS for Mailbox 22
+   Uint16      TRS23:1;    // 23  TRS for Mailbox 23
+   Uint16      TRS24:1;    // 24  TRS for Mailbox 24
+   Uint16      TRS25:1;    // 25  TRS for Mailbox 25
+   Uint16      TRS26:1;    // 26  TRS for Mailbox 26
+   Uint16      TRS27:1;    // 27  TRS for Mailbox 27
+   Uint16      TRS28:1;    // 28  TRS for Mailbox 28
+   Uint16      TRS29:1;    // 29  TRS for Mailbox 29
+   Uint16      TRS30:1;    // 30  TRS for Mailbox 30
+   Uint16      TRS31:1;    // 31  TRS for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTRS_REG {
+   Uint32              all;
+   struct CANTRS_BITS  bit;
+};
+
+/* eCAN Transmit Request Reset register (CANTRR) bit definitions */
+struct  CANTRR_BITS {      // bit  description
+   Uint16      TRR0:1;     // 0   TRR for Mailbox 0
+   Uint16      TRR1:1;     // 1   TRR for Mailbox 1
+   Uint16      TRR2:1;     // 2   TRR for Mailbox 2
+   Uint16      TRR3:1;     // 3   TRR for Mailbox 3
+   Uint16      TRR4:1;     // 4   TRR for Mailbox 4
+   Uint16      TRR5:1;     // 5   TRR for Mailbox 5
+   Uint16      TRR6:1;     // 6   TRR for Mailbox 6
+   Uint16      TRR7:1;     // 7   TRR for Mailbox 7
+   Uint16      TRR8:1;     // 8   TRR for Mailbox 8
+   Uint16      TRR9:1;     // 9   TRR for Mailbox 9
+   Uint16      TRR10:1;    // 10  TRR for Mailbox 10
+   Uint16      TRR11:1;    // 11  TRR for Mailbox 11
+   Uint16      TRR12:1;    // 12  TRR for Mailbox 12
+   Uint16      TRR13:1;    // 13  TRR for Mailbox 13
+   Uint16      TRR14:1;    // 14  TRR for Mailbox 14
+   Uint16      TRR15:1;    // 15  TRR for Mailbox 15
+   Uint16      TRR16:1;    // 16  TRR for Mailbox 16
+   Uint16      TRR17:1;    // 17  TRR for Mailbox 17
+   Uint16      TRR18:1;    // 18  TRR for Mailbox 18
+   Uint16      TRR19:1;    // 19  TRR for Mailbox 19
+   Uint16      TRR20:1;    // 20  TRR for Mailbox 20
+   Uint16      TRR21:1;    // 21  TRR for Mailbox 21
+   Uint16      TRR22:1;    // 22  TRR for Mailbox 22
+   Uint16      TRR23:1;    // 23  TRR for Mailbox 23
+   Uint16      TRR24:1;    // 24  TRR for Mailbox 24
+   Uint16      TRR25:1;    // 25  TRR for Mailbox 25
+   Uint16      TRR26:1;    // 26  TRR for Mailbox 26
+   Uint16      TRR27:1;    // 27  TRR for Mailbox 27
+   Uint16      TRR28:1;    // 28  TRR for Mailbox 28
+   Uint16      TRR29:1;    // 29  TRR for Mailbox 29
+   Uint16      TRR30:1;    // 30  TRR for Mailbox 30
+   Uint16      TRR31:1;    // 31  TRR for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTRR_REG {
+   Uint32              all;
+   struct CANTRR_BITS  bit;
+};
+
+/* eCAN Transmit Acknowledge register (CANTA) bit definitions */
+struct  CANTA_BITS {      // bit  description
+   Uint16      TA0:1;     // 0   TA for Mailbox 0
+   Uint16      TA1:1;     // 1   TA for Mailbox 1
+   Uint16      TA2:1;     // 2   TA for Mailbox 2
+   Uint16      TA3:1;     // 3   TA for Mailbox 3
+   Uint16      TA4:1;     // 4   TA for Mailbox 4
+   Uint16      TA5:1;     // 5   TA for Mailbox 5
+   Uint16      TA6:1;     // 6   TA for Mailbox 6
+   Uint16      TA7:1;     // 7   TA for Mailbox 7
+   Uint16      TA8:1;     // 8   TA for Mailbox 8
+   Uint16      TA9:1;     // 9   TA for Mailbox 9
+   Uint16      TA10:1;    // 10  TA for Mailbox 10
+   Uint16      TA11:1;    // 11  TA for Mailbox 11
+   Uint16      TA12:1;    // 12  TA for Mailbox 12
+   Uint16      TA13:1;    // 13  TA for Mailbox 13
+   Uint16      TA14:1;    // 14  TA for Mailbox 14
+   Uint16      TA15:1;    // 15  TA for Mailbox 15
+   Uint16      TA16:1;    // 16  TA for Mailbox 16
+   Uint16      TA17:1;    // 17  TA for Mailbox 17
+   Uint16      TA18:1;    // 18  TA for Mailbox 18
+   Uint16      TA19:1;    // 19  TA for Mailbox 19
+   Uint16      TA20:1;    // 20  TA for Mailbox 20
+   Uint16      TA21:1;    // 21  TA for Mailbox 21
+   Uint16      TA22:1;    // 22  TA for Mailbox 22
+   Uint16      TA23:1;    // 23  TA for Mailbox 23
+   Uint16      TA24:1;    // 24  TA for Mailbox 24
+   Uint16      TA25:1;    // 25  TA for Mailbox 25
+   Uint16      TA26:1;    // 26  TA for Mailbox 26
+   Uint16      TA27:1;    // 27  TA for Mailbox 27
+   Uint16      TA28:1;    // 28  TA for Mailbox 28
+   Uint16      TA29:1;    // 29  TA for Mailbox 29
+   Uint16      TA30:1;    // 30  TA for Mailbox 30
+   Uint16      TA31:1;    // 31  TA for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTA_REG {
+   Uint32             all;
+   struct CANTA_BITS  bit;
+};
+
+/* eCAN Transmit Abort Acknowledge register (CANAA) bit definitions */
+struct  CANAA_BITS {      // bit  description
+   Uint16      AA0:1;     // 0   AA for Mailbox 0
+   Uint16      AA1:1;     // 1   AA for Mailbox 1
+   Uint16      AA2:1;     // 2   AA for Mailbox 2
+   Uint16      AA3:1;     // 3   AA for Mailbox 3
+   Uint16      AA4:1;     // 4   AA for Mailbox 4
+   Uint16      AA5:1;     // 5   AA for Mailbox 5
+   Uint16      AA6:1;     // 6   AA for Mailbox 6
+   Uint16      AA7:1;     // 7   AA for Mailbox 7
+   Uint16      AA8:1;     // 8   AA for Mailbox 8
+   Uint16      AA9:1;     // 9   AA for Mailbox 9
+   Uint16      AA10:1;    // 10  AA for Mailbox 10
+   Uint16      AA11:1;    // 11  AA for Mailbox 11
+   Uint16      AA12:1;    // 12  AA for Mailbox 12
+   Uint16      AA13:1;    // 13  AA for Mailbox 13
+   Uint16      AA14:1;    // 14  AA for Mailbox 14
+   Uint16      AA15:1;    // 15  AA for Mailbox 15
+   Uint16      AA16:1;    // 16  AA for Mailbox 16
+   Uint16      AA17:1;    // 17  AA for Mailbox 17
+   Uint16      AA18:1;    // 18  AA for Mailbox 18
+   Uint16      AA19:1;    // 19  AA for Mailbox 19
+   Uint16      AA20:1;    // 20  AA for Mailbox 20
+   Uint16      AA21:1;    // 21  AA for Mailbox 21
+   Uint16      AA22:1;    // 22  AA for Mailbox 22
+   Uint16      AA23:1;    // 23  AA for Mailbox 23
+   Uint16      AA24:1;    // 24  AA for Mailbox 24
+   Uint16      AA25:1;    // 25  AA for Mailbox 25
+   Uint16      AA26:1;    // 26  AA for Mailbox 26
+   Uint16      AA27:1;    // 27  AA for Mailbox 27
+   Uint16      AA28:1;    // 28  AA for Mailbox 28
+   Uint16      AA29:1;    // 29  AA for Mailbox 29
+   Uint16      AA30:1;    // 30  AA for Mailbox 30
+   Uint16      AA31:1;    // 31  AA for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANAA_REG {
+   Uint32             all;
+   struct CANAA_BITS  bit;
+};
+
+/* eCAN Received Message Pending register (CANRMP) bit definitions */
+struct  CANRMP_BITS {      // bit  description
+   Uint16      RMP0:1;     // 0   RMP for Mailbox 0
+   Uint16      RMP1:1;     // 1   RMP for Mailbox 1
+   Uint16      RMP2:1;     // 2   RMP for Mailbox 2
+   Uint16      RMP3:1;     // 3   RMP for Mailbox 3
+   Uint16      RMP4:1;     // 4   RMP for Mailbox 4
+   Uint16      RMP5:1;     // 5   RMP for Mailbox 5
+   Uint16      RMP6:1;     // 6   RMP for Mailbox 6
+   Uint16      RMP7:1;     // 7   RMP for Mailbox 7
+   Uint16      RMP8:1;     // 8   RMP for Mailbox 8
+   Uint16      RMP9:1;     // 9   RMP for Mailbox 9
+   Uint16      RMP10:1;    // 10  RMP for Mailbox 10
+   Uint16      RMP11:1;    // 11  RMP for Mailbox 11
+   Uint16      RMP12:1;    // 12  RMP for Mailbox 12
+   Uint16      RMP13:1;    // 13  RMP for Mailbox 13
+   Uint16      RMP14:1;    // 14  RMP for Mailbox 14
+   Uint16      RMP15:1;    // 15  RMP for Mailbox 15
+   Uint16      RMP16:1;    // 16  RMP for Mailbox 16
+   Uint16      RMP17:1;    // 17  RMP for Mailbox 17
+   Uint16      RMP18:1;    // 18  RMP for Mailbox 18
+   Uint16      RMP19:1;    // 19  RMP for Mailbox 19
+   Uint16      RMP20:1;    // 20  RMP for Mailbox 20
+   Uint16      RMP21:1;    // 21  RMP for Mailbox 21
+   Uint16      RMP22:1;    // 22  RMP for Mailbox 22
+   Uint16      RMP23:1;    // 23  RMP for Mailbox 23
+   Uint16      RMP24:1;    // 24  RMP for Mailbox 24
+   Uint16      RMP25:1;    // 25  RMP for Mailbox 25
+   Uint16      RMP26:1;    // 26  RMP for Mailbox 26
+   Uint16      RMP27:1;    // 27  RMP for Mailbox 27
+   Uint16      RMP28:1;    // 28  RMP for Mailbox 28
+   Uint16      RMP29:1;    // 29  RMP for Mailbox 29
+   Uint16      RMP30:1;    // 30  RMP for Mailbox 30
+   Uint16      RMP31:1;    // 31  RMP for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRMP_REG {
+   Uint32              all;
+   struct CANRMP_BITS  bit;
+};
+
+/* eCAN Received Message Lost register (CANRML) bit definitions */
+struct  CANRML_BITS {      // bit  description
+   Uint16      RML0:1;     // 0   RML for Mailbox 0
+   Uint16      RML1:1;     // 1   RML for Mailbox 1
+   Uint16      RML2:1;     // 2   RML for Mailbox 2
+   Uint16      RML3:1;     // 3   RML for Mailbox 3
+   Uint16      RML4:1;     // 4   RML for Mailbox 4
+   Uint16      RML5:1;     // 5   RML for Mailbox 5
+   Uint16      RML6:1;     // 6   RML for Mailbox 6
+   Uint16      RML7:1;     // 7   RML for Mailbox 7
+   Uint16      RML8:1;     // 8   RML for Mailbox 8
+   Uint16      RML9:1;     // 9   RML for Mailbox 9
+   Uint16      RML10:1;    // 10  RML for Mailbox 10
+   Uint16      RML11:1;    // 11  RML for Mailbox 11
+   Uint16      RML12:1;    // 12  RML for Mailbox 12
+   Uint16      RML13:1;    // 13  RML for Mailbox 13
+   Uint16      RML14:1;    // 14  RML for Mailbox 14
+   Uint16      RML15:1;    // 15  RML for Mailbox 15
+   Uint16      RML16:1;    // 16  RML for Mailbox 16
+   Uint16      RML17:1;    // 17  RML for Mailbox 17
+   Uint16      RML18:1;    // 18  RML for Mailbox 18
+   Uint16      RML19:1;    // 19  RML for Mailbox 19
+   Uint16      RML20:1;    // 20  RML for Mailbox 20
+   Uint16      RML21:1;    // 21  RML for Mailbox 21
+   Uint16      RML22:1;    // 22  RML for Mailbox 22
+   Uint16      RML23:1;    // 23  RML for Mailbox 23
+   Uint16      RML24:1;    // 24  RML for Mailbox 24
+   Uint16      RML25:1;    // 25  RML for Mailbox 25
+   Uint16      RML26:1;    // 26  RML for Mailbox 26
+   Uint16      RML27:1;    // 27  RML for Mailbox 27
+   Uint16      RML28:1;    // 28  RML for Mailbox 28
+   Uint16      RML29:1;    // 29  RML for Mailbox 29
+   Uint16      RML30:1;    // 30  RML for Mailbox 30
+   Uint16      RML31:1;    // 31  RML for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRML_REG {
+   Uint32              all;
+   struct CANRML_BITS  bit;
+};
+
+/* eCAN Remote Frame Pending register (CANRFP) bit definitions */
+struct  CANRFP_BITS {      // bit  description
+   Uint16      RFP0:1;     // 0   RFP for Mailbox 0
+   Uint16      RFP1:1;     // 1   RFP for Mailbox 1
+   Uint16      RFP2:1;     // 2   RFP for Mailbox 2
+   Uint16      RFP3:1;     // 3   RFP for Mailbox 3
+   Uint16      RFP4:1;     // 4   RFP for Mailbox 4
+   Uint16      RFP5:1;     // 5   RFP for Mailbox 5
+   Uint16      RFP6:1;     // 6   RFP for Mailbox 6
+   Uint16      RFP7:1;     // 7   RFP for Mailbox 7
+   Uint16      RFP8:1;     // 8   RFP for Mailbox 8
+   Uint16      RFP9:1;     // 9   RFP for Mailbox 9
+   Uint16      RFP10:1;    // 10  RFP for Mailbox 10
+   Uint16      RFP11:1;    // 11  RFP for Mailbox 11
+   Uint16      RFP12:1;    // 12  RFP for Mailbox 12
+   Uint16      RFP13:1;    // 13  RFP for Mailbox 13
+   Uint16      RFP14:1;    // 14  RFP for Mailbox 14
+   Uint16      RFP15:1;    // 15  RFP for Mailbox 15
+   Uint16      RFP16:1;    // 16  RFP for Mailbox 16
+   Uint16      RFP17:1;    // 17  RFP for Mailbox 17
+   Uint16      RFP18:1;    // 18  RFP for Mailbox 18
+   Uint16      RFP19:1;    // 19  RFP for Mailbox 19
+   Uint16      RFP20:1;    // 20  RFP for Mailbox 20
+   Uint16      RFP21:1;    // 21  RFP for Mailbox 21
+   Uint16      RFP22:1;    // 22  RFP for Mailbox 22
+   Uint16      RFP23:1;    // 23  RFP for Mailbox 23
+   Uint16      RFP24:1;    // 24  RFP for Mailbox 24
+   Uint16      RFP25:1;    // 25  RFP for Mailbox 25
+   Uint16      RFP26:1;    // 26  RFP for Mailbox 26
+   Uint16      RFP27:1;    // 27  RFP for Mailbox 27
+   Uint16      RFP28:1;    // 28  RFP for Mailbox 28
+   Uint16      RFP29:1;    // 29  RFP for Mailbox 29
+   Uint16      RFP30:1;    // 30  RFP for Mailbox 30
+   Uint16      RFP31:1;    // 31  RFP for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRFP_REG {
+   Uint32              all;
+   struct CANRFP_BITS  bit;
+};
+
+/* eCAN Global Acceptance Mask register (CANGAM) bit definitions */
+struct  CANGAM_BITS {   // bits  description
+   Uint16 GAM150:16;    // 15:0  Global acceptance mask bits 0-15
+   Uint16 GAM2816:13;   // 28:16 Global acceptance mask bits 16-28    
+   Uint16 rsvd:2;       // 30:29 reserved        
+   Uint16 AMI:1;        // 31    AMI bit
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGAM_REG {
+   Uint32              all;
+   struct CANGAM_BITS  bit;
+};
+
+
+/* eCAN Master Control register (CANMC) bit definitions */
+struct  CANMC_BITS {       // bits  description
+   Uint16      MBNR:5;     // 4:0   MBX # for CDR bit
+   Uint16      SRES:1;     // 5     Soft reset
+   Uint16      STM:1;      // 6     Self-test mode
+   Uint16      ABO:1;      // 7     Auto bus-on
+   Uint16      CDR:1;      // 8     Change data request
+   Uint16      WUBA:1;     // 9     Wake-up on bus activity
+   Uint16      DBO:1;      // 10    Data-byte order
+   Uint16      PDR:1;      // 11    Power-down mode request
+   Uint16      CCR:1;      // 12    Change configuration request
+   Uint16      SCB:1;      // 13    SCC compatibility bit      
+   Uint16      TCC:1;      // 14    TSC MSB clear bit
+   Uint16      MBCC:1;     // 15    TSC clear bit thru mailbox 16      
+   Uint16      SUSP:1;     // 16    SUSPEND free/soft bit
+   Uint16      rsvd:15;    // 31:17  reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMC_REG {
+   Uint32             all;
+   struct CANMC_BITS  bit;
+};
+
+/* eCAN Bit -timing configuration register (CANBTC) bit definitions */
+struct  CANBTC_BITS {  // bits  description
+   Uint16  TSEG2REG:3; // 2:0   TSEG2 register value
+   Uint16  TSEG1REG:4; // 6:3   TSEG1 register value
+   Uint16  SAM:1;      // 7     Sample-point setting
+   Uint16  SJWREG:2;   // 9:8   Synchroniztion Jump Width register value
+   Uint16  rsvd1:6;    // 15:10 reserved   
+   Uint16  BRPREG:8;   // 23:16 Baudrate prescaler register value
+   Uint16  rsvd2:8;    // 31:24 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANBTC_REG {
+   Uint32              all;
+   struct CANBTC_BITS  bit;
+};
+
+/* eCAN Error & Status register (CANES) bit definitions */
+struct  CANES_BITS {    // bits  description
+   Uint16   TM:1;       // 0     Transmit Mode
+   Uint16   RM:1;       // 1     Receive Mode
+   Uint16   rsvd1:1;    // 2     reserved   
+   Uint16   PDA:1;      // 3     Power-down acknowledge
+   Uint16   CCE:1;      // 4     Change Configuration Enable
+   Uint16   SMA:1;      // 5     Suspend Mode Acknowledge
+   Uint16   rsvd2:10;   // 15:6  reserved   
+   Uint16   EW:1;       // 16    Warning status
+   Uint16   EP:1;       // 17    Error Passive status
+   Uint16   BO:1;       // 18    Bus-off status
+   Uint16   ACKE:1;     // 19    Acknowledge error
+   Uint16   SE:1;       // 20    Stuff error
+   Uint16   CRCE:1;     // 21    CRC error
+   Uint16   SA1:1;      // 22    Stuck at Dominant error
+   Uint16   BE:1;       // 23    Bit error
+   Uint16   FE:1;       // 24    Framing error
+   Uint16   rsvd3:7;    // 31:25 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANES_REG {
+   Uint32             all;
+   struct CANES_BITS  bit;
+};
+
+
+/* eCAN Transmit Error Counter register (CANTEC) bit definitions */
+struct  CANTEC_BITS {  // bits  description
+   Uint16 TEC:8;       // 7:0   TEC
+   Uint16 rsvd1:8;     // 15:8  reserved
+   Uint16 rsvd2:16;    // 31:16  reserved      
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTEC_REG {
+   Uint32              all;
+   struct CANTEC_BITS  bit;
+};
+
+/* eCAN Receive Error Counter register (CANREC) bit definitions */
+struct  CANREC_BITS {  // bits  description
+   Uint16 REC:8;       // 7:0   REC
+   Uint16 rsvd1:8;     // 15:8  reserved
+   Uint16 rsvd2:16;    // 31:16 reserved      
+};
+
+/* Allow access to the bit fields or entire register */
+union CANREC_REG {
+   Uint32              all;
+   struct CANREC_BITS  bit;
+};
+
+/* eCAN Global Interrupt Flag 0 (CANGIF0) bit definitions */
+struct  CANGIF0_BITS {  // bits  description
+   Uint16   MIV0:5;     // 4:0   Mailbox Interrupt Vector
+   Uint16   rsvd1:3;    // 7:5   reserved   
+   Uint16   WLIF0:1;    // 8     Warning level interrupt flag
+   Uint16   EPIF0:1;    // 9     Error-passive interrupt flag
+   Uint16   BOIF0:1;    // 10    Bus-off interrupt flag
+   Uint16   RMLIF0:1;   // 11    Received message lost interrupt flag
+   Uint16   WUIF0:1;    // 12    Wakeup interrupt flag
+   Uint16   WDIF0:1;    // 13    Write denied interrupt flag
+   Uint16   AAIF0:1;    // 14    Abort Ack interrupt flag
+   Uint16   GMIF0:1;    // 15    Global MBX interrupt flag
+   Uint16   TCOF0:1;    // 16    TSC Overflow flag
+   Uint16   MTOF0:1;    // 17    Mailbox Timeout flag
+   Uint16   rsvd2:14;   // 31:18 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIF0_REG {
+   Uint32               all;
+   struct CANGIF0_BITS  bit;
+};
+
+/* eCAN Global Interrupt Mask register (CANGIM) bit definitions */
+struct  CANGIM_BITS { // bits  description
+   Uint16  I0EN:1;    // 0      Interrupt 0 enable
+   Uint16  I1EN:1;    // 1      Interrupt 1 enable
+   Uint16  GIL:1;     // 2      Global Interrupt Level
+   Uint16  rsvd1:5;   // 7:3    reserved   
+   Uint16  WLIM:1;    // 8      Warning level interrupt mask 
+   Uint16  EPIM:1;    // 9      Error-passive interrupt mask
+   Uint16  BOIM:1;    // 10     Bus-off interrupt mask
+   Uint16  RMLIM:1;   // 11     Received message lost interrupt mask
+   Uint16  WUIM:1;    // 12     Wakeup interrupt mask
+   Uint16  WDIM:1;    // 13     Write denied interrupt mask
+   Uint16  AAIM:1;    // 14     Abort Ack interrupt mask
+   Uint16  rsvd2:1;   // 15     reserved 
+   Uint16  TCOM:1;    // 16     TSC overflow interrupt mask
+   Uint16  MTOM:1;    // 17     MBX Timeout interrupt mask
+   Uint16  rsvd3:14;  // 31:18  reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIM_REG {
+   Uint32              all;
+   struct CANGIM_BITS  bit;
+};
+
+
+/* eCAN Global Interrupt Flag 1 (eCANGIF1) bit definitions */
+struct  CANGIF1_BITS {     // bits  description
+   Uint16      MIV1:5;     // 4:0   Mailbox Interrupt Vector
+   Uint16      rsvd1:3;    // 7:5   reserved   
+   Uint16      WLIF1:1;    // 8     Warning level interrupt flag
+   Uint16      EPIF1:1;    // 9     Error-passive interrupt flag
+   Uint16      BOIF1:1;    // 10    Bus-off interrupt flag
+   Uint16      RMLIF1:1;   // 11    Received message lost interrupt flag
+   Uint16      WUIF1:1;    // 12    Wakeup interrupt flag
+   Uint16      WDIF1:1;    // 13    Write denied interrupt flag
+   Uint16      AAIF1:1;    // 14    Abort Ack interrupt flag
+   Uint16      GMIF1:1;    // 15    Global MBX interrupt flag
+   Uint16      TCOF1:1;    // 16    TSC Overflow flag
+   Uint16      MTOF1:1;    // 17    Mailbox Timeout flag
+   Uint16      rsvd2:14;   // 31:18 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIF1_REG {
+   Uint32               all;
+   struct CANGIF1_BITS  bit;
+};
+
+
+/* eCAN Mailbox Interrupt Mask register (CANMIM) bit definitions */
+struct  CANMIM_BITS {      // bit  description
+   Uint16      MIM0:1;     // 0   MIM for Mailbox 0
+   Uint16      MIM1:1;     // 1   MIM for Mailbox 1
+   Uint16      MIM2:1;     // 2   MIM for Mailbox 2
+   Uint16      MIM3:1;     // 3   MIM for Mailbox 3
+   Uint16      MIM4:1;     // 4   MIM for Mailbox 4
+   Uint16      MIM5:1;     // 5   MIM for Mailbox 5
+   Uint16      MIM6:1;     // 6   MIM for Mailbox 6
+   Uint16      MIM7:1;     // 7   MIM for Mailbox 7
+   Uint16      MIM8:1;     // 8   MIM for Mailbox 8
+   Uint16      MIM9:1;     // 9   MIM for Mailbox 9
+   Uint16      MIM10:1;    // 10  MIM for Mailbox 10
+   Uint16      MIM11:1;    // 11  MIM for Mailbox 11
+   Uint16      MIM12:1;    // 12  MIM for Mailbox 12
+   Uint16      MIM13:1;    // 13  MIM for Mailbox 13
+   Uint16      MIM14:1;    // 14  MIM for Mailbox 14
+   Uint16      MIM15:1;    // 15  MIM for Mailbox 15
+   Uint16      MIM16:1;    // 16  MIM for Mailbox 16
+   Uint16      MIM17:1;    // 17  MIM for Mailbox 17
+   Uint16      MIM18:1;    // 18  MIM for Mailbox 18
+   Uint16      MIM19:1;    // 19  MIM for Mailbox 19
+   Uint16      MIM20:1;    // 20  MIM for Mailbox 20
+   Uint16      MIM21:1;    // 21  MIM for Mailbox 21
+   Uint16      MIM22:1;    // 22  MIM for Mailbox 22
+   Uint16      MIM23:1;    // 23  MIM for Mailbox 23
+   Uint16      MIM24:1;    // 24  MIM for Mailbox 24
+   Uint16      MIM25:1;    // 25  MIM for Mailbox 25
+   Uint16      MIM26:1;    // 26  MIM for Mailbox 26
+   Uint16      MIM27:1;    // 27  MIM for Mailbox 27
+   Uint16      MIM28:1;    // 28  MIM for Mailbox 28
+   Uint16      MIM29:1;    // 29  MIM for Mailbox 29
+   Uint16      MIM30:1;    // 30  MIM for Mailbox 30
+   Uint16      MIM31:1;    // 31  MIM for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMIM_REG {
+   Uint32              all;
+   struct CANMIM_BITS  bit;
+};
+
+/* eCAN Mailbox Interrupt Level register (CANMIL) bit definitions */
+struct  CANMIL_BITS {      // bit  description
+   Uint16      MIL0:1;     // 0   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL1:1;     // 1   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL2:1;     // 2   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL3:1;     // 3   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL4:1;     // 4   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL5:1;     // 5   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL6:1;     // 6   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL7:1;     // 7   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL8:1;     // 8   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL9:1;     // 9   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL10:1;    // 10  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL11:1;    // 11  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL12:1;    // 12  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL13:1;    // 13  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL14:1;    // 14  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL15:1;    // 15  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL16:1;    // 16  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL17:1;    // 17  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL18:1;    // 18  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL19:1;    // 19  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL20:1;    // 20  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL21:1;    // 21  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL22:1;    // 22  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL23:1;    // 23  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL24:1;    // 24  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL25:1;    // 25  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL26:1;    // 26  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL27:1;    // 27  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL28:1;    // 28  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL29:1;    // 29  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL30:1;    // 30  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL31:1;    // 31  0 -> Int 9.5   1 -> Int 9.6
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMIL_REG {
+   Uint32              all;
+   struct CANMIL_BITS  bit;
+};
+
+
+/* eCAN Overwrite Protection Control register (CANOPC) bit definitions */
+struct  CANOPC_BITS {      // bit  description
+   Uint16      OPC0:1;     // 0   OPC for Mailbox 0
+   Uint16      OPC1:1;     // 1   OPC for Mailbox 1
+   Uint16      OPC2:1;     // 2   OPC for Mailbox 2
+   Uint16      OPC3:1;     // 3   OPC for Mailbox 3
+   Uint16      OPC4:1;     // 4   OPC for Mailbox 4
+   Uint16      OPC5:1;     // 5   OPC for Mailbox 5
+   Uint16      OPC6:1;     // 6   OPC for Mailbox 6
+   Uint16      OPC7:1;     // 7   OPC for Mailbox 7
+   Uint16      OPC8:1;     // 8   OPC for Mailbox 8
+   Uint16      OPC9:1;     // 9   OPC for Mailbox 9
+   Uint16      OPC10:1;    // 10  OPC for Mailbox 10
+   Uint16      OPC11:1;    // 11  OPC for Mailbox 11
+   Uint16      OPC12:1;    // 12  OPC for Mailbox 12
+   Uint16      OPC13:1;    // 13  OPC for Mailbox 13
+   Uint16      OPC14:1;    // 14  OPC for Mailbox 14
+   Uint16      OPC15:1;    // 15  OPC for Mailbox 15
+   Uint16      OPC16:1;    // 16  OPC for Mailbox 16
+   Uint16      OPC17:1;    // 17  OPC for Mailbox 17
+   Uint16      OPC18:1;    // 18  OPC for Mailbox 18
+   Uint16      OPC19:1;    // 19  OPC for Mailbox 19
+   Uint16      OPC20:1;    // 20  OPC for Mailbox 20
+   Uint16      OPC21:1;    // 21  OPC for Mailbox 21
+   Uint16      OPC22:1;    // 22  OPC for Mailbox 22
+   Uint16      OPC23:1;    // 23  OPC for Mailbox 23
+   Uint16      OPC24:1;    // 24  OPC for Mailbox 24
+   Uint16      OPC25:1;    // 25  OPC for Mailbox 25
+   Uint16      OPC26:1;    // 26  OPC for Mailbox 26
+   Uint16      OPC27:1;    // 27  OPC for Mailbox 27
+   Uint16      OPC28:1;    // 28  OPC for Mailbox 28
+   Uint16      OPC29:1;    // 29  OPC for Mailbox 29
+   Uint16      OPC30:1;    // 30  OPC for Mailbox 30
+   Uint16      OPC31:1;    // 31  OPC for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANOPC_REG {
+   Uint32              all;
+   struct CANOPC_BITS  bit;
+};
+
+
+/* eCAN TX I/O Control Register (CANTIOC) bit definitions */
+struct  CANTIOC_BITS { // bits  description
+   Uint16  rsvd1:3;    // 2:0   reserved
+   Uint16  TXFUNC:1;   // 3     TXFUNC
+   Uint16  rsvd2:12;   // 15:4  reserved   
+   Uint16  rsvd3:16;   // 31:16 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTIOC_REG {
+   Uint32               all;
+   struct CANTIOC_BITS  bit;
+};
+
+/* eCAN RX I/O Control Register (CANRIOC) bit definitions */
+struct  CANRIOC_BITS { // bits  description
+   Uint16  rsvd1:3;    // 2:0   reserved
+   Uint16  RXFUNC:1;   // 3     RXFUNC
+   Uint16  rsvd2:12;   // 15:4  reserved   
+   Uint16  rsvd3:16;   // 31:16 reserved   
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRIOC_REG {
+   Uint32               all;
+   struct CANRIOC_BITS  bit;
+};
+
+
+/* eCAN Time-out Control register (CANTOC) bit definitions */
+struct  CANTOC_BITS {      // bit  description
+   Uint16      TOC0:1;     // 0   TOC for Mailbox 0
+   Uint16      TOC1:1;     // 1   TOC for Mailbox 1
+   Uint16      TOC2:1;     // 2   TOC for Mailbox 2
+   Uint16      TOC3:1;     // 3   TOC for Mailbox 3
+   Uint16      TOC4:1;     // 4   TOC for Mailbox 4
+   Uint16      TOC5:1;     // 5   TOC for Mailbox 5
+   Uint16      TOC6:1;     // 6   TOC for Mailbox 6
+   Uint16      TOC7:1;     // 7   TOC for Mailbox 7
+   Uint16      TOC8:1;     // 8   TOC for Mailbox 8
+   Uint16      TOC9:1;     // 9   TOC for Mailbox 9
+   Uint16      TOC10:1;    // 10  TOC for Mailbox 10
+   Uint16      TOC11:1;    // 11  TOC for Mailbox 11
+   Uint16      TOC12:1;    // 12  TOC for Mailbox 12
+   Uint16      TOC13:1;    // 13  TOC for Mailbox 13
+   Uint16      TOC14:1;    // 14  TOC for Mailbox 14
+   Uint16      TOC15:1;    // 15  TOC for Mailbox 15
+   Uint16      TOC16:1;    // 16  TOC for Mailbox 16
+   Uint16      TOC17:1;    // 17  TOC for Mailbox 17
+   Uint16      TOC18:1;    // 18  TOC for Mailbox 18
+   Uint16      TOC19:1;    // 19  TOC for Mailbox 19
+   Uint16      TOC20:1;    // 20  TOC for Mailbox 20
+   Uint16      TOC21:1;    // 21  TOC for Mailbox 21
+   Uint16      TOC22:1;    // 22  TOC for Mailbox 22
+   Uint16      TOC23:1;    // 23  TOC for Mailbox 23
+   Uint16      TOC24:1;    // 24  TOC for Mailbox 24
+   Uint16      TOC25:1;    // 25  TOC for Mailbox 25
+   Uint16      TOC26:1;    // 26  TOC for Mailbox 26
+   Uint16      TOC27:1;    // 27  TOC for Mailbox 27
+   Uint16      TOC28:1;    // 28  TOC for Mailbox 28
+   Uint16      TOC29:1;    // 29  TOC for Mailbox 29
+   Uint16      TOC30:1;    // 30  TOC for Mailbox 30
+   Uint16      TOC31:1;    // 31  TOC for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTOC_REG {
+   Uint32              all;
+   struct CANTOC_BITS  bit;
+};
+
+
+/* eCAN Time-out Status register (CANTOS) bit definitions */
+struct  CANTOS_BITS {            // bit  description
+   Uint16      TOS0:1;     // 0   TOS for Mailbox 0
+   Uint16      TOS1:1;     // 1   TOS for Mailbox 1
+   Uint16      TOS2:1;     // 2   TOS for Mailbox 2
+   Uint16      TOS3:1;     // 3   TOS for Mailbox 3
+   Uint16      TOS4:1;     // 4   TOS for Mailbox 4
+   Uint16      TOS5:1;     // 5   TOS for Mailbox 5
+   Uint16      TOS6:1;     // 6   TOS for Mailbox 6
+   Uint16      TOS7:1;     // 7   TOS for Mailbox 7
+   Uint16      TOS8:1;     // 8   TOS for Mailbox 8
+   Uint16      TOS9:1;     // 9   TOS for Mailbox 9
+   Uint16      TOS10:1;    // 10  TOS for Mailbox 10
+   Uint16      TOS11:1;    // 11  TOS for Mailbox 11
+   Uint16      TOS12:1;    // 12  TOS for Mailbox 12
+   Uint16      TOS13:1;    // 13  TOS for Mailbox 13
+   Uint16      TOS14:1;    // 14  TOS for Mailbox 14
+   Uint16      TOS15:1;    // 15  TOS for Mailbox 15
+   Uint16      TOS16:1;    // 16  TOS for Mailbox 16
+   Uint16      TOS17:1;    // 17  TOS for Mailbox 17
+   Uint16      TOS18:1;    // 18  TOS for Mailbox 18
+   Uint16      TOS19:1;    // 19  TOS for Mailbox 19
+   Uint16      TOS20:1;    // 20  TOS for Mailbox 20
+   Uint16      TOS21:1;    // 21  TOS for Mailbox 21
+   Uint16      TOS22:1;    // 22  TOS for Mailbox 22
+   Uint16      TOS23:1;    // 23  TOS for Mailbox 23
+   Uint16      TOS24:1;    // 24  TOS for Mailbox 24
+   Uint16      TOS25:1;    // 25  TOS for Mailbox 25
+   Uint16      TOS26:1;    // 26  TOS for Mailbox 26
+   Uint16      TOS27:1;    // 27  TOS for Mailbox 27
+   Uint16      TOS28:1;    // 28  TOS for Mailbox 28
+   Uint16      TOS29:1;    // 29  TOS for Mailbox 29
+   Uint16      TOS30:1;    // 30  TOS for Mailbox 30
+   Uint16      TOS31:1;    // 31  TOS for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTOS_REG {
+   Uint32              all;
+   struct CANTOS_BITS  bit;
+};
+
+/**************************************/
+/* eCAN Control & Status register file */
+/**************************************/
+
+struct ECAN_REGS {
+   union CANME_REG   CANME;          // Mailbox Enable
+   union CANMD_REG   CANMD;          // Mailbox Direction
+   union CANTRS_REG  CANTRS;         // Transmit Request Set
+   union CANTRR_REG  CANTRR;         // Transmit Request Reset
+   union CANTA_REG   CANTA;          // Transmit Acknowledge
+   union CANAA_REG   CANAA;          // Abort Acknowledge
+   union CANRMP_REG  CANRMP;         // Received Message Pending
+   union CANRML_REG  CANRML;         // Received Message Lost
+   union CANRFP_REG  CANRFP;         // Remote Frame Pending
+   union CANGAM_REG  CANGAM;         // Global Acceptance Mask       
+   union CANMC_REG   CANMC;          // Master Control
+   union CANBTC_REG  CANBTC;         // Bit Timing
+   union CANES_REG   CANES;          // Error Status
+   union CANTEC_REG  CANTEC;         // Transmit Error Counter
+   union CANREC_REG  CANREC;         // Receive Error Counter
+   union CANGIF0_REG CANGIF0;        // Global Interrupt Flag 0
+   union CANGIM_REG  CANGIM;         // Global Interrupt Mask 0
+   union CANGIF1_REG CANGIF1;        // Global Interrupt Flag 1
+   union CANMIM_REG  CANMIM;         // Mailbox Interrupt Mask
+   union CANMIL_REG  CANMIL;         // Mailbox Interrupt Level
+   union CANOPC_REG  CANOPC;         // Overwrite Protection Control
+   union CANTIOC_REG CANTIOC;        // TX I/O Control
+   union CANRIOC_REG CANRIOC;        // RX I/O Control
+   Uint32            CANTSC;         // Time-stamp counter
+   union CANTOC_REG  CANTOC;         // Time-out Control
+   union CANTOS_REG  CANTOS;         // Time-out Status               
+ 
+};
+
+/* --------------------------------------------------- */
+/* eCAN Mailbox Registers                               */
+/* ----------------------------------------------------*/
+
+/* eCAN Message ID (MSGID) bit definitions */
+struct  CANMSGID_BITS {        // bits  description
+   Uint16      EXTMSGID_L:16;  // 0:15
+   Uint16      EXTMSGID_H:2;   // 16:17
+   Uint16      STDMSGID:11;    // 18:28  
+   Uint16      AAM:1;          // 29   
+   Uint16      AME:1;          // 30
+   Uint16      IDE:1;          // 31   
+ 
+};
+
+/* Allow access to the bit fields or entire register */ 
+union CANMSGID_REG {
+   Uint32                all;
+   struct CANMSGID_BITS  bit;
+};
+
+/* eCAN Message Control Field (MSGCTRL) bit definitions */
+struct  CANMSGCTRL_BITS {     // bits  description
+   Uint16 DLC:4;          // 0:3  
+   Uint16 RTR:1;          // 4  
+   Uint16 rsvd1:3;        // 7:5   reserved   
+   Uint16 TPL:5;          // 12:8  
+   Uint16 rsvd2:3;        // 15:13 reserved 
+   Uint16 rsvd3:16;       // 31:16 reserved     
+};
+
+/* Allow access to the bit fields or entire register */ 
+union CANMSGCTRL_REG {
+   Uint32                  all;
+   struct CANMSGCTRL_BITS  bit;
+};
+
+/* eCAN Message Data Register low (MDR_L) word definitions */
+struct  CANMDL_WORDS {      // bits  description
+   Uint16      LOW_WORD:16; // 0:15  
+   Uint16      HI_WORD:16;  // 31:16  
+};
+
+/* eCAN Message Data Register low (MDR_L) byte definitions */
+struct  CANMDL_BYTES {      // bits   description
+   Uint16      BYTE3:8;     // 31:24
+   Uint16      BYTE2:8;     // 23:16
+   Uint16      BYTE1:8;     // 15:8
+   Uint16      BYTE0:8;     // 7:0        
+};
+
+
+/* Allow access to the bit fields or entire register */ 
+
+union CANMDL_REG {
+   Uint32                all;
+   struct CANMDL_WORDS   word;
+   struct CANMDL_BYTES   byte;      
+};
+
+
+
+/* eCAN Message Data Register high  (MDR_H) word definitions */
+struct  CANMDH_WORDS {         // bits  description
+   Uint16      LOW_WORD:16;    // 0:15  
+   Uint16      HI_WORD:16;     // 31:16  
+};
+
+/* eCAN Message Data Register low (MDR_H) byte definitions */
+struct  CANMDH_BYTES {      // bits   description
+   Uint16      BYTE7:8;     // 63:56 
+   Uint16      BYTE6:8;     // 55:48
+   Uint16      BYTE5:8;     // 47:40    
+   Uint16      BYTE4:8;     // 39:32    
+};
+
+/* Allow access to the bit fields or entire register */ 
+union CANMDH_REG {
+   Uint32                  all;
+   struct CANMDH_WORDS     word;
+   struct CANMDH_BYTES     byte;
+};
+
+
+struct MBOX {
+   union CANMSGID_REG     MSGID;
+   union CANMSGCTRL_REG   MSGCTRL;
+   union CANMDL_REG       MDL;
+   union CANMDH_REG       MDH;
+};
+
+/**************************************/
+/*          eCAN Mailboxes             */
+/**************************************/
+
+struct ECAN_MBOXES {
+   struct MBOX MBOX0;
+   struct MBOX MBOX1;
+   struct MBOX MBOX2;
+   struct MBOX MBOX3;
+   struct MBOX MBOX4;
+   struct MBOX MBOX5;
+   struct MBOX MBOX6;
+   struct MBOX MBOX7;
+   struct MBOX MBOX8;
+   struct MBOX MBOX9;
+   struct MBOX MBOX10;
+   struct MBOX MBOX11;
+   struct MBOX MBOX12;
+   struct MBOX MBOX13;
+   struct MBOX MBOX14;
+   struct MBOX MBOX15;
+   struct MBOX MBOX16;
+   struct MBOX MBOX17;
+   struct MBOX MBOX18;
+   struct MBOX MBOX19;
+   struct MBOX MBOX20;
+   struct MBOX MBOX21;
+   struct MBOX MBOX22;
+   struct MBOX MBOX23;
+   struct MBOX MBOX24;
+   struct MBOX MBOX25;
+   struct MBOX MBOX26;
+   struct MBOX MBOX27;
+   struct MBOX MBOX28;
+   struct MBOX MBOX29;
+   struct MBOX MBOX30;
+   struct MBOX MBOX31;
+};   
+
+/* eCAN Local Acceptance Mask (LAM) bit definitions */
+struct  CANLAM_BITS {                // bits  description
+   Uint16      LAM_L:16;     // 0:15  
+   Uint16      LAM_H:13;     // 16:28  
+   Uint16 rsvd1:2;           // 29:30   reserved   
+   Uint16      LAMI:1;       // 31 
+};
+
+/* Allow access to the bit fields or entire register */ 
+union CANLAM_REG {
+   Uint32        all;
+   struct CANLAM_BITS  bit;
+};
+
+
+/**************************************/
+/*    eCAN Local Acceptance Masks      */
+/**************************************/
+
+/* eCAN LAM File */
+struct LAM_REGS {
+   union CANLAM_REG LAM0;
+   union CANLAM_REG LAM1;
+   union CANLAM_REG LAM2;
+   union CANLAM_REG LAM3;
+   union CANLAM_REG LAM4;
+   union CANLAM_REG LAM5;
+   union CANLAM_REG LAM6;
+   union CANLAM_REG LAM7;
+   union CANLAM_REG LAM8;
+   union CANLAM_REG LAM9;
+   union CANLAM_REG LAM10;
+   union CANLAM_REG LAM11;
+   union CANLAM_REG LAM12;
+   union CANLAM_REG LAM13;
+   union CANLAM_REG LAM14;
+   union CANLAM_REG LAM15;
+   union CANLAM_REG LAM16;
+   union CANLAM_REG LAM17;
+   union CANLAM_REG LAM18;
+   union CANLAM_REG LAM19;
+   union CANLAM_REG LAM20;
+   union CANLAM_REG LAM21;
+   union CANLAM_REG LAM22;
+   union CANLAM_REG LAM23;
+   union CANLAM_REG LAM24;
+   union CANLAM_REG LAM25;
+   union CANLAM_REG LAM26;
+   union CANLAM_REG LAM27;
+   union CANLAM_REG LAM28;
+   union CANLAM_REG LAM29;
+   union CANLAM_REG LAM30;
+   union CANLAM_REG LAM31;
+};
+
+/* Mailbox MOTS File */
+
+struct MOTS_REGS {
+   Uint32 MOTS0;
+   Uint32 MOTS1;
+   Uint32 MOTS2;
+   Uint32 MOTS3;
+   Uint32 MOTS4;
+   Uint32 MOTS5;
+   Uint32 MOTS6;
+   Uint32 MOTS7;
+   Uint32 MOTS8;
+   Uint32 MOTS9;
+   Uint32 MOTS10;
+   Uint32 MOTS11;
+   Uint32 MOTS12;
+   Uint32 MOTS13;
+   Uint32 MOTS14;
+   Uint32 MOTS15;
+   Uint32 MOTS16;
+   Uint32 MOTS17;
+   Uint32 MOTS18;
+   Uint32 MOTS19;
+   Uint32 MOTS20;
+   Uint32 MOTS21;
+   Uint32 MOTS22;
+   Uint32 MOTS23;
+   Uint32 MOTS24;
+   Uint32 MOTS25;
+   Uint32 MOTS26;
+   Uint32 MOTS27;
+   Uint32 MOTS28;
+   Uint32 MOTS29;
+   Uint32 MOTS30;
+   Uint32 MOTS31;
+};
+
+/* Mailbox MOTO File */
+
+struct MOTO_REGS {
+   Uint32 MOTO0;
+   Uint32 MOTO1;
+   Uint32 MOTO2;
+   Uint32 MOTO3;
+   Uint32 MOTO4;
+   Uint32 MOTO5;
+   Uint32 MOTO6;
+   Uint32 MOTO7;
+   Uint32 MOTO8;
+   Uint32 MOTO9;
+   Uint32 MOTO10;
+   Uint32 MOTO11;
+   Uint32 MOTO12;
+   Uint32 MOTO13;
+   Uint32 MOTO14;
+   Uint32 MOTO15;
+   Uint32 MOTO16;
+   Uint32 MOTO17;
+   Uint32 MOTO18;
+   Uint32 MOTO19;
+   Uint32 MOTO20;
+   Uint32 MOTO21;
+   Uint32 MOTO22;
+   Uint32 MOTO23;
+   Uint32 MOTO24;
+   Uint32 MOTO25;
+   Uint32 MOTO26;
+   Uint32 MOTO27;
+   Uint32 MOTO28;
+   Uint32 MOTO29;
+   Uint32 MOTO30;
+   Uint32 MOTO31;
+};
+
+
+//---------------------------------------------------------------------------
+// eCAN External References & Function Declarations:
+//
+extern struct ECAN_REGS ECanaRegs;
+extern struct ECAN_MBOXES ECanaMboxes;
+extern struct LAM_REGS ECanaLAMRegs;
+extern struct MOTO_REGS ECanaMOTORegs;
+extern struct MOTS_REGS ECanaMOTSRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_ECAN.H definition        
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Ev.h b/Inu/main_matlab/device_support/include/DSP281x_Ev.h
new file mode 100644
index 0000000..3447af0
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Ev.h
@@ -0,0 +1,655 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: June 22, 2007   09:30:33 $
+//###########################################################################
+//
+// FILE:	DSP281x_Ev.h
+//
+// TITLE:	DSP281x Device Event Manager Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_EV_H
+#define DSP281x_EV_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//#include "DSP281x_Device.h" 
+/* --------------------------------------------------- */
+/* F2810/12 Event Manager (EV) GP Timer Registers      */
+/*                                                     */
+/* ----------------------------------------------------*/
+
+/* Overall Timer Control Register */
+
+struct GPTCONA_BITS  {
+   Uint16 T1PIN:2;         // 1:0   Polarity of GP timer 1 compare
+   Uint16 T2PIN:2;         // 3:2   Polarity of GP timer 2 compare
+   Uint16 T1CMPOE:1;       // 4     Timer1 compare output
+   Uint16 T2CMPOE:1;       // 5     Timer2 compare output
+   Uint16 TCMPOE:1;        // 6     Compare output enable
+   Uint16 T1TOADC:2;       // 8:7   Start ADC with timer 1 event
+   Uint16 T2TOADC:2;       // 10:9  Start ADC with timer 2 event
+   Uint16 T1CTRIPE:1;      // 11    Enable Timer 1 compare trip
+   Uint16 T2CTRIPE:1;      // 12    Enable Timer 2 compare trip
+   Uint16 T1STAT:1;        // 13    GP Timer 1 status (read only)
+   Uint16 T2STAT:1;        // 14    GP Timer 2 status (read only)
+   Uint16 rsvd:1;          // 15    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union GPTCONA_REG {
+   Uint16        all;
+   struct  GPTCONA_BITS bit;
+};
+
+struct GPTCONB_BITS  {
+   Uint16 T3PIN:2;         // 1:0   Polarity of GP timer 3 compare
+   Uint16 T4PIN:2;         // 3:2   Polarity of GP timer 4 compare
+   Uint16 T3CMPOE:1;       // 4     Timer3 compare output
+   Uint16 T4CMPOE:1;       // 5     Timer4 compare output
+   Uint16 TCMPOE:1;        // 6     Compare output enable
+   Uint16 T3TOADC:2;       // 8:7   Start ADC with timer 3 event
+   Uint16 T4TOADC:2;       // 10:9  Start ADC with timer 4 event
+   Uint16 T3CTRIPE:1;      // 11    Timer 3 trip enable
+   Uint16 T4CTRIPE:1;      // 12    Timer 4 trip enable
+   Uint16 T3STAT:1;        // 13    GP Timer 3 status (read only)
+   Uint16 T4STAT:1;        // 14    GP Timer 4 status (read only)
+   Uint16 rsvd2:1;         // 15    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union GPTCONB_REG {
+   Uint16        all;
+   struct  GPTCONB_BITS bit;
+};
+
+/* Timer 1 Control Register bit defintions */
+struct T1CON_BITS  {
+   Uint16  rsvd1:1;         // 0     reserved
+   Uint16  TECMPR:1;        // 1     Timer compare enable
+   Uint16  TCLD10:2;        // 3:2   Timer copare register reload
+   Uint16  TCLKS10:2;       // 5:4   Clock source select
+   Uint16  TENABLE:1;       // 6     Timer enable
+   Uint16  rsvd2:1;         // 7     reserved
+   Uint16  TPS:3;           // 10:8  Input clock prescaler
+   Uint16  TMODE:2;         // 12:11 Count mode selection
+   Uint16  rsvd:1;          // 13    reserved
+   Uint16  SOFT:1;          // 14    Soft emulation control
+   Uint16  FREE:1;          // 15    Free emulation control
+};
+
+/* Allow access to the bit fields or entire register */
+union T1CON_REG {
+   Uint16             all;
+   struct  T1CON_BITS bit;
+};
+
+
+/* Timer 2 Control Register bit defintions */
+struct T2CON_BITS  {
+   Uint16  SET1PR:1;        // 0     Period register select
+   Uint16  TECMPR:1;        // 1     Timer compare enable
+   Uint16  TCLD10:2;        // 3:2   Timer copare register reload
+   Uint16  TCLKS10:2;       // 5:4   Clock source select
+   Uint16  TENABLE:1;       // 6     Timer enable
+   Uint16  T2SWT1:1;        // 7     Start GP timer 2 with GP timer 1's enable
+   Uint16  TPS:3;           // 10:8  Input clock prescaler
+   Uint16  TMODE:2;         // 12:11 Count mode selection
+   Uint16  rsvd:1;          // 13    reserved
+   Uint16  SOFT:1;          // 14    Soft emulation control
+   Uint16  FREE:1;          // 15    Free emulation control
+};
+
+/* Allow access to the bit fields or entire register */
+union T2CON_REG {
+   Uint16             all;
+   struct  T2CON_BITS bit;
+};
+
+/* Timer 3 Control Register bit defintions */
+struct T3CON_BITS  {
+   Uint16  rsvd1:1;         // 0     reserved
+   Uint16  TECMPR:1;        // 1     Timer compare enable
+   Uint16  TCLD10:2;        // 3:2   Timer copare register reload
+   Uint16  TCLKS10:2;       // 5:4   Clock source select
+   Uint16  TENABLE:1;       // 6     Timer enable
+   Uint16  rsvd2:1;         // 7     reserved
+   Uint16  TPS:3;           // 10:8  Input clock prescaler
+   Uint16  TMODE:2;         // 12:11 Count mode selection
+   Uint16  rsvd:1;          // 13    reserved
+   Uint16  SOFT:1;          // 14    Soft emulation control
+   Uint16  FREE:1;          // 15    Free emulation control
+};
+
+/* Allow access to the bit fields or entire register */
+union T3CON_REG {
+   Uint16             all;
+   struct  T3CON_BITS bit;
+};
+
+/* Timer 4 Control Register bit defintions */
+struct T4CON_BITS  {
+   Uint16  SET3PR:1;        // 0     Period register select
+   Uint16  TECMPR:1;        // 1     Timer compare enable
+   Uint16  TCLD10:2;        // 3:2   Timer copare register reload
+   Uint16  TCLKS10:2;       // 5:4   Clock source select
+   Uint16  TENABLE:1;       // 6     Timer enable
+   Uint16  T4SWT3:1;        // 7     Start GP timer 2 with GP timer 1's enable
+   Uint16  TPS:3;           // 10:8  Input clock prescaler
+   Uint16  TMODE:2;         // 12:11 Count mode selection
+   Uint16  rsvd:1;          // 13    reserved
+   Uint16  SOFT:1;          // 14    Soft emulation control
+   Uint16  FREE:1;          // 15    Free emulation control
+};
+
+/* Allow access to the bit fields or entire register */
+union T4CON_REG {
+   Uint16             all;
+   struct  T4CON_BITS bit;
+};
+
+
+struct EXTCONA_BITS {
+   Uint16   INDCOE:1;        // 0      Independant compare output
+   Uint16   QEPIQUAL:1;      // 1      QEP/CAP3 Index Qual Mode
+   Uint16   QEPIE:1;         // 2      QEP index enable
+   Uint16   EVSOCE:1;        // 3      EvA start of conversion output enable
+   Uint16   rsvd:12;         // 15:4   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EXTCONA_REG {
+   Uint16        all;
+   struct  EXTCONA_BITS bit;
+};
+
+
+struct EXTCONB_BITS {
+   Uint16   INDCOE:1;        // 0      Independant compare output
+   Uint16   QEPIQUAL:1;      // 1      QEP/CAP3 Index Qual Mode
+   Uint16   QEPIE:1;         // 2      QEP index enable
+   Uint16   EVSOCE:1;        // 3      EvB start of conversion output enable
+   Uint16   rsvd:12;         // 15:4   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EXTCONB_REG {
+   Uint16               all;
+   struct  EXTCONA_BITS bit;
+};
+
+
+
+/* Compare Control Register */
+struct COMCONA_BITS {
+   Uint16   C1TRIPE:1;      // 0      C1TRIP enable
+   Uint16   C2TRIPE:1;      // 1      C2TRIP enable
+   Uint16   C3TRIPE:1;      // 2      C3TRIP eanble
+   Uint16   rsvd:2;         // 4:3    reserved
+   Uint16   FCMP1OE:1;      // 5      Full compare 1 output enable
+   Uint16   FCMP2OE:1;      // 6      Full compare 2 output enable
+   Uint16   FCMP3OE:1;      // 7      Full compare 3 output enable
+   Uint16   PDPINTASTATUS:1;// 8      Current status of the PDPINTA pin
+   Uint16   FCOMPOE:1;      // 9      Compare output enable
+   Uint16   ACTRLD:2;       // 11:10  Action control register reload
+   Uint16   SVENABLE:1;     // 12     Space vector PWM Mode enable
+   Uint16   CLD:2;          // 14:13  Compare register reload condition
+   Uint16   CENABLE:1;      // 15     Compare enable
+};
+
+/* Allow access to the bit fields or entire register */
+union COMCONA_REG {
+   Uint16               all;
+   struct  COMCONA_BITS bit;
+};
+
+struct COMCONB_BITS {
+   Uint16   C4TRIPE:1;      // 0      C4TRIP enable
+   Uint16   C5TRIPE:1;      // 1      C5TRIP enable
+   Uint16   C6TRIPE:1;      // 2      C6TRIP eanble
+   Uint16   rsvd:2;         // 4:3    reserved
+   Uint16   FCMP4OE:1;      // 5      Full compare 4 output enable
+   Uint16   FCMP5OE:1;      // 6      Full compare 5 output enable
+   Uint16   FCMP6OE:1;      // 7      Full compare 6 output enable
+   Uint16   PDPINTBSTATUS:1;// 8      Current status of the PDPINTB pin
+   Uint16   FCOMPOE:1;      // 9      Compare output enable
+   Uint16   ACTRLD:2;       // 11:10  Action control register reload
+   Uint16   SVENABLE:1;     // 12     Space vector PWM Mode enable
+   Uint16   CLD:2;          // 14:13  Compare register reload condition
+   Uint16   CENABLE:1;      // 15     Compare enable
+};
+
+/* Allow access to the bit fields or entire register */
+union COMCONB_REG {
+   Uint16               all;
+   struct  COMCONB_BITS bit;
+};
+
+/* Compare Action Control Register bit definitions */
+
+struct ACTRA_BITS {
+   Uint16   CMP1ACT:2;     // 1:0    Action on compare output pin 1 CMP1
+   Uint16   CMP2ACT:2;     // 3:2    Action on compare output pin 2 CMP2
+   Uint16   CMP3ACT:2;     // 5:4    Action on compare output pin 3 CMP3
+   Uint16   CMP4ACT:2;     // 7:6    Action on compare output pin 4 CMP4
+   Uint16   CMP5ACT:2;     // 9:8    Action on compare output pin 5 CMP5
+   Uint16   CMP6ACT:2;     // 11:10  Action on compare output pin 6 CMP6
+   Uint16   D:3;           // 14:12  Basic vector bits
+   Uint16   SVRDIR:1;      // 15     Space vecor PWM rotation dir
+};
+
+/* Allow access to the bit fields or entire register */
+union ACTRA_REG {
+   Uint16             all;
+   struct  ACTRA_BITS bit;
+};
+
+struct ACTRB_BITS {
+   Uint16   CMP7ACT:2;     // 1:0    Action on compare output pin 7 CMP7
+   Uint16   CMP8ACT:2;     // 3:2    Action on compare output pin 8 CMP8
+   Uint16   CMP9ACT:2;     // 5:4    Action on compare output pin 9 CMP9
+   Uint16   CMP10ACT:2;    // 7:6    Action on compare output pin 10 CMP10
+   Uint16   CMP11ACT:2;    // 9:8    Action on compare output pin 11 CMP11
+   Uint16   CMP12ACT:2;    // 11:10  Action on compare output pin 12 CMP12
+   Uint16   D:3;           // 14:12  Basic vector bits
+   Uint16   SVRDIR:1;      // 15     Space vecor PWM rotation dir
+};
+
+/* Allow access to the bit fields or entire register */
+union ACTRB_REG {
+   Uint16        all;
+   struct  ACTRB_BITS bit;
+};
+
+/* Dead-Band Timer Control register bit definitions */
+struct DBTCON_BITS {
+   Uint16   rsvd1:2;       // 1:0    reserved
+   Uint16   DBTPS:3;       // 4:2    Dead-Band timer prescaler
+   Uint16   EDBT1:1;       // 5      Dead-Band timer 1 enable
+   Uint16   EDBT2:1;       // 6      Dead-Band timer 2 enable
+   Uint16   EDBT3:1;       // 7      Dead-Band timer 3 enable
+   Uint16   DBT:4;         // 11:8   Dead-Band timer period
+   Uint16   rsvd2:4;       // 15:12  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union DBTCON_REG {
+   Uint16        all;
+   struct  DBTCON_BITS bit;
+};
+
+
+/* Capture Control register bit definitions */
+struct CAPCONA_BITS {
+   Uint16  rsvd1:2;         // 1:0   reserved
+   Uint16  CAP3EDGE:2;      // 3:2   Edge Detection for Unit 3
+   Uint16  CAP2EDGE:2;      // 5:4   Edge Detection for Unit 2
+   Uint16  CAP1EDGE:2;      // 7:6   Edge Detection for Unit 1
+   Uint16  CAP3TOADC:1;     // 8     Unit 3 starts the ADC
+   Uint16  CAP12TSEL:1;     // 9     GP Timer selection for Units 1 and 2
+   Uint16  CAP3TSEL:1;      // 10    GP Timer selection for Unit 3
+   Uint16  rsvd2:1;         // 11    reserved
+   Uint16  CAP3EN:1;        // 12    Capture Unit 3 enable
+   Uint16  CAP12EN:2;       // 14:13 Capture Unit 1 and 2 enable
+   Uint16  CAPRES:1;        // 15    Capture reset (always reads 0)
+};
+
+/* Allow access to the bit fields or entire register */
+union CAPCONA_REG {
+   Uint16        all;
+   struct  CAPCONA_BITS bit;
+};
+
+
+/* Control register bit definitions */
+struct CAPCONB_BITS {
+   Uint16  rsvd1:2;         // 1:0   reserved
+   Uint16  CAP6EDGE:2;      // 3:2   Edge Detection for Unit 6
+   Uint16  CAP5EDGE:2;      // 5:4   Edge Detection for Unit 5
+   Uint16  CAP4EDGE:2;      // 7:6   Edge Detection for Unit 4
+   Uint16  CAP6TOADC:1;     // 8     Unit 6 starts the ADC
+   Uint16  CAP45TSEL:1;     // 9     GP Timer selection for Units 4 and 5
+   Uint16  CAP6TSEL:1;      // 10    GP Timer selection for Unit 6
+   Uint16  rsvd2:1;         // 11    reserved
+   Uint16  CAP6EN:1;        // 12    Capture Unit 6 control
+   Uint16  CAP45EN:2;       // 14:13 Capture Unit 4 and 5 control
+   Uint16  CAPRES:1;        // 15    Capture reset (always reads 0)
+};
+
+/* Allow access to the bit fields or entire register */
+union CAPCONB_REG {
+   Uint16        all;
+   struct  CAPCONB_BITS bit;
+};
+
+/* Capture FIFO Status Register bit definitions */
+struct CAPFIFOA_BITS  {
+   Uint16 rsvd1:8;           // 7:0   reserved
+   Uint16 CAP1FIFO:2;        // 9:8   CAP1 FIFO status
+   Uint16 CAP2FIFO:2;        // 11:10 CAP2 FIFO status
+   Uint16 CAP3FIFO:2;        // 13:12 CAP2 FIFO status
+   Uint16 rsvd2:2;           // 15:14 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CAPFIFOA_REG {
+   Uint16        all;
+   struct  CAPFIFOA_BITS bit;
+};
+
+/* Capture FIFO Status Register bit definitions */
+struct CAPFIFOB_BITS  {
+   Uint16 rsvd1:8;           // 7:0   reserved
+   Uint16 CAP4FIFO:2;        // 9:8   CAP4 FIFO status
+   Uint16 CAP5FIFO:2;        // 11:10 CAP5 FIFO status
+   Uint16 CAP6FIFO:2;        // 13:12 CAP6 FIFO status
+   Uint16 rsvd2:2;           // 15:14 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CAPFIFOB_REG {
+   Uint16        all;
+   struct  CAPFIFOB_BITS bit;
+};
+
+/* Interrupt Mask Register bit definitions */
+struct EVAIMRA_BITS {
+    Uint16  PDPINTA:1;      // 0       Enable PDPINTA
+    Uint16  CMP1INT:1;      // 1       Enable
+    Uint16  CMP2INT:1;      // 2       Enable
+    Uint16  CMP3INT:1;      // 3       Enable
+    Uint16  rsvd1:3;        // 6:4     reserved
+    Uint16  T1PINT:1;       // 7       Enable
+    Uint16  T1CINT:1;       // 8       Enable
+    Uint16  T1UFINT:1;      // 9       Enable
+    Uint16  T1OFINT:1;      // 10      Enable
+    Uint16  rsvd2:5;        // 15:11   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIMRA_REG {
+   Uint16         all;
+   struct  EVAIMRA_BITS bit;
+};
+
+/* Interrupt Mask Register bit definitions */
+struct EVBIMRA_BITS {
+    Uint16  PDPINTB:1;      // 0       Enable PDPINTB
+    Uint16  CMP4INT:1;      // 1       Enable
+    Uint16  CMP5INT:1;      // 2       Enable
+    Uint16  CMP6INT:1;      // 3       Enable
+    Uint16  rsvd1:3;        // 6:4     reserved
+    Uint16  T3PINT:1;       // 7       Enable
+    Uint16  T3CINT:1;       // 8       Enable
+    Uint16  T3UFINT:1;      // 9       Enable
+    Uint16  T3OFINT:1;      // 10      Enable
+    Uint16  rsvd2:5;        // 15:11   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIMRA_REG {
+   Uint16         all;
+   struct  EVBIMRA_BITS bit;
+};
+
+struct EVAIMRB_BITS {
+   Uint16   T2PINT:1;       // 0       Enable
+   Uint16   T2CINT:1;       // 1       Enable
+   Uint16   T2UFINT:1;      // 2       Enable
+   Uint16   T2OFINT:1;      // 3       Enable
+   Uint16   rsvd1:12;       // 15:4    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIMRB_REG {
+   Uint16         all;
+   struct  EVAIMRB_BITS bit;
+};
+
+struct EVBIMRB_BITS {
+   Uint16   T4PINT:1;       // 0       Enable
+   Uint16   T4CINT:1;       // 1       Enable
+   Uint16   T4UFINT:1;      // 2       Enable
+   Uint16   T4OFINT:1;      // 3       Enable
+   Uint16   rsvd1:12;       // 15:4    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIMRB_REG {
+   Uint16         all;
+   struct  EVBIMRB_BITS bit;
+};
+
+struct EVAIMRC_BITS {
+    Uint16   CAP1INT:1;     // 0        Enable
+    Uint16   CAP2INT:1;     // 1        Enable
+    Uint16   CAP3INT:1;     // 2        Enable
+    Uint16   rsvd1:13;      // 15:3     reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIMRC_REG {
+   Uint16         all;
+   struct  EVAIMRC_BITS bit;
+};
+
+struct EVBIMRC_BITS {
+    Uint16   CAP4INT:1;     // 0        Enable
+    Uint16   CAP5INT:1;     // 1        Enable
+    Uint16   CAP6INT:1;     // 2        Enable
+    Uint16   rsvd1:13;      // 15:3     reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIMRC_REG {
+   Uint16         all;
+   struct  EVBIMRC_BITS bit;
+};
+
+/* Interrupt Flag Register bit definitions */
+struct EVAIFRA_BITS {
+    Uint16  PDPINTA:1;      // 0       Flag PDPINTA
+    Uint16  CMP1INT:1;      // 1       Flag
+    Uint16  CMP2INT:1;      // 2       Flag
+    Uint16  CMP3INT:1;      // 3       Flag
+    Uint16  rsvd1:3;        // 6:4     reserved
+    Uint16  T1PINT:1;       // 7       Flag
+    Uint16  T1CINT:1;       // 8       Flag
+    Uint16  T1UFINT:1;      // 9       Flag
+    Uint16  T1OFINT:1;      // 10      Flag
+    Uint16  rsvd2:5;        // 15:11   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIFRA_REG {
+   Uint16         all;
+   struct  EVAIMRA_BITS bit;
+};
+
+/* Interrupt Mask Register bit definitions */
+struct EVBIFRA_BITS {
+    Uint16  PDPINTB:1;      // 0       Flag PDPINTB
+    Uint16  CMP4INT:1;      // 1       Flag
+    Uint16  CMP5INT:1;      // 2       Flag
+    Uint16  CMP6INT:1;      // 3       Flag
+    Uint16  rsvd1:3;        // 6:4     reserved
+    Uint16  T3PINT:1;       // 7       Flag
+    Uint16  T3CINT:1;       // 8       Flag
+    Uint16  T3UFINT:1;      // 9       Flag
+    Uint16  T3OFINT:1;      // 10      Flag
+    Uint16  rsvd2:5;        // 15:11   reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIFRA_REG {
+   Uint16         all;
+   struct  EVBIFRA_BITS bit;
+};
+
+struct EVAIFRB_BITS {
+   Uint16   T2PINT:1;       // 0       Flag
+   Uint16   T2CINT:1;       // 1       Flag
+   Uint16   T2UFINT:1;      // 2       Flag
+   Uint16   T2OFINT:1;      // 3       Flag
+   Uint16   rsvd1:12;       // 15:4    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIFRB_REG {
+   Uint16         all;
+   struct  EVAIFRB_BITS bit;
+};
+
+struct EVBIFRB_BITS {
+   Uint16   T4PINT:1;       // 0       Flag
+   Uint16   T4CINT:1;       // 1       Flag
+   Uint16   T4UFINT:1;      // 2       Flag
+   Uint16   T4OFINT:1;      // 3       Flag
+   Uint16   rsvd1:12;       // 15:4    reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIFRB_REG {
+   Uint16         all;
+   struct  EVBIFRB_BITS bit;
+};
+
+struct EVAIFRC_BITS {
+    Uint16   CAP1INT:1;     // 0        Flag
+    Uint16   CAP2INT:1;     // 1        Flag
+    Uint16   CAP3INT:1;     // 2        Flag
+    Uint16   rsvd1:13;      // 15:3     reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVAIFRC_REG {
+   Uint16         all;
+   struct  EVAIFRC_BITS bit;
+};
+
+struct EVBIFRC_BITS {
+    Uint16   CAP4INT:1;     // 0        Flag
+    Uint16   CAP5INT:1;     // 1        Flag
+    Uint16   CAP6INT:1;     // 2        Flag
+    Uint16   rsvd1:13;      // 15:3     reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union EVBIFRC_REG {
+   Uint16         all;
+   struct  EVBIFRC_BITS bit;
+};
+
+/* EVA Register File */
+
+struct EVA_REGS  {
+  union GPTCONA_REG  GPTCONA;   //0x7400
+  Uint16             T1CNT;     //0x7401
+  Uint16             T1CMPR;    //0x7402
+  Uint16             T1PR;      //0x7403
+  union T1CON_REG    T1CON;     //0x7404
+  Uint16             T2CNT;     //0x7405
+  Uint16             T2CMPR;    //0x7406
+  Uint16             T2PR;      //0x7407
+  union T2CON_REG    T2CON;     //0x7408
+  union EXTCONA_REG  EXTCONA;   //0x7409
+  Uint16             rsvd1[7];  //0x740A-10
+  union COMCONA_REG  COMCONA;	//0x7411
+  Uint16             rsvd2;     //0x7412
+  union ACTRA_REG    ACTRA;     //0x7413
+  Uint16             rsvd3;     //0x7414
+  union DBTCON_REG   DBTCONA;   //0x7415
+  Uint16             rsvd4;     //0x7416
+  Uint16             CMPR1;     //0x7417
+  Uint16             CMPR2;     //0x7418
+  Uint16             CMPR3;     //0x7419
+  Uint16             rsvd5[6];  //0x741A-F
+  union CAPCONA_REG  CAPCONA;	//0x7420
+  Uint16             rsvd6;     //0x7421
+  union CAPFIFOA_REG CAPFIFOA;  //0x7422
+  Uint16             CAP1FIFO;  //0x7423
+  Uint16             CAP2FIFO;  //0x7424
+  Uint16             CAP3FIFO;  //0x7425
+  Uint16             rsvd7;     //0x7426
+  Uint16             CAP1FBOT;  //0x7427
+  Uint16             CAP2FBOT;  //0x7428
+  Uint16             CAP3FBOT;  //0x7429
+  Uint16             rsvd8[2];  //0x742A-B
+  union EVAIMRA_REG  EVAIMRA;	//0x742C
+  union EVAIMRB_REG  EVAIMRB;	//0x742D
+  union EVAIMRC_REG  EVAIMRC;	//0x742E
+  union EVAIFRA_REG  EVAIFRA;	//0x742F
+  union EVAIFRB_REG  EVAIFRB;	//0x7430
+  union EVAIFRC_REG  EVAIFRC;	//0x7431
+};
+
+
+/* EVB Register File */
+
+struct EVB_REGS  {
+  union GPTCONB_REG  GPTCONB;	//0x7500
+  Uint16             T3CNT;     //0x7501
+  Uint16             T3CMPR;    //0x7502
+  Uint16             T3PR;      //0x7503
+  union T3CON_REG    T3CON;     //0x7504
+  Uint16             T4CNT;     //0x7505
+  Uint16             T4CMPR;    //0x7506
+  Uint16             T4PR;      //0x7507
+  union T4CON_REG    T4CON;     //0x7508
+  union EXTCONB_REG  EXTCONB;   //0x7509
+  Uint16             rsvd1[7];  //0x750A-10
+  union COMCONB_REG  COMCONB;   //0x7511
+  Uint16             rsvd2;     //0x7512
+  union ACTRB_REG    ACTRB;     //0x7513
+  Uint16             rsvd3;     //0x7514
+  union DBTCON_REG   DBTCONB;   //0x7515
+  Uint16             rsvd4;     //0x7516
+  Uint16             CMPR4;     //0x7517
+  Uint16             CMPR5;     //0x7518
+  Uint16             CMPR6;     //0x7519
+  Uint16             rsvd5[6];  //0x751A-F
+  union CAPCONB_REG  CAPCONB;   //0x7520
+  Uint16             rsvd6;     //0x7521
+  union CAPFIFOB_REG CAPFIFOB;  //0x7522
+  Uint16             CAP4FIFO;  //0x7523
+  Uint16             CAP5FIFO;  //0x7524
+  Uint16             CAP6FIFO;  //0x7525
+  Uint16             rsvd7;     //0x7526
+  Uint16             CAP4FBOT;  //0x7527
+  Uint16             CAP5FBOT;  //0x7528
+  Uint16             CAP6FBOT;  //0x7529
+  Uint16             rsvd8[2];  //0x752A-B
+  union EVBIMRA_REG  EVBIMRA;   //0x752C
+  union EVBIMRB_REG  EVBIMRB;   //0x752D
+  union EVBIMRC_REG  EVBIMRC;   //0x752E
+  union EVBIFRA_REG  EVBIFRA;   //0x752F
+  union EVBIFRB_REG  EVBIFRB;   //0x7530
+  union EVBIFRC_REG  EVBIFRC;   //0x7531
+};
+
+
+
+//---------------------------------------------------------------------------
+// Function prototypes and external definitions:
+//
+
+extern struct EVA_REGS EvaRegs;
+extern struct EVB_REGS EvbRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_EV.H definition
+
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Examples.h b/Inu/main_matlab/device_support/include/DSP281x_Examples.h
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Examples.h
@@ -0,0 +1 @@
+
diff --git a/Inu/main_matlab/device_support/include/DSP281x_GlobalPrototypes.h b/Inu/main_matlab/device_support/include/DSP281x_GlobalPrototypes.h
new file mode 100644
index 0000000..e69de29
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Gpio.h b/Inu/main_matlab/device_support/include/DSP281x_Gpio.h
new file mode 100644
index 0000000..3eda7c8
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Gpio.h
@@ -0,0 +1,1035 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:26 $
+//###########################################################################
+//
+// FILE:   DSP281x_Gpio.h
+//
+// TITLE:  DSP281x General Purpose I/O Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_GPIO_H
+#define DSP281x_GPIO_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//----------------------------------------------------
+// General purpose I/O (GPIO) Register Bit Definitions                                               
+
+//----------------------------------------------------
+// GPIO A mux control register bit definitions */                                    
+// 
+//
+struct GPAMUX_BITS  {        // bits   description
+   Uint16 PWM1_GPIOA0:1;     // 0  
+   Uint16 PWM2_GPIOA1:1;     // 1 
+   Uint16 PWM3_GPIOA2:1;     // 2  
+   Uint16 PWM4_GPIOA3:1;     // 3  
+   Uint16 PWM5_GPIOA4:1;     // 4  
+   Uint16 PWM6_GPIOA5:1;     // 5
+   Uint16 T1PWM_GPIOA6:1;    // 6  
+   Uint16 T2PWM_GPIOA7:1;    // 7        
+   Uint16 CAP1Q1_GPIOA8:1;   // 8 
+   Uint16 CAP2Q2_GPIOA9:1;   // 9 
+   Uint16 CAP3QI1_GPIOA10:1; // 10
+   Uint16 TDIRA_GPIOA11:1;   // 11
+   Uint16 TCLKINA_GPIOA12:1; // 12
+   Uint16 C1TRIP_GPIOA13:1;  // 13  
+   Uint16 C2TRIP_GPIOA14:1;  // 14  
+   Uint16 C3TRIP_GPIOA15:1;  // 15   
+         
+};
+
+union GPAMUX_REG {
+   Uint16             all;
+   struct GPAMUX_BITS bit;
+};
+
+
+
+//---------------------------------------------------------------------------------------
+// GPIO A Direction control register bit definitions                                    
+// 
+//
+struct GPADIR_BITS  {      // bits   description
+   Uint16 GPIOA0:1;          // 0  
+   Uint16 GPIOA1:1;          // 1 
+   Uint16 GPIOA2:1;          // 2  
+   Uint16 GPIOA3:1;          // 3  
+   Uint16 GPIOA4:1;          // 4  
+   Uint16 GPIOA5:1;          // 5
+   Uint16 GPIOA6:1;          // 6  
+   Uint16 GPIOA7:1;          // 7        
+   Uint16 GPIOA8:1;          // 8 
+   Uint16 GPIOA9:1;          // 9 
+   Uint16 GPIOA10:1;         // 10
+   Uint16 GPIOA11:1;         // 11
+   Uint16 GPIOA12:1;         // 12
+   Uint16 GPIOA13:1;         // 13  
+   Uint16 GPIOA14:1;         // 14  
+   Uint16 GPIOA15:1;         // 15   
+         
+};
+
+union GPADIR_REG {
+   Uint16             all;
+   struct GPADIR_BITS bit;
+};
+
+//----------------------------------
+// GPA Qualregister bit definitions
+// 
+//
+
+struct GPAQUAL_BITS {    // bits   description
+   Uint16 QUALPRD:8;     // 0:7    Qualification Sampling Period
+   Uint16 rsvd1:8;       // 15:8   reserved
+}; 
+
+union GPAQUAL_REG {
+   Uint16              all;
+   struct GPAQUAL_BITS bit;
+};          
+
+
+//---------------------------------------------------------------------------------------
+// GPIO A Data register bit definitions                                    
+// 
+//
+struct GPADAT_BITS  {      // bits   description
+   Uint16 GPIOA0:1;          // 0  
+   Uint16 GPIOA1:1;          // 1 
+   Uint16 GPIOA2:1;          // 2  
+   Uint16 GPIOA3:1;          // 3  
+   Uint16 GPIOA4:1;          // 4  
+   Uint16 GPIOA5:1;          // 5
+   Uint16 GPIOA6:1;          // 6  
+   Uint16 GPIOA7:1;          // 7        
+   Uint16 GPIOA8:1;          // 8 
+   Uint16 GPIOA9:1;          // 9 
+   Uint16 GPIOA10:1;         // 10
+   Uint16 GPIOA11:1;         // 11
+   Uint16 GPIOA12:1;         // 12
+   Uint16 GPIOA13:1;         // 13  
+   Uint16 GPIOA14:1;         // 14  
+   Uint16 GPIOA15:1;         // 15   
+         
+};
+
+union GPADAT_REG {
+   Uint16             all;
+   struct GPADAT_BITS bit;
+};
+
+
+//---------------------------------------------------------------------------------------
+// GPIO A Data set bit definitions                                    
+// 
+//
+struct GPASET_BITS  {      // bits   description
+   Uint16 GPIOA0:1;          // 0  
+   Uint16 GPIOA1:1;          // 1 
+   Uint16 GPIOA2:1;          // 2  
+   Uint16 GPIOA3:1;          // 3  
+   Uint16 GPIOA4:1;          // 4  
+   Uint16 GPIOA5:1;          // 5
+   Uint16 GPIOA6:1;          // 6  
+   Uint16 GPIOA7:1;          // 7        
+   Uint16 GPIOA8:1;          // 8 
+   Uint16 GPIOA9:1;          // 9 
+   Uint16 GPIOA10:1;         // 10
+   Uint16 GPIOA11:1;         // 11
+   Uint16 GPIOA12:1;         // 12
+   Uint16 GPIOA13:1;         // 13  
+   Uint16 GPIOA14:1;         // 14  
+   Uint16 GPIOA15:1;         // 15   
+         
+};
+
+union GPASET_REG {
+   Uint16             all;
+   struct GPASET_BITS bit;
+};
+
+
+
+//---------------------------------------------------------------------------------------
+// GPIO A Data clear register bit definitions                                    
+// 
+//
+struct GPACLEAR_BITS  {    // bits   description
+   Uint16 GPIOA0:1;          // 0  
+   Uint16 GPIOA1:1;          // 1 
+   Uint16 GPIOA2:1;          // 2  
+   Uint16 GPIOA3:1;          // 3  
+   Uint16 GPIOA4:1;          // 4  
+   Uint16 GPIOA5:1;          // 5
+   Uint16 GPIOA6:1;          // 6  
+   Uint16 GPIOA7:1;          // 7        
+   Uint16 GPIOA8:1;          // 8 
+   Uint16 GPIOA9:1;          // 9 
+   Uint16 GPIOA10:1;         // 10
+   Uint16 GPIOA11:1;         // 11
+   Uint16 GPIOA12:1;         // 12
+   Uint16 GPIOA13:1;         // 13  
+   Uint16 GPIOA14:1;         // 14  
+   Uint16 GPIOA15:1;         // 15   
+         
+};
+
+union GPACLEAR_REG {
+   Uint16               all;
+   struct GPACLEAR_BITS bit;
+};
+
+//---------------------------------------------------------------------------------------
+// GPIO A Data toggle register bit definitions                                    
+// 
+//
+struct GPATOGGLE_BITS  {   // bits   description
+   Uint16 GPIOA0:1;          // 0  
+   Uint16 GPIOA1:1;          // 1 
+   Uint16 GPIOA2:1;          // 2  
+   Uint16 GPIOA3:1;          // 3  
+   Uint16 GPIOA4:1;          // 4  
+   Uint16 GPIOA5:1;          // 5
+   Uint16 GPIOA6:1;          // 6  
+   Uint16 GPIOA7:1;          // 7        
+   Uint16 GPIOA8:1;          // 8 
+   Uint16 GPIOA9:1;          // 9 
+   Uint16 GPIOA10:1;         // 10
+   Uint16 GPIOA11:1;         // 11
+   Uint16 GPIOA12:1;         // 12
+   Uint16 GPIOA13:1;         // 13  
+   Uint16 GPIOA14:1;         // 14  
+   Uint16 GPIOA15:1;         // 15   
+         
+};
+
+union GPATOGGLE_REG {
+   Uint16                all;
+   struct GPATOGGLE_BITS bit;
+};
+
+
+
+//---------------------------------------------------------------------------------
+// GPIO B mux control register bit definitions                                    
+// 
+//
+struct GPBMUX_BITS  {      // bits   description
+   Uint16 PWM7_GPIOB0:1;     // 0  
+   Uint16 PWM8_GPIOB1:1;     // 1 
+   Uint16 PWM9_GPIOB2:1;     // 2  
+   Uint16 PWM10_GPIOB3:1;    // 3  
+   Uint16 PWM11_GPIOB4:1;    // 4  
+   Uint16 PWM12_GPIOB5:1;    // 5
+   Uint16 T3PWM_GPIOB6:1;    // 6  
+   Uint16 T4PWM_GPIOB7:1;    // 7        
+   Uint16 CAP4Q1_GPIOB8:1;   // 8 
+   Uint16 CAP5Q2_GPIOB9:1;   // 9 
+   Uint16 CAP6QI2_GPIOB10:1; // 10
+   Uint16 TDIRB_GPIOB11:1;   // 11
+   Uint16 TCLKINB_GPIOB12:1; // 12
+   Uint16 C4TRIP_GPIOB13:1;  // 13  
+   Uint16 C5TRIP_GPIOB14:1;  // 14  
+   Uint16 C6TRIP_GPIOB15:1;  // 15   
+         
+};
+
+union GPBMUX_REG {
+   Uint16             all;
+   struct GPBMUX_BITS bit;
+};
+
+//---------------------------------------------------------------------------------------
+// GPIO B Direction control register bit definitions                                    
+// 
+//
+struct GPBDIR_BITS  {        // bits  description
+   Uint16 GPIOB0:1;          // 0  
+   Uint16 GPIOB1:1;          // 1 
+   Uint16 GPIOB2:1;          // 2  
+   Uint16 GPIOB3:1;          // 3  
+   Uint16 GPIOB4:1;          // 4  
+   Uint16 GPIOB5:1;          // 5
+   Uint16 GPIOB6:1;          // 6  
+   Uint16 GPIOB7:1;          // 7        
+   Uint16 GPIOB8:1;          // 8 
+   Uint16 GPIOB9:1;          // 9 
+   Uint16 GPIOB10:1;         // 10
+   Uint16 GPIOB11:1;         // 11
+   Uint16 GPIOB12:1;         // 12
+   Uint16 GPIOB13:1;         // 13  
+   Uint16 GPIOB14:1;         // 14  
+   Uint16 GPIOB15:1;         // 15   
+         
+};
+
+union GPBDIR_REG {
+   Uint16             all;
+   struct GPBDIR_BITS bit;
+};
+
+//-----------------------------------
+// GPB Qualregister bit definitions 
+// 
+//
+
+struct GPBQUAL_BITS {    // bits   description
+   Uint16 QUALPRD:8;     // 0:7    Qualification Sampling Period
+   Uint16 rsvd1:8;       // 15:8   reserved
+};
+
+union GPBQUAL_REG {
+   Uint16              all;
+   struct GPBQUAL_BITS bit;
+};           
+
+
+//---------------------------------------------------------------------------------------
+// GPIO B data register bit definitions                                    
+// 
+//
+struct GPBDAT_BITS  {      // bits  description
+   Uint16 GPIOB0:1;          // 0  
+   Uint16 GPIOB1:1;          // 1 
+   Uint16 GPIOB2:1;          // 2  
+   Uint16 GPIOB3:1;          // 3  
+   Uint16 GPIOB4:1;          // 4  
+   Uint16 GPIOB5:1;          // 5
+   Uint16 GPIOB6:1;          // 6  
+   Uint16 GPIOB7:1;          // 7        
+   Uint16 GPIOB8:1;          // 8 
+   Uint16 GPIOB9:1;          // 9 
+   Uint16 GPIOB10:1;         // 10
+   Uint16 GPIOB11:1;         // 11
+   Uint16 GPIOB12:1;         // 12
+   Uint16 GPIOB13:1;         // 13  
+   Uint16 GPIOB14:1;         // 14  
+   Uint16 GPIOB15:1;         // 15   
+         
+};
+
+union GPBDAT_REG {
+   Uint16             all;
+   struct GPBDAT_BITS bit;
+};
+
+
+
+//---------------------------------------------------------------------------------------
+// GPIO B data set register bit definitions                                    
+// 
+//
+struct GPBSET_BITS  {        // bits  description
+   Uint16 GPIOB0:1;          // 0  
+   Uint16 GPIOB1:1;          // 1 
+   Uint16 GPIOB2:1;          // 2  
+   Uint16 GPIOB3:1;          // 3  
+   Uint16 GPIOB4:1;          // 4  
+   Uint16 GPIOB5:1;          // 5
+   Uint16 GPIOB6:1;          // 6  
+   Uint16 GPIOB7:1;          // 7        
+   Uint16 GPIOB8:1;          // 8 
+   Uint16 GPIOB9:1;          // 9 
+   Uint16 GPIOB10:1;         // 10
+   Uint16 GPIOB11:1;         // 11
+   Uint16 GPIOB12:1;         // 12
+   Uint16 GPIOB13:1;         // 13  
+   Uint16 GPIOB14:1;         // 14  
+   Uint16 GPIOB15:1;         // 15   
+         
+};
+
+
+union GPBSET_REG {
+   Uint16             all;
+   struct GPBSET_BITS bit;
+};
+
+
+//---------------------------------------------------------------------------------------
+// GPIO B data clear register bit definitions                                    
+// 
+//
+struct GPBCLEAR_BITS  {      // bits  description
+   Uint16 GPIOB0:1;          // 0  
+   Uint16 GPIOB1:1;          // 1 
+   Uint16 GPIOB2:1;          // 2  
+   Uint16 GPIOB3:1;          // 3  
+   Uint16 GPIOB4:1;          // 4  
+   Uint16 GPIOB5:1;          // 5
+   Uint16 GPIOB6:1;          // 6  
+   Uint16 GPIOB7:1;          // 7        
+   Uint16 GPIOB8:1;          // 8 
+   Uint16 GPIOB9:1;          // 9 
+   Uint16 GPIOB10:1;         // 10
+   Uint16 GPIOB11:1;         // 11
+   Uint16 GPIOB12:1;         // 12
+   Uint16 GPIOB13:1;         // 13  
+   Uint16 GPIOB14:1;         // 14  
+   Uint16 GPIOB15:1;         // 15   
+         
+};
+
+union GPBCLEAR_REG {
+   Uint16               all;
+   struct GPBCLEAR_BITS bit;
+};
+
+
+
+//---------------------------------------------------------------------------------------
+// GPIO B data toggle register bit definitions                                    
+// 
+//
+struct GPBTOGGLE_BITS  {     // bits  description
+   Uint16 GPIOB0:1;          // 0  
+   Uint16 GPIOB1:1;          // 1 
+   Uint16 GPIOB2:1;          // 2  
+   Uint16 GPIOB3:1;          // 3  
+   Uint16 GPIOB4:1;          // 4  
+   Uint16 GPIOB5:1;          // 5
+   Uint16 GPIOB6:1;          // 6  
+   Uint16 GPIOB7:1;          // 7        
+   Uint16 GPIOB8:1;          // 8 
+   Uint16 GPIOB9:1;          // 9 
+   Uint16 GPIOB10:1;         // 10
+   Uint16 GPIOB11:1;         // 11
+   Uint16 GPIOB12:1;         // 12
+   Uint16 GPIOB13:1;         // 13  
+   Uint16 GPIOB14:1;         // 14  
+   Uint16 GPIOB15:1;         // 15   
+         
+};
+
+union GPBTOGGLE_REG {
+   Uint16                all;
+   struct GPBTOGGLE_BITS bit;
+};
+
+
+//---------------------------------------------------------------------------------
+// GPIO D mux control register bit definitions                                    
+// 
+//
+struct GPDMUX_BITS  {                  // bits  description
+   Uint16 T1CTRIP_PDPA_GPIOD0:1;       // 0  
+   Uint16 T2CTRIP_SOCA_GPIOD1:1;       // 1   
+   Uint16 rsvd1:3;                     // 4:2  
+   Uint16 T3CTRIP_PDPB_GPIOD5:1;       // 5  
+   Uint16 T4CTRIP_SOCB_GPIOD6:1;       // 6   
+   Uint16 rsvd2:9;                     // 15:7  
+            
+};
+
+union GPDMUX_REG {
+   Uint16             all;
+   struct GPDMUX_BITS bit;
+};
+
+//----------------------------------------------------
+// GPIO D Direction control register bit definitions 
+//                                     
+//
+struct GPDDIR_BITS  {      // bits   description
+   Uint16 GPIOD0:1;          // 0  
+   Uint16 GPIOD1:1;          // 1 
+   Uint16 rsvd1:3;           // 4:2  
+   Uint16 GPIOD5:1;          // 5
+   Uint16 GPIOD6:1;          // 6  
+   Uint16 rsvd2:9;           // 15:7
+};
+
+union GPDDIR_REG {
+   Uint16             all;
+   struct GPDDIR_BITS bit;
+};
+
+
+//----------------------------------------------------
+// GPIO D data register bit definitions 
+//                                     
+//
+struct GPDDAT_BITS  {      // bits   description
+   Uint16 GPIOD0:1;          // 0  
+   Uint16 GPIOD1:1;          // 1 
+   Uint16 rsvd1:3;           // 4:2  
+   Uint16 GPIOD5:1;          // 5
+   Uint16 GPIOD6:1;          // 6  
+   Uint16 rsvd2:9;           // 15:7
+};           
+
+union GPDDAT_REG {
+   Uint16             all;
+   struct GPDDAT_BITS bit;
+};
+
+
+//----------------------------------------------------
+// GPIO D data set register bit definitions 
+//                                     
+//
+struct GPDSET_BITS  {        // bits   description
+   Uint16 GPIOD0:1;          // 0  
+   Uint16 GPIOD1:1;          // 1 
+   Uint16 rsvd1:3;           // 4:2  
+   Uint16 GPIOD5:1;          // 5
+   Uint16 GPIOD6:1;          // 6  
+   Uint16 rsvd2:9;           // 15:7
+};
+
+union GPDSET_REG {
+   Uint16             all;
+   struct GPDSET_BITS bit;
+};
+
+
+//----------------------------------------------------
+// GPIO D data clear register bit definitions 
+//                                     
+//
+struct GPDCLEAR_BITS  {      // bits   description
+   Uint16 GPIOD0:1;          // 0  
+   Uint16 GPIOD1:1;          // 1 
+   Uint16 rsvd1:3;           // 4:2  
+   Uint16 GPIOD5:1;          // 5
+   Uint16 GPIOD6:1;          // 6  
+   Uint16 rsvd2:9;           // 15:7
+};
+
+union GPDCLEAR_REG {
+   Uint16               all;
+   struct GPDCLEAR_BITS bit;
+};
+
+
+
+//----------------------------------------------------
+// GPIO D data toggle register bit definitions 
+//                                     
+//
+struct GPDTOGGLE_BITS  {     // bits   description
+   Uint16 GPIOD0:1;          // 0  
+   Uint16 GPIOD1:1;          // 1 
+   Uint16 rsvd1:3;           // 4:2  
+   Uint16 GPIOD5:1;          // 5
+   Uint16 GPIOD6:1;          // 6  
+   Uint16 rsvd2:9;           // 15:7
+};
+
+union GPDTOGGLE_REG {
+   Uint16                all;
+   struct GPDTOGGLE_BITS bit;
+};
+
+
+
+//----------------------------------
+// GPIOD Qualregister bit definitions
+// 
+//
+struct GPDQUAL_BITS {    // bits   description
+   Uint16 QUALPRD:8;     // 0:7    Qualification Sampling Period
+   Uint16 rsvd1:8;       // 15:8   reserved
+};    
+
+union GPDQUAL_REG {
+   Uint16              all;
+   struct GPDQUAL_BITS bit;
+};       
+
+
+//---------------------------------------------
+// GPIO E mux control register bit definitions
+//                                     
+//
+struct GPEMUX_BITS  {                // bits  description
+   Uint16 XINT1_XBIO_GPIOE0:1;       // 0  
+   Uint16 XINT2_ADCSOC_GPIOE1:1;     // 1  
+   Uint16 XNMI_XINT13_GPIOE2:1;      // 2 
+   Uint16 rsvd1:12;                  // 15:3  
+               
+};
+
+union GPEMUX_REG {
+   Uint16             all;
+   struct GPEMUX_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO E Direction control register bit definitions
+//                                     
+//
+struct GPEDIR_BITS  {        // bits   description
+   Uint16 GPIOE0:1;          // 0 
+   Uint16 GPIOE1:1;          // 1 
+   Uint16 GPIOE2:1;          // 2 
+   Uint16 rsvd1:12;          // 15:3        
+};
+
+union GPEDIR_REG {
+   Uint16             all;
+   struct GPEDIR_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO E data register bit definitions
+//                                     
+//
+struct GPEDAT_BITS  {        // bits   description
+   Uint16 GPIOE0:1;          // 0 
+   Uint16 GPIOE1:1;          // 1 
+   Uint16 GPIOE2:1;          // 2 
+   Uint16 rsvd1:12;          // 15:3        
+};
+
+union GPEDAT_REG {
+   Uint16             all;
+   struct GPEDAT_BITS bit;
+};
+
+
+
+//---------------------------------------------------
+// GPIO E data set register bit definitions
+//                                     
+//
+struct GPESET_BITS  {        // bits   description
+   Uint16 GPIOE0:1;          // 0 
+   Uint16 GPIOE1:1;          // 1 
+   Uint16 GPIOE2:1;          // 2 
+   Uint16 rsvd1:12;          // 15:3        
+};
+
+union GPESET_REG {
+   Uint16             all;
+   struct GPESET_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO E data clear register bit definitions
+//                                     
+//
+struct GPECLEAR_BITS  {      // bits   description
+   Uint16 GPIOE0:1;          // 0 
+   Uint16 GPIOE1:1;          // 1 
+   Uint16 GPIOE2:1;          // 2 
+   Uint16 rsvd1:12;          // 15:3        
+};
+
+union GPECLEAR_REG {
+   Uint16               all;
+   struct GPECLEAR_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO E data toggle register bit definitions
+//                                     
+//
+struct GPETOGGLE_BITS  {     // bits   description
+   Uint16 GPIOE0:1;          // 0 
+   Uint16 GPIOE1:1;          // 1 
+   Uint16 GPIOE2:1;          // 2 
+   Uint16 rsvd1:12;          // 15:3        
+};
+
+union GPETOGGLE_REG {
+   Uint16                all;
+   struct GPETOGGLE_BITS bit;
+};
+
+
+
+//-----------------------------------
+// GPIOE Qualregister bit definitions 
+// 
+//
+struct GPEQUAL_BITS {        // bits   description
+   Uint16     QUALPRD:8;     // 0:7    Qualification Sampling Period
+   Uint16 rsvd1:8;           // 15:8   reserved
+};     
+
+union GPEQUAL_REG {
+   Uint16              all;
+   struct GPEQUAL_BITS bit;
+};      
+
+
+//----------------------------------------------
+//  GPIO F mux control register bit definitions
+// 
+//
+struct GPFMUX_BITS  {      // bits   description
+   Uint16 SPISIMOA_GPIOF0:1; // 0 
+   Uint16 SPISOMIA_GPIOF1:1; // 1 
+   Uint16 SPICLKA_GPIOF2:1;  // 2 
+   Uint16 SPISTEA_GPIOF3:1;  // 3 
+   Uint16 SCITXDA_GPIOF4:1;  // 4 
+   Uint16 SCIRXDA_GPIOF5:1;  // 5 
+   Uint16 CANTXA_GPIOF6:1;   // 6 
+   Uint16 CANRXA_GPIOF7:1;   // 7 
+   Uint16 MCLKXA_GPIOF8:1;   // 8 
+   Uint16 MCLKRA_GPIOF9:1;   // 9 
+   Uint16 MFSXA_GPIOF10:1;   // 10
+   Uint16 MFSRA_GPIOF11:1;   // 11
+   Uint16 MDXA_GPIOF12:1;    // 12
+   Uint16 MDRA_GPIOF13:1;    // 13
+   Uint16 XF_GPIOF14:1;      // 14
+   Uint16 spare_GPIOF15:1;   // 15
+         
+};
+
+/* Allow access to the bit fields or entire register */
+union GPFMUX_REG {
+   Uint16             all;
+   struct GPFMUX_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO F Direction control register bit definitions
+//                                     
+//
+                                          
+struct GPFDIR_BITS  {      // bits   description
+   Uint16 GPIOF0:1;          // 0 
+   Uint16 GPIOF1:1;          // 1 
+   Uint16 GPIOF2:1;          // 2 
+   Uint16 GPIOF3:1;          // 3 
+   Uint16 GPIOF4:1;          // 4 
+   Uint16 GPIOF5:1;          // 5 
+   Uint16 GPIOF6:1;          // 6 
+   Uint16 GPIOF7:1;          // 7 
+   Uint16 GPIOF8:1;          // 8 
+   Uint16 GPIOF9:1;          // 9 
+   Uint16 GPIOF10:1;         // 10
+   Uint16 GPIOF11:1;         // 11
+   Uint16 GPIOF12:1;         // 12
+   Uint16 GPIOF13:1;         // 13
+   Uint16 GPIOF14:1;         // 14
+   Uint16 GPIOF15:1;         // 15
+
+};
+
+union GPFDIR_REG {
+   Uint16             all;
+   struct GPFDIR_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO F data register bit definitions
+//                                     
+//
+                                          
+struct GPFDAT_BITS  {      // bits   description
+   Uint16 GPIOF0:1;          // 0 
+   Uint16 GPIOF1:1;          // 1 
+   Uint16 GPIOF2:1;          // 2 
+   Uint16 GPIOF3:1;          // 3 
+   Uint16 GPIOF4:1;          // 4 
+   Uint16 GPIOF5:1;          // 5 
+   Uint16 GPIOF6:1;          // 6 
+   Uint16 GPIOF7:1;          // 7 
+   Uint16 GPIOF8:1;          // 8 
+   Uint16 GPIOF9:1;          // 9 
+   Uint16 GPIOF10:1;         // 10
+   Uint16 GPIOF11:1;         // 11
+   Uint16 GPIOF12:1;         // 12
+   Uint16 GPIOF13:1;         // 13
+   Uint16 GPIOF14:1;         // 14
+   Uint16 GPIOF15:1;         // 15
+
+};
+
+union GPFDAT_REG {
+   Uint16             all;
+   struct GPFDAT_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO F data set register bit definitions
+//                                     
+//
+                                          
+struct GPFSET_BITS  {      // bits   description
+   Uint16 GPIOF0:1;          // 0 
+   Uint16 GPIOF1:1;          // 1 
+   Uint16 GPIOF2:1;          // 2 
+   Uint16 GPIOF3:1;          // 3 
+   Uint16 GPIOF4:1;          // 4 
+   Uint16 GPIOF5:1;          // 5 
+   Uint16 GPIOF6:1;          // 6 
+   Uint16 GPIOF7:1;          // 7 
+   Uint16 GPIOF8:1;          // 8 
+   Uint16 GPIOF9:1;          // 9 
+   Uint16 GPIOF10:1;         // 10
+   Uint16 GPIOF11:1;         // 11
+   Uint16 GPIOF12:1;         // 12
+   Uint16 GPIOF13:1;         // 13
+   Uint16 GPIOF14:1;         // 14
+   Uint16 GPIOF15:1;         // 15
+
+};
+
+union GPFSET_REG {
+   Uint16             all;
+   struct GPFSET_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO F data clear register bit definitions
+//                                     
+//
+                                          
+struct GPFCLEAR_BITS  {    // bits   description
+   Uint16 GPIOF0:1;          // 0 
+   Uint16 GPIOF1:1;          // 1 
+   Uint16 GPIOF2:1;          // 2 
+   Uint16 GPIOF3:1;          // 3 
+   Uint16 GPIOF4:1;          // 4 
+   Uint16 GPIOF5:1;          // 5 
+   Uint16 GPIOF6:1;          // 6 
+   Uint16 GPIOF7:1;          // 7 
+   Uint16 GPIOF8:1;          // 8 
+   Uint16 GPIOF9:1;          // 9 
+   Uint16 GPIOF10:1;         // 10
+   Uint16 GPIOF11:1;         // 11
+   Uint16 GPIOF12:1;         // 12
+   Uint16 GPIOF13:1;         // 13
+   Uint16 GPIOF14:1;         // 14
+   Uint16 GPIOF15:1;         // 15
+
+};
+
+union GPFCLEAR_REG {
+   Uint16               all;
+   struct GPFCLEAR_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO F data toggle register bit definitions
+//                                     
+//
+                                          
+struct GPFTOGGLE_BITS  {   // bits   description
+   Uint16 GPIOF0:1;          // 0 
+   Uint16 GPIOF1:1;          // 1 
+   Uint16 GPIOF2:1;          // 2 
+   Uint16 GPIOF3:1;          // 3 
+   Uint16 GPIOF4:1;          // 4 
+   Uint16 GPIOF5:1;          // 5 
+   Uint16 GPIOF6:1;          // 6 
+   Uint16 GPIOF7:1;          // 7 
+   Uint16 GPIOF8:1;          // 8 
+   Uint16 GPIOF9:1;          // 9 
+   Uint16 GPIOF10:1;         // 10
+   Uint16 GPIOF11:1;         // 11
+   Uint16 GPIOF12:1;         // 12
+   Uint16 GPIOF13:1;         // 13
+   Uint16 GPIOF14:1;         // 14
+   Uint16 GPIOF15:1;         // 15
+
+};
+
+union GPFTOGGLE_REG {
+   Uint16                all;
+   struct GPFTOGGLE_BITS bit;
+};
+
+//----------------------------------------------
+//  GPIO G mux control register bit definitions
+// 
+//
+struct GPGMUX_BITS  {      // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 SCITXDB_GPIOG4:1;  // 4 
+   Uint16 SCIRXDB_GPIOG5:1;  // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+
+/* Allow access to the bit fields or entire register */
+union GPGMUX_REG {
+   Uint16             all;
+   struct GPGMUX_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO G Direction control register bit definitions
+//                                     
+//
+                                          
+struct GPGDIR_BITS  {      // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 GPIOG4:1;          // 4 
+   Uint16 GPIOG5:1;          // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+union GPGDIR_REG {
+   Uint16             all;
+   struct GPGDIR_BITS bit;
+};
+
+//---------------------------------------------------
+// GPIO G data register bit definitions
+//                                     
+//
+                                          
+struct GPGDAT_BITS  {      // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 GPIOG4:1;          // 4 
+   Uint16 GPIOG5:1;          // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+union GPGDAT_REG {
+   Uint16             all;
+   struct GPGDAT_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO G data set register bit definitions
+//                                     
+//
+                                          
+struct GPGSET_BITS  {        // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 GPIOG4:1;          // 4 
+   Uint16 GPIOG5:1;          // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+union GPGSET_REG {
+   Uint16             all;
+   struct GPGSET_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO G data clear register bit definitions
+//                                     
+//
+                                          
+struct GPGCLEAR_BITS  {      // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 GPIOG4:1;          // 4 
+   Uint16 GPIOG5:1;          // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+union GPGCLEAR_REG {
+   Uint16               all;
+   struct GPGCLEAR_BITS bit;
+};
+
+
+//---------------------------------------------------
+// GPIO G data toggle register bit definitions
+//                                     
+//
+                                          
+struct GPGTOGGLE_BITS  {     // bits   description
+   Uint16 rsvd1:4;           // 3:0
+   Uint16 GPIOG4:1;          // 4 
+   Uint16 GPIOG5:1;          // 5 
+   Uint16 rsvd2:10;          // 15:6
+
+};
+
+union GPGTOGGLE_REG {
+   Uint16                all;
+   struct GPGTOGGLE_BITS bit;
+};
+
+
+struct GPIO_MUX_REGS {
+   union  GPAMUX_REG   GPAMUX;
+   union  GPADIR_REG   GPADIR;
+   union  GPAQUAL_REG  GPAQUAL;
+   Uint16              rsvd1;
+   union  GPBMUX_REG   GPBMUX;
+   union  GPBDIR_REG   GPBDIR;
+   union  GPBQUAL_REG  GPBQUAL;   
+   Uint16              rsvd2[5];
+   union  GPDMUX_REG   GPDMUX;
+   union  GPDDIR_REG   GPDDIR;
+   union  GPDQUAL_REG  GPDQUAL;   
+   Uint16              rsvd3;
+   union  GPEMUX_REG   GPEMUX;
+   union  GPEDIR_REG   GPEDIR;
+   union  GPEQUAL_REG  GPEQUAL;   
+   Uint16              rsvd4;
+   union  GPFMUX_REG   GPFMUX;
+   union  GPFDIR_REG   GPFDIR;
+   Uint16              rsvd5[2];
+   union  GPGMUX_REG   GPGMUX;
+   union  GPGDIR_REG   GPGDIR;
+   Uint16              rsvd6[6];
+};
+
+struct GPIO_DATA_REGS {
+   union  GPADAT_REG    GPADAT;
+   union  GPASET_REG    GPASET;
+   union  GPACLEAR_REG  GPACLEAR;
+   union  GPATOGGLE_REG GPATOGGLE;
+   union  GPBDAT_REG    GPBDAT;
+   union  GPBSET_REG    GPBSET;
+   union  GPBCLEAR_REG  GPBCLEAR;
+   union  GPBTOGGLE_REG GPBTOGGLE;
+   Uint16               rsvd1[4];
+   union  GPDDAT_REG    GPDDAT;
+   union  GPDSET_REG    GPDSET;
+   union  GPDCLEAR_REG  GPDCLEAR;
+   union  GPDTOGGLE_REG GPDTOGGLE;
+   union  GPEDAT_REG    GPEDAT;
+   union  GPESET_REG    GPESET;
+   union  GPECLEAR_REG  GPECLEAR;
+   union  GPETOGGLE_REG GPETOGGLE;
+   union  GPFDAT_REG    GPFDAT;
+   union  GPFSET_REG    GPFSET;
+   union  GPFCLEAR_REG  GPFCLEAR;
+   union  GPFTOGGLE_REG GPFTOGGLE;
+   union  GPGDAT_REG    GPGDAT;
+   union  GPGSET_REG    GPGSET;
+   union  GPGCLEAR_REG  GPGCLEAR;
+   union  GPGTOGGLE_REG GPGTOGGLE;
+   Uint16               rsvd2[4];      
+};     
+ 
+
+//---------------------------------------------------------------------------
+// GPI/O External References & Function Declarations:
+//
+extern struct GPIO_MUX_REGS GpioMuxRegs;
+extern struct GPIO_DATA_REGS GpioDataRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_GPIO_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Mcbsp.h b/Inu/main_matlab/device_support/include/DSP281x_Mcbsp.h
new file mode 100644
index 0000000..ebadfbd
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Mcbsp.h
@@ -0,0 +1,778 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:24 $
+//###########################################################################
+//
+// FILE:   DSP281x_Mcbsp.h
+//
+// TITLE:  DSP281x Device McBSP Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_MCBSP_H
+#define DSP281x_MCBSP_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// McBSP Individual Register Bit Definitions:
+//
+// McBSP DRR2 register bit definitions:
+struct  DRR2_BITS {       // bit   description
+   Uint16     HWLB:8;     // 16:23 High word low byte
+   Uint16     HWHB:8;     // 24:31 High word high byte
+};                                                                 
+
+union DRR2_REG {
+   Uint16            all;
+   struct DRR2_BITS  bit;
+};
+
+// McBSP DRR1 register bit definitions:
+struct  DRR1_BITS {       // bit   description
+   Uint16     LWLB:8;     // 16:23 Low word low byte
+   Uint16     LWHB:8;     // 24:31 low word high byte
+};
+
+union DRR1_REG {
+   Uint16            all;
+   struct DRR1_BITS  bit;
+};
+
+// McBSP DXR2 register bit definitions:
+struct  DXR2_BITS {       // bit   description
+   Uint16     HWLB:8;     // 16:23 High word low byte
+   Uint16     HWHB:8;     // 24:31 High word high byte
+};
+
+union DXR2_REG {
+   Uint16            all;
+   struct DXR2_BITS  bit;
+};
+
+// McBSP DXR1 register bit definitions:
+struct  DXR1_BITS {       // bit   description
+   Uint16     LWLB:8;     // 16:23 Low word low byte
+   Uint16     LWHB:8;     // 24:31 low word high byte
+};               
+
+union DXR1_REG {
+   Uint16              all;
+   struct DXR1_BITS  bit;
+};
+
+// SPCR2 control register bit definitions:
+struct  SPCR2_BITS {       // bit   description
+   Uint16     XRST:1;      // 0     transmit reset
+   Uint16     XRDY:1;      // 1     transmit ready
+   Uint16     XEMPTY:1;    // 2     Transmit empty    
+   Uint16     XSYNCERR:1;  // 3     Transmit syn errorINT flag
+   Uint16     XINTM:2;     // 5:4   Transmit interrupt types
+   Uint16     GRST:1;      // 6     CLKG reset     
+   Uint16     FRST:1;      // 7     Frame sync reset
+   Uint16     SOFT:1;      // 8     SOFT bit
+   Uint16     FREE:1;      // 9     FREE bit
+   Uint16     rsvd:6;      // 15:10 reserved
+}; 
+
+union SPCR2_REG {
+   Uint16               all;
+   struct SPCR2_BITS  bit;
+};
+         
+// SPCR1 control register bit definitions:
+struct  SPCR1_BITS {       // bit   description
+   Uint16     RRST:1;      // 0     Receive reset
+   Uint16     RRDY:1;      // 1     Receive  ready
+   Uint16     RFULL:1;     // 2     Receive  full    
+   Uint16     RSYNCERR:1;  // 7     Receive  syn error
+   Uint16     RINTM:2;     // 5:4   Receive  interrupt types
+   Uint16     ABIS:1;      // 6     ABIS mode select     
+   Uint16     DXENA:1;     // 7     DX hi-z enable     
+   Uint16     rsvd:3;      // 10:8  reserved  
+   Uint16     CLKSTP:2;    // 12:11 CLKSTOP mode bit
+   Uint16     RJUST:2;     // 13:14 Right justified
+   Uint16     DLB:1;       // 15    Digital loop back
+}; 
+
+union SPCR1_REG {
+   Uint16              all;
+   struct SPCR1_BITS bit;
+};                                                               
+
+// RCR2 control register bit definitions:
+struct  RCR2_BITS {         // bit    description
+   Uint16     RDATDLY:2;    // 1:0    Receive data delay
+   Uint16     RFIG:1;       // 2      Receive  frame sync ignore
+   Uint16     RCOMPAND:2;   // 4:3    Receive  Companding Mode selects
+   Uint16     RWDLEN2:3;    // 7:5    Receive  word length   
+   Uint16     RFRLEN2:7;    // 14:8   Receive  Frame sync
+   Uint16     RPHASE:1;     // 15     Receive Phase
+}; 
+
+union RCR2_REG {
+   Uint16           all;
+   struct RCR2_BITS bit;
+};
+     
+// RCR1 control register bit definitions:
+struct  RCR1_BITS {         // bit   description
+   Uint16     rsvd1:5;      // 4:0   reserved  
+   Uint16     RWDLEN1:3;    // 7:5   Receive word length   
+   Uint16     RFRLEN1:7;    // 14:8  Receive frame length    
+   Uint16     rsvd2:1;      // 15    reserved  
+}; 
+
+union RCR1_REG {
+   Uint16           all;
+   struct RCR1_BITS bit;
+};    
+
+// XCR2 control register bit definitions:
+
+struct  XCR2_BITS {         // bit    description
+   Uint16     XDATDLY:2;    // 1:0    Transmit data delay
+   Uint16     XFIG:1;       // 2      Transmit frame sync ignore
+   Uint16     XCOMPAND:2;   // 4:3    Transmit Companding Mode selects
+   Uint16     XWDLEN2:3;    // 7:5    Transmit  word length   
+   Uint16     XFRLEN2:7;    // 14:8   Transmit  Frame sync
+   Uint16     XPHASE:1;     // 15     Transmit Phase
+}; 
+
+union XCR2_REG {
+   Uint16           all;
+   struct XCR2_BITS bit;
+};
+     
+// XCR1 control register bit definitions:
+struct  XCR1_BITS {         // bit   description
+   Uint16     rsvd1:5;      // 4:0   reserved      
+   Uint16     XWDLEN1:3;    // 7:5   Transmit word length    
+   Uint16     XFRLEN1:7;    // 14:8  Transmit frame length    
+   Uint16     rsvd2:1;      // 15    reserved  
+}; 
+
+union XCR1_REG {
+   Uint16             all;
+   struct XCR1_BITS bit;
+};         
+
+// SRGR2 Sample rate generator control register bit definitions:
+struct  SRGR2_BITS {        // bit  description
+   Uint16     FPER:12;      // 11:0 Frame period
+   Uint16     FSGM:1;       // 12   Frame sync generator mode 
+   Uint16     CLKSM:1;      // 13   Sample rate generator mode
+   Uint16     rsvd:1;       // 14   reserved 
+   Uint16     GSYNC:1;      // 15   CLKG sync   
+}; 
+
+union  SRGR2_REG {
+   Uint16              all;
+   struct  SRGR2_BITS  bit;
+};
+
+// SRGR1 control register bit definitions:
+struct  SRGR1_BITS {        // bit   description
+   Uint16     CLKGDV:8;     // 7:0   CLKG divider 
+   Uint16     FWID:8;       // 15:8  Frame width
+}; 
+
+union  SRGR1_REG {
+   Uint16              all;
+   struct  SRGR1_BITS  bit;
+};
+
+// MCR2 Multichannel control register bit definitions:
+struct  MCR2_BITS {         // bit   description
+   Uint16     XMCM:2;       // 1:0   Transmit multichannel mode      
+   Uint16     XCBLK:3;      // 2:4   Transmit current block    
+   Uint16     XPABLK:2;     // 5:6   Transmit partition A Block 
+   Uint16     XPBBLK:2;     // 7:8   Transmit partition B Block 
+   Uint16     XMCME:1;      // 9     Transmit multi-channel enhance mode 
+   Uint16     rsvd:6;       // 15:10 reserved  
+}; 
+
+union  MCR2_REG {
+   Uint16             all;
+   struct  MCR2_BITS  bit;
+};
+      
+// MCR1 Multichannel control register bit definitions:
+struct  MCR1_BITS {         // bit   description
+   Uint16     RMCM:1;       // 0     Receive multichannel mode  
+   Uint16     rsvd:1;       // 1     reserved     
+   Uint16     RCBLK:3;      // 4:2   Receive current block    
+   Uint16     RPABLK:2;     // 6:5   Receive partition A Block 
+   Uint16     RPBBLK:2;     // 7:8   Receive partition B Block 
+   Uint16     RMCME:1;      // 9     Receive multi-channel enhance mode 
+   Uint16     rsvd1:6;      // 15:10 reserved   
+}; 
+
+union  MCR1_REG {
+   Uint16             all;
+   struct  MCR1_BITS  bit;
+};
+ 
+// RCERA control register bit definitions:
+struct  RCERA_BITS {         // bit description
+   Uint16     RCEA0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEA1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEA2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEA3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEA4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEA5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEA6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEA7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEA8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEA9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEA10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEA11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEA12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEA13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEA14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEA15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERA_REG {
+   Uint16              all;
+   struct  RCERA_BITS  bit;
+};  
+
+// RCERB control register bit definitions:
+struct  RCERB_BITS {         // bit description
+   Uint16     RCEB0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEB1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEB2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEB3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEB4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEB5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEB6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEB7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEB8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEB9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEB10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEB11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEB12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEB13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEB14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEB15:1;      // 15  Receive Channel enable bit   
+}; 
+
+union RCERB_REG {
+   Uint16              all;
+   struct  RCERB_BITS  bit;
+};
+
+// XCERA control register bit definitions:
+struct  XCERA_BITS {         // bit description
+   Uint16     XCERA0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERA1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERA2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERA3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERA4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERA5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERA6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERA7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERA8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERA9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERA10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERA11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERA12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERA13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERA14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERA15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERA_REG {
+   Uint16              all;
+   struct  XCERA_BITS  bit;
+};  
+
+// XCERB control register bit definitions:
+struct  XCERB_BITS {         // bit description
+   Uint16     XCERB0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERB1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERB2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERB3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERB4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERB5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERB6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERB7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERB8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERB9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERB10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERB11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERB12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERB13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERB14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERB15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERB_REG {
+   Uint16              all;
+   struct  XCERB_BITS  bit;
+};
+  
+// PCR control register bit definitions:
+struct  PCR_BITS {          // bit description
+   Uint16     CLKRP:1;       // 0   Receive Clock polarity
+   Uint16     CLKXP:1;       // 1   Transmit clock polarity  
+   Uint16     FSRP:1;        // 2   Receive Frame synchronization polarity  
+   Uint16     FSXP:1;        // 3   Transmit Frame synchronization polarity   
+   Uint16     DR_STAT:1;     // 4   DR pin status - reserved for this McBSP  
+   Uint16     DX_STAT:1;     // 5   DX pin status - reserved for this McBSP  
+   Uint16     CLKS_STAT:1;   // 6   CLKS pin status - reserved for 28x -McBSP  
+   Uint16     SCLKME:1;      // 7   Enhanced sample clock mode selection bit.
+   Uint16     CLKRM:1;       // 8   Receiver Clock Mode 
+   Uint16     CLKXM:1;       // 9   Transmitter Clock Mode.  
+   Uint16     FSRM:1;        // 10  Receive Frame Synchronization Mode  
+   Uint16     FSXM:1;        // 11  Transmit Frame Synchronization Mode
+   Uint16     RIOEN:1;       // 12  General Purpose I/O Mode - reserved in this 28x-McBSP    
+   Uint16     XIOEN:1;       // 13  General Purpose I/O Mode - reserved in this 28x-McBSP
+   Uint16     IDEL_EN:1;     // 14  reserved in this 28x-McBSP
+   Uint16     rsvd:1  ;      // 15  reserved
+}; 
+
+union PCR_REG {
+   Uint16            all;
+   struct  PCR_BITS  bit;
+};
+  
+// RCERC control register bit definitions:
+struct  RCERC_BITS {         // bit description
+   Uint16     RCEC0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEC1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEC2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEC3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEC4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEC5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEC6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEC7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEC8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEC9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEC10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEC11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEC12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEC13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEC14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEC15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERC_REG {
+   Uint16              all;
+   struct  RCERC_BITS  bit;
+};  
+
+// RCERD control register bit definitions:
+struct  RCERD_BITS {         // bit description
+   Uint16     RCED0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCED1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCED2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCED3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCED4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCED5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCED6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCED7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCED8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCED9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCED10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCED11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCED12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCED13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCED14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCED15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERD_REG {
+   Uint16              all;
+   struct  RCERD_BITS  bit;
+};
+
+// XCERC control register bit definitions:
+struct  XCERC_BITS {         // bit description
+   Uint16     XCERC0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERC1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERC2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERC3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERC4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERC5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERC6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERC7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERC8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERC9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERC10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERC11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERC12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERC13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERC14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERC15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERC_REG {
+   Uint16              all;
+   struct  XCERC_BITS  bit;
+};  
+
+// XCERD control register bit definitions:
+struct  XCERD_BITS {         // bit description
+   Uint16     XCERD0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERD1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERD2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERD3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERD4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERD5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERD6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERD7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERD8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERD9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERD10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERD11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERD12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERD13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERD14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERD15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERD_REG {
+   Uint16              all;
+   struct  XCERD_BITS  bit;
+};
+  
+// RCERE control register bit definitions:
+struct  RCERE_BITS {         // bit description
+   Uint16     RCEE0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEE1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEE2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEE3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEE4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEE5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEE6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEE7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEE8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEE9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEE10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEE11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEE12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEE13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEE14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEE15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERE_REG {
+   Uint16              all;
+   struct  RCERE_BITS  bit;
+};  
+
+// RCERF control register bit definitions:
+struct  RCERF_BITS {         // bit   description
+   Uint16     RCEF0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEF1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEF2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEF3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEF4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEF5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEF6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEF7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEF8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEF9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEF10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEF11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEF12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEF13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEF14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEF15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERF_REG {
+   Uint16              all;
+   struct  RCERF_BITS  bit;
+};
+
+// XCERE control register bit definitions:
+struct  XCERE_BITS {         // bit description
+   Uint16     XCERE0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERE1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERE2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERE3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERE4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERE5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERE6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERE7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERE8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERE9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERE10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERE11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERE12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERE13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERE14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERE15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERE_REG {
+   Uint16              all;
+   struct  XCERE_BITS  bit;
+};  
+
+// XCERF control register bit definitions:
+struct  XCERF_BITS {         // bit description
+   Uint16     XCERF0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERF1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERF2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERF3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERF4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERF5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERF6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERF7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERF8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERF9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERF10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERF11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERF12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERF13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERF14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERF15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERF_REG {
+   Uint16              all;
+   struct  XCERF_BITS  bit;
+};                   
+
+// RCERG control register bit definitions:
+struct  RCERG_BITS {         // bit description
+   Uint16     RCEG0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEG1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEG2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEG3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEG4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEG5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEG6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEG7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEG8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEG9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEG10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEG11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEG12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEG13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEG14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEG15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERG_REG {
+   Uint16              all;
+   struct  RCERG_BITS  bit;
+};  
+
+// RCERH control register bit definitions:
+struct  RCERH_BITS {         // bit description
+   Uint16     RCEH0:1;       // 0   Receive Channel enable bit  
+   Uint16     RCEH1:1;       // 1   Receive Channel enable bit  
+   Uint16     RCEH2:1;       // 2   Receive Channel enable bit  
+   Uint16     RCEH3:1;       // 3   Receive Channel enable bit   
+   Uint16     RCEH4:1;       // 4   Receive Channel enable bit  
+   Uint16     RCEH5:1;       // 5   Receive Channel enable bit  
+   Uint16     RCEH6:1;       // 6   Receive Channel enable bit  
+   Uint16     RCEH7:1;       // 7   Receive Channel enable bit 
+   Uint16     RCEH8:1;       // 8   Receive Channel enable bit  
+   Uint16     RCEH9:1;       // 9   Receive Channel enable bit  
+   Uint16     RCEH10:1;      // 10  Receive Channel enable bit  
+   Uint16     RCEH11:1;      // 11  Receive Channel enable bit 
+   Uint16     RCEH12:1;      // 12  Receive Channel enable bit  
+   Uint16     RCEH13:1;      // 13  Receive Channel enable bit  
+   Uint16     RCEH14:1;      // 14  Receive Channel enable bit  
+   Uint16     RCEH15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union RCERH_REG {
+   Uint16              all;
+   struct  RCERH_BITS  bit;
+};
+
+// XCERG control register bit definitions:
+struct  XCERG_BITS {         // bit description
+   Uint16     XCERG0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCERG1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCERG2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCERG3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCERG4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCERG5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCERG6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCERG7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCERG8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCERG9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCERG10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCERG11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCERG12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCERG13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCERG14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCERG15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERG_REG {
+   Uint16              all;
+   struct  XCERG_BITS  bit;
+};  
+
+// XCERH control register bit definitions:
+struct  XCERH_BITS {         // bit description
+   Uint16     XCEH0:1;       // 0   Receive Channel enable bit  
+   Uint16     XCEH1:1;       // 1   Receive Channel enable bit  
+   Uint16     XCEH2:1;       // 2   Receive Channel enable bit  
+   Uint16     XCEH3:1;       // 3   Receive Channel enable bit   
+   Uint16     XCEH4:1;       // 4   Receive Channel enable bit  
+   Uint16     XCEH5:1;       // 5   Receive Channel enable bit  
+   Uint16     XCEH6:1;       // 6   Receive Channel enable bit  
+   Uint16     XCEH7:1;       // 7   Receive Channel enable bit 
+   Uint16     XCEH8:1;       // 8   Receive Channel enable bit  
+   Uint16     XCEH9:1;       // 9   Receive Channel enable bit  
+   Uint16     XCEH10:1;      // 10  Receive Channel enable bit  
+   Uint16     XCEH11:1;      // 11  Receive Channel enable bit 
+   Uint16     XCEH12:1;      // 12  Receive Channel enable bit  
+   Uint16     XCEH13:1;      // 13  Receive Channel enable bit  
+   Uint16     XCEH14:1;      // 14  Receive Channel enable bit  
+   Uint16     XCEH15:1;      // 15  Receive Channel enable bit 
+}; 
+
+union XCERH_REG {
+   Uint16              all;
+   struct  XCERH_BITS  bit;
+};
+
+// McBSP FIFO Transmit register bit definitions:
+struct  MFFTX_BITS {            // bit   description
+   Uint16     TXFFIL:5;         // 4:0   Interrupt level
+   Uint16     TXFFIENA:1;       // 5     Interrupt enable
+   Uint16     TXFFINT_CLEAR:1;  // 6     Clear INT flag
+   Uint16     TXFFINT_FLAG:1;   // 7     INT flag
+   Uint16     TXFFST:5;         // 12:8  FIFO status
+   Uint16     TXFIFO_RESET:1;   // 13    FIFO reset
+   Uint16     MFFENA:1;         // 14    Enhancement enable
+   Uint16     rsvd:1;           // 15    reserved
+}; 
+
+union MFFTX_REG {
+   Uint16            all;
+   struct MFFTX_BITS bit;
+};
+
+// McBSP FIFO recieve register bit definitions:
+struct  MFFRX_BITS {        // bits  description
+   Uint16 RXFFIL:5;         // 4:0   Interrupt level
+   Uint16 RXFFIENA:1;       // 5     Interrupt enable
+   Uint16 RXFFINT_CLEAR:1;  // 6     Clear INT flag
+   Uint16 RXFFINT_FLAG:1;   // 7     INT flag
+   Uint16 RXFFST:5;         // 12:8  FIFO status
+   Uint16 RXFIFO_RESET:1;   // 13    FIFO reset
+   Uint16 RXFFOVF_CLEAR:1;  // 14    Clear overflow
+   Uint16 RXFFOVF_FLAG:1;   // 15    FIFO overflow
+}; 
+
+union MFFRX_REG {
+   Uint16            all;
+   struct MFFRX_BITS bit;
+};
+
+// McBSP FIFO control register bit definitions:
+struct  MFFCT_BITS {        // bits  description
+    Uint16 FFTXTXDLY:8;     // 7:0   FIFO transmit delay
+    Uint16 rsvd:7;          // 15:7  reserved
+    Uint16 IACKM:1;         // 15    is IACK mode enable bit
+};
+
+union MFFCT_REG {
+   Uint16             all;
+   struct MFFCT_BITS  bit;
+};
+   
+// McBSP FIFO INTERRUPT control register bit definitions:
+struct  MFFINT_BITS {       // bits description
+    Uint16     XINT:1;      // 0    XINT  interrupt enable
+    Uint16     XEVTA:1;     // 1    XEVTA interrupt enable
+    Uint16     RINT:1;      // 2    RINT  interrupt enable
+    Uint16     REVTA:1;     // 3    REVTA interrupt enable
+    Uint16     rsvd:12;     // 15:4 reserved
+};
+
+union MFFINT_REG {
+   Uint16              all;
+   struct MFFINT_BITS  bit;
+};
+
+// McBSP FIFO INTERRUPT status  register bit definitions:
+struct  MFFST_BITS {       // bits description
+    Uint16     EOBX:1;     // 0    EOBX flag
+    Uint16     FSX:1;      // 1    FSX flag
+    Uint16     EOBR:1;     // 2    EOBR flag
+    Uint16     FSR:1;      // 3    FSR flag
+    Uint16     rsvd:12;    // 15:4 reserved
+};
+
+union MFFST_REG {
+   Uint16            all;
+   struct MFFST_BITS bit;
+};
+
+
+//---------------------------------------------------------------------------
+// McBSP Register File:
+//
+struct  MCBSP_REGS {      
+   union DRR2_REG    DRR2;   // 0x7800, MCBSP Data receive register bits 31-16 
+   union DRR1_REG    DRR1;   // 0x7801, MCBSP Data receive register bits 15-0 
+   union DXR2_REG    DXR2;   // 0x7802, MCBSP Data transmit register bits 31-16 
+   union DXR1_REG    DXR1;   // 0x7803, MCBSP Data transmit register bits 15-0 
+   union SPCR2_REG   SPCR2;  // 0x7804, MCBSP control register bits 31-16 
+   union SPCR1_REG   SPCR1;  // 0x7805, MCBSP control register bits 15-0 
+   union RCR2_REG    RCR2;   // 0x7806, MCBSP receive control register bits 31-16 
+   union RCR1_REG    RCR1;   // 0x7807, MCBSP receive control register bits 15-0 
+   union XCR2_REG    XCR2;   // 0x7808, MCBSP transmit control register bits 31-16 
+   union XCR1_REG    XCR1;   // 0x7809, MCBSP transmit control register bits 15-0 
+   union SRGR2_REG   SRGR2;  // 0x7810, MCBSP sample rate gen register bits 31-16 
+   union SRGR1_REG   SRGR1;  // 0x7811, MCBSP sample rate gen register bits 15-0  
+   union MCR2_REG    MCR2;   // 0x7812, MCBSP multichannel register bits 31-16 
+   union MCR1_REG    MCR1;   // 0x7813, MCBSP multichannel register bits 15-0    
+   union RCERA_REG   RCERA;  // 0x7814, MCBSP Receive channel enable partition A 
+   union RCERB_REG   RCERB;  // 0x7815, MCBSP Receive channel enable partition B 
+   union XCERA_REG   XCERA;  // 0x7816, MCBSP Transmit channel enable partition A 
+   union XCERB_REG   XCERB;  // 0x7817, MCBSP Transmit channel enable partition B            
+   union PCR_REG     PCR;    // 0x7818, MCBSP Pin control register bits 15-0  
+   union RCERC_REG   RCERC;  // 0x7819, MCBSP Receive channel enable partition C 
+   union RCERD_REG   RCERD;  // 0x7820, MCBSP Receive channel enable partition D
+   union XCERC_REG   XCERC;  // 0x7821, MCBSP Transmit channel enable partition C 
+   union XCERD_REG   XCERD;  // 0x7823, MCBSP Transmit channel enable partition D             
+   union RCERE_REG   RCERE;  // 0x7824, MCBSP Receive channel enable partition E 
+   union RCERF_REG   RCERF;  // 0x7825, MCBSP Receive channel enable partition F
+   union XCERE_REG   XCERE;  // 0x7826, MCBSP Transmit channel enable partition E
+   union XCERF_REG   XCERF;  // 0x7827, MCBSP Transmit channel enable partition F            
+   union RCERG_REG   RCERG;  // 0x7828, MCBSP Receive channel enable partition G
+   union RCERH_REG   RCERH;  // 0x7829, MCBSP Receive channel enable partition H
+   union XCERG_REG   XCERG;  // 0x7830, MCBSP Transmit channel enable partition G 
+   union XCERH_REG   XCERH;  // 0x7831, MCBSP Transmit channel enable partition H             
+   Uint16            rsvd1;  // 0x7832, reserved             
+   union MFFTX_REG   MFFTX;  // 0x7833, MCBSP Transmit FIFO register bits  
+   union MFFRX_REG   MFFRX;  // 0x7834, MCBSP Receive FIFO register bits
+   union MFFCT_REG   MFFCT;  // 0x7835, MCBSP FIFO control register bits    
+   union MFFINT_REG  MFFINT; // 0x7836, MCBSP Interrupt register bits  
+   union MFFST_REG   MFFST;  // 0x7837, MCBSP Status register bits 
+};
+
+//---------------------------------------------------------------------------
+// McBSP External References & Function Declarations:
+//
+extern struct MCBSP_REGS McbspaRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_MCBSP_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_PieCtrl.h b/Inu/main_matlab/device_support/include/DSP281x_PieCtrl.h
new file mode 100644
index 0000000..20698fb
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_PieCtrl.h
@@ -0,0 +1,154 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:22 $
+//###########################################################################
+//
+// FILE:   DSP281x_PieCtrl.h
+//
+// TITLE:  DSP281x Device PIE Control Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+
+#ifndef DSP281x_PIE_CTRL_H
+#define DSP281x_PIE_CTRL_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//---------------------------------------------------------------------------
+// PIE Control Register Bit Definitions:
+//
+// PIECTRL: Register bit definitions:
+struct PIECTRL_BITS {      // bits description
+   Uint16  ENPIE:1;        // 0    Enable PIE block
+   Uint16  PIEVECT:15;     // 15:1 Fetched vector address
+};
+
+union PIECTRL_REG {
+   Uint16                 all;
+   struct PIECTRL_BITS  bit;
+};  
+
+// PIEIER: Register bit definitions:
+struct PIEIER_BITS {       // bits description
+   Uint16 INTx1:1;         // 0    INTx.1
+   Uint16 INTx2:1;         // 1    INTx.2
+   Uint16 INTx3:1;         // 2    INTx.3
+   Uint16 INTx4:1;         // 3    INTx.4
+   Uint16 INTx5:1;         // 4    INTx.5
+   Uint16 INTx6:1;         // 5    INTx.6
+   Uint16 INTx7:1;         // 6    INTx.7
+   Uint16 INTx8:1;         // 7    INTx.8
+   Uint16 rsvd:8;          // 15:8 reserved
+};
+
+union PIEIER_REG {
+   Uint16              all;
+   struct PIEIER_BITS  bit;
+}; 
+
+// PIEIFR: Register bit definitions:
+struct PIEIFR_BITS {       // bits description
+   Uint16 INTx1:1;         // 0    INTx.1
+   Uint16 INTx2:1;         // 1    INTx.2
+   Uint16 INTx3:1;         // 2    INTx.3
+   Uint16 INTx4:1;         // 3    INTx.4
+   Uint16 INTx5:1;         // 4    INTx.5
+   Uint16 INTx6:1;         // 5    INTx.6
+   Uint16 INTx7:1;         // 6    INTx.7
+   Uint16 INTx8:1;         // 7    INTx.8
+   Uint16 rsvd:8;          // 15:8 reserved
+};
+
+union PIEIFR_REG {
+   Uint16              all;
+   struct PIEIFR_BITS  bit;
+};
+
+// PIEACK: Register bit definitions:
+struct PIEACK_BITS {       // bits description
+   Uint16 ACK1:1;          // 0    Acknowledge PIE interrupt group 1
+   Uint16 ACK2:1;          // 1    Acknowledge PIE interrupt group 2
+   Uint16 ACK3:1;          // 2    Acknowledge PIE interrupt group 3
+   Uint16 ACK4:1;          // 3    Acknowledge PIE interrupt group 4
+   Uint16 ACK5:1;          // 4    Acknowledge PIE interrupt group 5
+   Uint16 ACK6:1;          // 5    Acknowledge PIE interrupt group 6
+   Uint16 ACK7:1;          // 6    Acknowledge PIE interrupt group 7
+   Uint16 ACK8:1;          // 7    Acknowledge PIE interrupt group 8
+   Uint16 ACK9:1;          // 8    Acknowledge PIE interrupt group 9
+   Uint16 ACK10:1;         // 9    Acknowledge PIE interrupt group 10
+   Uint16 ACK11:1;         // 10   Acknowledge PIE interrupt group 11
+   Uint16 ACK12:1;         // 11   Acknowledge PIE interrupt group 12
+   Uint16 rsvd:4;          // 15:12 reserved
+};
+
+union PIEACK_REG {
+   Uint16              all;
+   struct PIEACK_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// PIE Control Register File:
+//
+struct PIE_CTRL_REGS {
+   union PIECTRL_REG PIECRTL;       // PIE control register
+   union PIEACK_REG  PIEACK;        // PIE acknowledge
+   union PIEIER_REG  PIEIER1;       // PIE INT1 IER register  
+   union PIEIFR_REG  PIEIFR1;       // PIE INT1 IFR register
+   union PIEIER_REG  PIEIER2;       // PIE INT2 IER register 
+   union PIEIFR_REG  PIEIFR2;       // PIE INT2 IFR register
+   union PIEIER_REG  PIEIER3;       // PIE INT3 IER register 
+   union PIEIFR_REG  PIEIFR3;       // PIE INT3 IFR register
+   union PIEIER_REG  PIEIER4;       // PIE INT4 IER register             
+   union PIEIFR_REG  PIEIFR4;       // PIE INT4 IFR register
+   union PIEIER_REG  PIEIER5;       // PIE INT5 IER register  
+   union PIEIFR_REG  PIEIFR5;       // PIE INT5 IFR register
+   union PIEIER_REG  PIEIER6;       // PIE INT6 IER register 
+   union PIEIFR_REG  PIEIFR6;       // PIE INT6 IFR register
+   union PIEIER_REG  PIEIER7;       // PIE INT7 IER register 
+   union PIEIFR_REG  PIEIFR7;       // PIE INT7 IFR register
+   union PIEIER_REG  PIEIER8;       // PIE INT8 IER register
+   union PIEIFR_REG  PIEIFR8;       // PIE INT8 IFR register
+   union PIEIER_REG  PIEIER9;       // PIE INT9 IER register  
+   union PIEIFR_REG  PIEIFR9;       // PIE INT9 IFR register
+   union PIEIER_REG  PIEIER10;      // PIE INT10 IER register 
+   union PIEIFR_REG  PIEIFR10;      // PIE INT10 IFR register
+   union PIEIER_REG  PIEIER11;      // PIE INT11 IER register 
+   union PIEIFR_REG  PIEIFR11;      // PIE INT11 IFR register
+   union PIEIER_REG  PIEIER12;      // PIE INT12 IER register
+   union PIEIFR_REG  PIEIFR12;      // PIE INT12 IFR register
+};     
+
+#define PIEACK_GROUP1   0x0001;
+#define PIEACK_GROUP2   0x0002;
+#define PIEACK_GROUP3   0x0004;
+#define PIEACK_GROUP4   0x0008;
+#define PIEACK_GROUP5   0x0010;
+#define PIEACK_GROUP6   0x0020;
+#define PIEACK_GROUP7   0x0040;
+#define PIEACK_GROUP8   0x0080;
+#define PIEACK_GROUP9   0x0100;
+#define PIEACK_GROUP10  0x0200;
+#define PIEACK_GROUP11  0x0400;
+#define PIEACK_GROUP12  0x0800;
+
+//---------------------------------------------------------------------------
+// PIE Control Registers External References & Function Declarations:
+//
+extern struct PIE_CTRL_REGS PieCtrlRegs;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_PIE_CTRL_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_PieVect.h b/Inu/main_matlab/device_support/include/DSP281x_PieVect.h
new file mode 100644
index 0000000..227c4f0
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_PieVect.h
@@ -0,0 +1,210 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:21 $
+//###########################################################################
+//
+// FILE:   DSP281x_PieVect.h
+//
+// TITLE:  DSP281x Devices PIE Vector Table Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_PIE_VECT_H
+#define DSP281x_PIE_VECT_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// PIE Interrupt Vector Table Definition:
+//
+// Create a user type called PINT (pointer to interrupt):
+
+typedef interrupt void(*PINT)(void);
+
+// Define Vector Table:
+struct PIE_VECT_TABLE {
+
+// Reset is never fetched from this table.  
+// It will always be fetched from 0x3FFFC0 in either
+// boot ROM or XINTF Zone 7 depending on the state of
+// the XMP/MC input signal.  On the F2810 it is always
+// fetched from boot ROM. 
+
+      PINT     PIE1_RESERVED;  
+      PINT     PIE2_RESERVED;
+      PINT     PIE3_RESERVED;
+      PINT     PIE4_RESERVED;
+      PINT     PIE5_RESERVED;
+      PINT     PIE6_RESERVED;
+      PINT     PIE7_RESERVED;
+      PINT     PIE8_RESERVED;
+      PINT     PIE9_RESERVED;
+      PINT     PIE10_RESERVED;
+      PINT     PIE11_RESERVED;
+      PINT     PIE12_RESERVED;
+      PINT     PIE13_RESERVED;
+
+// Non-Peripheral Interrupts:
+      PINT     XINT13;    // XINT13
+      PINT     TINT2;     // CPU-Timer2
+      PINT     DATALOG;   // Datalogging interrupt
+      PINT     RTOSINT;   // RTOS interrupt
+      PINT     EMUINT;    // Emulation interrupt
+      PINT     XNMI;      // Non-maskable interrupt
+      PINT     ILLEGAL;   // Illegal operation TRAP
+      PINT     USER1;     // User Defined trap 1
+      PINT     USER2;     // User Defined trap 2
+      PINT     USER3;     // User Defined trap 3
+      PINT     USER4;     // User Defined trap 4
+      PINT     USER5;     // User Defined trap 5
+      PINT     USER6;     // User Defined trap 6
+      PINT     USER7;     // User Defined trap 7
+      PINT     USER8;     // User Defined trap 8
+      PINT     USER9;     // User Defined trap 9
+      PINT     USER10;    // User Defined trap 10
+      PINT     USER11;    // User Defined trap 11
+      PINT     USER12;    // User Defined trap 12
+      
+// Group 1 PIE Peripheral Vectors:
+      PINT     PDPINTA;   // EV-A
+      PINT     PDPINTB;   // EV-B
+      PINT     rsvd1_3;
+      PINT     XINT1;     
+      PINT     XINT2;
+      PINT     ADCINT;    // ADC
+      PINT     TINT0;     // Timer 0
+      PINT     WAKEINT;   // WD
+           
+// Group 2 PIE Peripheral Vectors:
+      PINT     CMP1INT;   // EV-A
+      PINT     CMP2INT;   // EV-A
+      PINT     CMP3INT;   // EV-A
+      PINT     T1PINT;    // EV-A
+      PINT     T1CINT;    // EV-A
+      PINT     T1UFINT;   // EV-A
+      PINT     T1OFINT;   // EV-A
+      PINT     rsvd2_8;
+      
+// Group 3 PIE Peripheral Vectors:
+      PINT     T2PINT;    // EV-A
+      PINT     T2CINT;    // EV-A
+      PINT     T2UFINT;   // EV-A
+      PINT     T2OFINT;   // EV-A
+      PINT     CAPINT1;   // EV-A
+      PINT     CAPINT2;   // EV-A
+      PINT     CAPINT3;   // EV-A
+      PINT     rsvd3_8;
+      
+// Group 4 PIE Peripheral Vectors:
+      PINT     CMP4INT;   // EV-B
+      PINT     CMP5INT;   // EV-B
+      PINT     CMP6INT;   // EV-B
+      PINT     T3PINT;    // EV-B
+      PINT     T3CINT;    // EV-B
+      PINT     T3UFINT;   // EV-B
+      PINT     T3OFINT;   // EV-B
+      PINT     rsvd4_8;      
+     
+// Group 5 PIE Peripheral Vectors:
+      PINT     T4PINT;    // EV-B
+      PINT     T4CINT;    // EV-B
+      PINT     T4UFINT;   // EV-B
+      PINT     T4OFINT;   // EV-B
+      PINT     CAPINT4;   // EV-B
+      PINT     CAPINT5;   // EV-B
+      PINT     CAPINT6;   // EV-B
+      PINT     rsvd5_8;      
+
+// Group 6 PIE Peripheral Vectors:
+      PINT     SPIRXINTA; // SPI-A
+      PINT     SPITXINTA; // SPI-A
+      PINT     rsvd6_3;
+      PINT     rsvd6_4;
+      PINT     MRINTA;    // McBSP-A
+      PINT     MXINTA;    // McBSP-A
+      PINT     rsvd6_7;
+      PINT     rsvd6_8;
+      
+// Group 7 PIE Peripheral Vectors:
+      PINT     rsvd7_1;
+      PINT     rsvd7_2;
+      PINT     rsvd7_3;
+      PINT     rsvd7_4;
+      PINT     rsvd7_5;
+      PINT     rsvd7_6;
+      PINT     rsvd7_7;
+      PINT     rsvd7_8;
+
+// Group 8 PIE Peripheral Vectors:
+      PINT     rsvd8_1;
+      PINT     rsvd8_2;
+      PINT     rsvd8_3;
+      PINT     rsvd8_4;
+      PINT     rsvd8_5;
+      PINT     rsvd8_6;
+      PINT     rsvd8_7;
+      PINT     rsvd8_8; 
+
+// Group 9 PIE Peripheral Vectors:   
+      PINT     RXAINT;    // SCI-A
+      PINT     TXAINT;    // SCI-A
+      PINT     RXBINT;    // SCI-B
+      PINT     TXBINT;    // SCI-B
+      PINT     ECAN0INTA; // eCAN
+      PINT     ECAN1INTA; // eCAN
+      PINT     rsvd9_7;
+      PINT     rsvd9_8;
+
+// Group 10 PIE Peripheral Vectors:
+      PINT     rsvd10_1;
+      PINT     rsvd10_2;
+      PINT     rsvd10_3;
+      PINT     rsvd10_4;
+      PINT     rsvd10_5;
+      PINT     rsvd10_6;
+      PINT     rsvd10_7;
+      PINT     rsvd10_8;
+            
+// Group 11 PIE Peripheral Vectors:
+      PINT     rsvd11_1;
+      PINT     rsvd11_2;
+      PINT     rsvd11_3;
+      PINT     rsvd11_4;
+      PINT     rsvd11_5;
+      PINT     rsvd11_6;
+      PINT     rsvd11_7;
+      PINT     rsvd11_8;
+
+// Group 12 PIE Peripheral Vectors:
+      PINT     rsvd12_1;
+      PINT     rsvd12_2;
+      PINT     rsvd12_3;
+      PINT     rsvd12_4;
+      PINT     rsvd12_5;
+      PINT     rsvd12_6;
+      PINT     rsvd12_7;
+      PINT     rsvd12_8;
+};
+
+//---------------------------------------------------------------------------
+// PIE Interrupt Vector Table External References & Function Declarations:
+//
+extern struct PIE_VECT_TABLE PieVectTable;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif    // end of DSP281x_PIE_VECT_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP281x_SWPrioritizedIsrLevels.h b/Inu/main_matlab/device_support/include/DSP281x_SWPrioritizedIsrLevels.h
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_SWPrioritizedIsrLevels.h
@@ -0,0 +1 @@
+
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Sci.h b/Inu/main_matlab/device_support/include/DSP281x_Sci.h
new file mode 100644
index 0000000..9fd8f02
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Sci.h
@@ -0,0 +1,234 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:19 $
+//###########################################################################
+//
+// FILE:	DSP281x_Sci.h
+//
+// TITLE:	DSP281x Device SCI Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_SCI_H
+#define DSP281x_SCI_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//---------------------------------------------------------------------------
+// SCI Individual Register Bit Definitions
+
+//----------------------------------------------------------
+// SCICCR communication control register bit definitions:
+//
+
+struct  SCICCR_BITS {        // bit    description
+   Uint16 SCICHAR:3;         // 2:0    Character length control        
+   Uint16 ADDRIDLE_MODE:1;   // 3      ADDR/IDLE Mode control
+   Uint16 LOOPBKENA:1;       // 4      Loop Back enable
+   Uint16 PARITYENA:1;       // 5      Parity enable   
+   Uint16 PARITY:1;          // 6      Even or Odd Parity
+   Uint16 STOPBITS:1;        // 7      Number of Stop Bits
+   Uint16 rsvd1:8;           // 15:8   reserved
+}; 
+
+
+union SCICCR_REG {
+   Uint16              all;
+   struct SCICCR_BITS  bit;
+};
+
+//-------------------------------------------
+// SCICTL1 control register 1 bit definitions:
+//
+                       
+struct  SCICTL1_BITS {       // bit    description
+   Uint16 RXENA:1;           // 0      SCI receiver enable
+   Uint16 TXENA:1;           // 1      SCI transmitter enable
+   Uint16 SLEEP:1;           // 2      SCI sleep  
+   Uint16 TXWAKE:1;          // 3      Transmitter wakeup method
+   Uint16 rsvd:1;            // 4      reserved
+   Uint16 SWRESET:1;         // 5      Software reset   
+   Uint16 RXERRINTENA:1;     // 6      Recieve interrupt enable
+   Uint16 rsvd1:9;           // 15:7   reserved
+
+}; 
+
+union SCICTL1_REG {
+   Uint16               all;
+   struct SCICTL1_BITS  bit;
+};
+
+//---------------------------------------------
+// SCICTL2 control register 2 bit definitions:
+// 
+
+struct  SCICTL2_BITS {       // bit    description
+   Uint16 TXINTENA:1;        // 0      Transmit interrupt enable    
+   Uint16 RXBKINTENA:1;      // 1      Receiver-buffer break enable
+   Uint16 rsvd:4;            // 5:2    reserved
+   Uint16 TXEMPTY:1;         // 6      Transmitter empty flag
+   Uint16 TXRDY:1;           // 7      Transmitter ready flag  
+   Uint16 rsvd1:8;           // 15:8   reserved
+
+}; 
+
+union SCICTL2_REG {
+   Uint16               all;
+   struct SCICTL2_BITS  bit;
+};
+
+//---------------------------------------------------
+// SCIRXST Receiver status register bit definitions:
+//
+
+struct  SCIRXST_BITS {       // bit    description
+   Uint16 rsvd:1;            // 0      reserved
+   Uint16 RXWAKE:1;          // 1      Receiver wakeup detect flag
+   Uint16 PE:1;              // 2      Parity error flag
+   Uint16 OE:1;              // 3      Overrun error flag
+   Uint16 FE:1;              // 4      Framing error flag
+   Uint16 BRKDT:1;           // 5      Break-detect flag   
+   Uint16 RXRDY:1;           // 6      Receiver ready flag
+   Uint16 RXERROR:1;         // 7      Receiver error flag
+
+}; 
+
+union SCIRXST_REG {
+   Uint16               all;
+   struct SCIRXST_BITS  bit;
+};
+
+//----------------------------------------------------
+// SCIRXBUF Receiver Data Buffer with FIFO bit definitions:
+// 
+
+struct  SCIRXBUF_BITS {      // bits   description
+   Uint16 RXDT:8;            // 7:0    Receive word
+   Uint16 rsvd:6;            // 13:8   reserved
+   Uint16 SCIFFPE:1;         // 14     SCI PE error in FIFO mode
+   Uint16 SCIFFFE:1;         // 15     SCI FE error in FIFO mode
+};
+
+union SCIRXBUF_REG {
+   Uint16                all;
+   struct SCIRXBUF_BITS  bit;
+};
+
+//--------------------------------------------------
+// SCIPRI Priority control register bit definitions:
+// 
+//
+                                                   
+struct  SCIPRI_BITS {        // bit    description
+   Uint16 rsvd:3;            // 2:0    reserved
+   Uint16 FREE:1;            // 3      Free emulation suspend mode
+   Uint16 SOFT:1;            // 4      Soft emulation suspend mode
+   Uint16 rsvd1:3;           // 7:5    reserved
+}; 
+
+union SCIPRI_REG {
+   Uint16              all;
+   struct SCIPRI_BITS  bit;
+};
+
+//-------------------------------------------------
+// SCI FIFO Transmit register bit definitions:
+// 
+//
+                                                  
+struct  SCIFFTX_BITS {       // bit    description
+   Uint16 TXFFILIL:5;        // 4:0    Interrupt level
+   Uint16 TXFFIENA:1;        // 5      Interrupt enable
+   Uint16 TXINTCLR:1;        // 6      Clear INT flag
+   Uint16 TXFFINT:1;         // 7      INT flag
+   Uint16 TXFFST:5;          // 12:8   FIFO status
+   Uint16 TXFIFOXRESET:1;    // 13     FIFO reset
+   Uint16 SCIFFENA:1;        // 14     Enhancement enable
+   Uint16 SCIRST:1;          // 15     SCI reset rx/tx channels 
+
+}; 
+
+union SCIFFTX_REG {
+   Uint16               all;
+   struct SCIFFTX_BITS  bit;
+};
+
+//------------------------------------------------
+// SCI FIFO recieve register bit definitions:
+// 
+//
+                                               
+struct  SCIFFRX_BITS {       // bits   description
+   Uint16 RXFFIL:5;          // 4:0    Interrupt level
+   Uint16 RXFFIENA:1;        // 5      Interrupt enable
+   Uint16 RXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 RXFFINT:1;         // 7      INT flag
+   Uint16 RXFIFST:5;         // 12:8   FIFO status
+   Uint16 RXFIFORESET:1;     // 13     FIFO reset
+   Uint16 RXFFOVRCLR:1;      // 14     Clear overflow
+   Uint16 RXFFOVF:1;         // 15     FIFO overflow
+
+}; 
+
+union SCIFFRX_REG {
+   Uint16               all;
+   struct SCIFFRX_BITS  bit;
+};
+
+// SCI FIFO control register bit definitions:
+struct  SCIFFCT_BITS {     // bits   description
+   Uint16 FFTXDLY:8;         // 7:0    FIFO transmit delay
+   Uint16 rsvd:5;            // 12:8   reserved
+   Uint16 CDC:1;             // 13     Auto baud mode enable
+   Uint16 ABDCLR:1;          // 14     Auto baud clear
+   Uint16 ABD:1;             // 15     Auto baud detect
+};
+
+union SCIFFCT_REG {
+   Uint16               all;
+   struct SCIFFCT_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// SCI Register File:
+//
+struct  SCI_REGS {
+   union SCICCR_REG     SCICCR;     // Communications control register
+   union SCICTL1_REG    SCICTL1;    // Control register 1
+   Uint16               SCIHBAUD;   // Baud rate (high) register
+   Uint16               SCILBAUD;   // Baud rate (low) register
+   union SCICTL2_REG    SCICTL2;    // Control register 2
+   union SCIRXST_REG    SCIRXST;    // Recieve status register
+   Uint16               SCIRXEMU;   // Recieve emulation buffer register
+   union SCIRXBUF_REG   SCIRXBUF;   // Recieve data buffer  
+   Uint16               rsvd1;      // reserved
+   Uint16               SCITXBUF;   // Transmit data buffer 
+   union SCIFFTX_REG    SCIFFTX;    // FIFO transmit register
+   union SCIFFRX_REG    SCIFFRX;    // FIFO recieve register
+   union SCIFFCT_REG    SCIFFCT;    // FIFO control register
+   Uint16               rsvd2;      // reserved
+   Uint16               rsvd3;      // reserved
+   union SCIPRI_REG     SCIPRI;     // FIFO Priority control   
+};
+
+//---------------------------------------------------------------------------
+// SCI External References & Function Declarations:
+//
+extern struct SCI_REGS SciaRegs;
+extern struct SCI_REGS ScibRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_SCI_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Spi.h b/Inu/main_matlab/device_support/include/DSP281x_Spi.h
new file mode 100644
index 0000000..976188b
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Spi.h
@@ -0,0 +1,184 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:16 $
+//###########################################################################
+//
+// FILE:   DSP281x_Spi.h
+//
+// TITLE:  DSP281x Device SPI Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_SPI_H
+#define DSP281x_SPI_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// SPI Individual Register Bit Definitions:
+//
+// SPI FIFO Transmit register bit    definitions:
+struct  SPIFFTX_BITS {       // bit    description
+   Uint16 TXFFIL:5;          // 4:0    Interrupt level
+   Uint16 TXFFIENA:1;        // 5      Interrupt enable
+   Uint16 TXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 TXFFINT:1;         // 7      INT flag
+   Uint16 TXFFST:5;          // 12:8   FIFO status
+   Uint16 TXFIFO:1;          // 13     FIFO reset
+   Uint16 SPIFFENA:1;        // 14     Enhancement enable
+   Uint16 SPIRST:1;          // 15     Reset SPI
+}; 
+
+union SPIFFTX_REG {
+   Uint16               all;
+   struct SPIFFTX_BITS  bit;
+};
+
+//--------------------------------------------
+// SPI FIFO recieve register bit definitions:
+// 
+//
+struct  SPIFFRX_BITS {       // bits   description
+   Uint16 RXFFIL:5;          // 4:0    Interrupt level
+   Uint16 RXFFIENA:1;        // 5      Interrupt enable
+   Uint16 RXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 RXFFINT:1;         // 7      INT flag
+   Uint16 RXFFST:5;          // 12:8   FIFO status
+   Uint16 RXFIFORESET:1;     // 13     FIFO reset
+   Uint16 RXFFOVFCLR:1;      // 14     Clear overflow
+   Uint16 RXFFOVF:1;         // 15     FIFO overflow
+
+}; 
+
+union SPIFFRX_REG {
+   Uint16               all;
+   struct SPIFFRX_BITS  bit;
+};
+
+//--------------------------------------------
+// SPI FIFO control register bit definitions:
+// 
+//
+struct  SPIFFCT_BITS {       // bits   description
+   Uint16 TXDLY:8;           // 7:0    FIFO transmit delay
+   Uint16 rsvd:8;            // 15:8   reserved
+};
+
+union SPIFFCT_REG {
+   Uint16               all;
+   struct SPIFFCT_BITS  bit;
+};
+   
+//---------------------------------------------
+// SPI configuration register bit definitions:
+// 
+//
+struct  SPICCR_BITS {        // bits   description
+   Uint16 SPICHAR:4;         // 3:0    Character length control
+   Uint16 SPILBK:1;          // 4      Loop-back enable/disable
+   Uint16 rsvd1:1;           // 5      reserved
+   Uint16 CLKPOLARITY:1;     // 6      Clock polarity
+   Uint16 SPISWRESET:1;      // 7      SPI SW Reset
+   Uint16 rsvd2:8;           // 15:8   reserved   
+};
+
+union SPICCR_REG {
+   Uint16              all;
+   struct SPICCR_BITS  bit;
+};
+
+//-------------------------------------------------
+// SPI operation control register bit definitions:
+// 
+//
+struct  SPICTL_BITS {        // bits   description
+   Uint16 SPIINTENA:1;       // 0      Interrupt enable
+   Uint16 TALK:1;            // 1      Master/Slave transmit enable
+   Uint16 MASTER_SLAVE:1;    // 2      Network control mode
+   Uint16 CLK_PHASE:1;       // 3      Clock phase select
+   Uint16 OVERRUNINTENA:1;   // 4      Overrun interrupt enable
+   Uint16 rsvd:11;           // 15:5   reserved      
+};
+
+union SPICTL_REG {
+   Uint16              all;
+   struct SPICTL_BITS  bit;
+};
+
+//--------------------------------------
+// SPI status register bit definitions:
+// 
+//
+struct  SPISTS_BITS {        // bits   description
+   Uint16 rsvd1:5;           // 4:0    reserved
+   Uint16 BUFFULL_FLAG:1;    // 5      SPI transmit buffer full flag
+   Uint16 INT_FLAG:1;        // 6      SPI interrupt flag
+   Uint16 OVERRUN_FLAG:1;    // 7      SPI reciever overrun flag
+   Uint16 rsvd2:8;           // 15:8   reserved   
+};
+
+union SPISTS_REG {
+   Uint16              all;
+   struct SPISTS_BITS  bit;
+}; 
+
+//------------------------------------------------
+// SPI priority control register bit definitions:
+// 
+//
+struct  SPIPRI_BITS {        // bits   description
+   Uint16 rsvd1:4;           // 3:0    reserved
+   Uint16 FREE:1;            // 4      Free emulation mode control
+   Uint16 SOFT:1;            // 5      Soft emulation mode control
+   Uint16 PRIORITY:1;        // 6      Interrupt priority select
+   Uint16 rsvd2:9;           // 15:7   reserved
+};
+
+union SPIPRI_REG {
+   Uint16              all;
+   struct SPIPRI_BITS  bit;
+};       
+
+//---------------------------------------------------------------------------
+// SPI Register File:
+//
+struct  SPI_REGS { 
+   union SPICCR_REG     SPICCR;      // Configuration register 
+   union SPICTL_REG     SPICTL;      // Operation control register
+   union SPISTS_REG     SPISTS;      // Status register
+   Uint16               rsvd1;       // reserved
+   Uint16               SPIBRR;      // Baud Rate
+   Uint16               rsvd2;       // reserved
+   Uint16               SPIRXEMU;    // Emulation buffer
+   Uint16               SPIRXBUF;    // Serial input buffer
+   Uint16               SPITXBUF;    // Serial output buffer
+   Uint16               SPIDAT;      // Serial data 
+   union SPIFFTX_REG    SPIFFTX;     // FIFO transmit register
+   union SPIFFRX_REG    SPIFFRX;     // FIFO recieve register
+   union SPIFFCT_REG    SPIFFCT;     // FIFO control register
+   Uint16               rsvd3[2];    // reserved
+   union SPIPRI_REG     SPIPRI;      // FIFO Priority control
+};
+
+//---------------------------------------------------------------------------
+// SPI External References & Function Declarations:
+//
+extern struct SPI_REGS SpiaRegs;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_SPI_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_SysCtrl.h b/Inu/main_matlab/device_support/include/DSP281x_SysCtrl.h
new file mode 100644
index 0000000..6db875e
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_SysCtrl.h
@@ -0,0 +1,326 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: March 16, 2007   13:58:47 $
+//###########################################################################
+//
+// FILE:   DSP281x_SysCtrl.h
+//
+// TITLE:  DSP281x Device System Control Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_SYS_CTRL_H
+#define DSP281x_SYS_CTRL_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//---------------------------------------------------------------------------
+// System Control Individual Register Bit Definitions:
+//
+// High speed peripheral clock register bit definitions:
+struct HISPCP_BITS  {   // bits  description
+   Uint16 HSPCLK:3;     // 2:0   Rate relative to SYSCLKOUT
+   Uint16 rsvd1:13;     // 15:3  reserved
+};
+
+union HISPCP_REG {
+   Uint16              all;
+   struct HISPCP_BITS  bit;
+};
+
+// Low speed peripheral clock register bit definitions:
+struct LOSPCP_BITS  {   // bits  description
+   Uint16 LSPCLK:3;     // 2:0   Rate relative to SYSCLKOUT
+   Uint16 rsvd1:13;     // 15:3  reserved
+};
+
+union LOSPCP_REG {
+   Uint16              all;
+   struct LOSPCP_BITS  bit;
+};
+
+// Peripheral clock control register bit definitions:
+struct PCLKCR_BITS  {   // bits  description
+   Uint16 EVAENCLK:1;   // 0     Enable high speed clk to EV-A
+   Uint16 EVBENCLK:1;   // 1     Enable high speed clk to EV-B
+   Uint16 rsvd1:1;      // 2
+   Uint16 ADCENCLK:1;   // 3     Enable high speed clk to ADC
+   Uint16 rsvd2:4;      // 7:4   reserved
+   Uint16 SPIENCLK:1;   // 8     Enable low speed clk to SPI
+   Uint16 rsvd3:1;      // 9     reserved
+   Uint16 SCIAENCLK:1;  // 10    Enable low speed clk to SCI-A
+   Uint16 SCIBENCLK:1;  // 11    Enable low speed clk to SCI-B
+   Uint16 MCBSPENCLK:1; // 12    Enable low speed clk to McBSP
+   Uint16 rsvd4:1;      // 13    reserved
+   Uint16 ECANENCLK:1;  // 14    Enable system clk to eCAN
+};
+
+union PCLKCR_REG {
+   Uint16              all;
+   struct PCLKCR_BITS  bit;
+};
+
+// PLL control register bit definitions:
+struct PLLCR_BITS {      // bits  description
+   Uint16 DIV:4;         // 3:0   Set clock ratio for the PLL
+   Uint16 rsvd1:12;      // 15:4  reserved
+};
+
+union PLLCR_REG {
+   Uint16             all;
+   struct PLLCR_BITS  bit;
+};
+
+// Low Power Mode 0 control register bit definitions:
+struct LPMCR0_BITS {     // bits  description
+   Uint16 LPM:2;         // 1:0   Set the low power mode
+   Uint16 QUALSTDBY:6;   // 7:2   Qualification
+   Uint16 rsvd1:8;       // 15:8  reserved
+};
+
+union LPMCR0_REG {
+   Uint16              all;
+   struct LPMCR0_BITS  bit;
+};
+
+// Low Power Mode 1 control register bit definitions:
+struct LPMCR1_BITS {     // bits  description
+   Uint16 XINT1:1;       // 0     Enable XINT1 to wake the device from standby
+   Uint16 XNMI:1;        // 1     Enable XMNI to wake the device from standby
+   Uint16 WDINT:1;       // 2     Enable watchdog interrupt to wake the device from standby
+   Uint16 T1CTRIP:1;     // 3     Enable T1CTRIP to wake the device from standby
+   Uint16 T2CTRIP:1;     // 4     Enable T2CTRIP to wake the device from standby
+   Uint16 T3CTRIP:1;     // 5     Enable T3CTRIP to wake the device from standby
+   Uint16 T4CTRIP:1;     // 6     Enable T4CTRIP to wake the device from standby
+   Uint16 C1TRIP:1;      // 7     Enable C1TRIP to wake the device from standby
+   Uint16 C2TRIP:1;      // 8     Enable C2TRIP to wake the device from standby
+   Uint16 C3TRIP:1;      // 9     Enable C3TRIP to wake the device from standby
+   Uint16 C4TRIP:1;      // 10    Enable C4TRIP to wake the device from standby
+   Uint16 C5TRIP:1;      // 11    Enable C5TRIP to wake the device from standby
+   Uint16 C6TRIP:1;      // 12    Enable C6TRIP to wake the device from standby
+   Uint16 SCIRXA:1;      // 13    Enable SCIRXA to wake the device from standby
+   Uint16 SCIRXB:1;      // 14    Enable SCIRXB to wake the device from standby
+   Uint16 CANRX:1;       // 15    Enable CANRX to wake the device from standby
+};
+
+union LPMCR1_REG {
+   Uint16              all;
+   struct LPMCR1_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// System Control Register File:
+//
+struct SYS_CTRL_REGS {
+   Uint16  rsvd1[10];            // 0-9
+   union   HISPCP_REG HISPCP;    // 10: High-speed peripheral clock pre-scaler
+   union   LOSPCP_REG LOSPCP;    // 11: Low-speed peripheral clock pre-scaler
+   union   PCLKCR_REG PCLKCR;    // 12: Peripheral clock control register
+   Uint16             rsvd2;     // 13: reserved
+   union   LPMCR0_REG LPMCR0;    // 14: Low-power mode control register 0
+   union   LPMCR1_REG LPMCR1;    // 15: Low-power mode control register 1
+   Uint16             rsvd3;     // 16: reserved
+   union   PLLCR_REG  PLLCR;     // 17: PLL control register
+   // No bit definitions are defined for SCSR because
+   // a read-modify-write instruction can clear the WDOVERRIDE bit
+   Uint16             SCSR;      // 18: System control and status register
+   Uint16             WDCNTR;    // 19: WD counter register
+   Uint16             rsvd4;     // 20
+   Uint16             WDKEY;     // 21: WD reset key register
+   Uint16             rsvd5[3];  // 22-24
+   // No bit definitions are defined for WDCR because
+   // the proper value must be written to the WDCHK field
+   // whenever writing to this register.
+   Uint16             WDCR;      // 25: WD timer control register
+   Uint16             rsvd6[6];  // 26-31
+};
+
+
+/* --------------------------------------------------- */
+/* CSM Registers                                       */
+/*                                                     */
+/* ----------------------------------------------------*/
+
+/* CSM Status & Control register bit definitions */
+struct  CSMSCR_BITS {      // bit   description
+   Uint16     SECURE:1;    // 0     Secure flag
+   Uint16     rsvd1:14;    // 14-1  reserved
+   Uint16     FORCESEC:1;  // 15    Force Secure control bit
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CSMSCR_REG {
+   Uint16             all;
+   struct CSMSCR_BITS bit;
+};
+
+/* CSM Register File */
+struct  CSM_REGS {
+   Uint16           KEY0;    // KEY reg bits 15-0
+   Uint16           KEY1;    // KEY reg bits 31-16
+   Uint16           KEY2;    // KEY reg bits 47-32
+   Uint16           KEY3;    // KEY reg bits 63-48
+   Uint16           KEY4;    // KEY reg bits 79-64
+   Uint16           KEY5;    // KEY reg bits 95-80
+   Uint16           KEY6;    // KEY reg bits 111-96
+   Uint16           KEY7;    // KEY reg bits 127-112
+   Uint16           rsvd1;   // reserved
+   Uint16           rsvd2;   // reserved
+   Uint16           rsvd3;   // reserved
+   Uint16           rsvd4;   // reserved
+   Uint16           rsvd5;   // reserved
+   Uint16           rsvd6;   // reserved
+   Uint16           rsvd7;   // reserved
+   union CSMSCR_REG CSMSCR;  // CSM Status & Control register
+};
+
+/* Password locations */
+struct  CSM_PWL {
+   Uint16   PSWD0;  // PSWD bits 15-0
+   Uint16   PSWD1;  // PSWD bits 31-16
+   Uint16   PSWD2;  // PSWD bits 47-32
+   Uint16   PSWD3;  // PSWD bits 63-48
+   Uint16   PSWD4;  // PSWD bits 79-64
+   Uint16   PSWD5;  // PSWD bits 95-80
+   Uint16   PSWD6;  // PSWD bits 111-96
+   Uint16   PSWD7;  // PSWD bits 127-112
+};
+
+
+
+/* Flash Registers */
+
+#define FLASH_SLEEP   0x0000;
+#define FLASH_STANDBY 0x0001;
+#define FLASH_ACTIVE  0x0003;
+
+
+/* Flash Option Register bit definitions */
+struct  FOPT_BITS {       // bit   description
+   Uint16     ENPIPE:1;   // 0     Enable Pipeline Mode
+   Uint16     rsvd:15;    // 1-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FOPT_REG {
+   Uint16           all;
+   struct FOPT_BITS bit;
+};
+
+/* Flash Power Modes Register bit definitions */
+struct  FPWR_BITS {       // bit   description
+   Uint16     PWR:2;      // 0-1   Power Mode bits
+   Uint16     rsvd:14;    // 2-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FPWR_REG {
+   Uint16           all;
+   struct FPWR_BITS bit;
+};
+
+
+/* Flash Status Register bit definitions */
+struct  FSTATUS_BITS {       // bit   description
+   Uint16     PWRS:2;        // 0-1   Power Mode Status bits
+   Uint16     STDBYWAITS:1;  // 2     Bank/Pump Sleep to Standby Wait Counter Status bits
+   Uint16     ACTIVEWAITS:1; // 3     Bank/Pump Standby to Active Wait Counter Status bits
+   Uint16     rsvd1:4;       // 4-7   reserved
+   Uint16     V3STAT:1;      // 8     VDD3V Status Latch bit
+   Uint16     rsvd2:7;       // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FSTATUS_REG {
+   Uint16              all;
+   struct FSTATUS_BITS bit;
+};
+
+/* Flash Sleep to Standby Wait Counter Register bit definitions */
+struct  FSTDBYWAIT_BITS {    // bit   description
+   Uint16     STDBYWAIT:9;   // 0-8   Bank/Pump Sleep to Standby Wait Count bits
+   Uint16     rsvd:7;        // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FSTDBYWAIT_REG {
+   Uint16                 all;
+   struct FSTDBYWAIT_BITS bit;
+};
+
+/* Flash Standby to Active Wait Counter Register bit definitions */
+struct  FACTIVEWAIT_BITS {   // bit   description
+   Uint16     ACTIVEWAIT:9;  // 0-8   Bank/Pump Standby to Active Wait Count bits
+   Uint16     rsvd:7;        // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FACTIVEWAIT_REG {
+   Uint16                  all;
+   struct FACTIVEWAIT_BITS bit;
+};
+
+/* Bank Read Access Wait State Register bit definitions */
+struct  FBANKWAIT_BITS {     // bit   description
+   Uint16     RANDWAIT:4;    // 0-3   Flash Random Read Wait State bits
+   Uint16     rsvd1:4;       // 4-7   reserved
+   Uint16     PAGEWAIT:4;    // 8-11  Flash Paged Read Wait State bits
+   Uint16     rsvd2:4;       // 12-15 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FBANKWAIT_REG {
+   Uint16                all;
+   struct FBANKWAIT_BITS bit;
+};
+
+/* OTP Read Access Wait State Register bit definitions */
+struct  FOTPWAIT_BITS {      // bit   description
+   Uint16     OTPWAIT:5;     // 0-4   OTP Read Wait State bits
+   Uint16     rsvd:11;       // 5-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FOTPWAIT_REG {
+   Uint16               all;
+   struct FOTPWAIT_BITS bit;
+};
+
+
+struct FLASH_REGS {
+   union FOPT_REG        FOPT;        // Option Register
+   Uint16                rsvd1;       // reserved
+   union FPWR_REG        FPWR;        // Power Modes Register
+   union FSTATUS_REG     FSTATUS;     // Status Register
+   union FSTDBYWAIT_REG  FSTDBYWAIT;  // Pump/Bank Sleep to Standby Wait State Register
+   union FACTIVEWAIT_REG FACTIVEWAIT; // Pump/Bank Standby to Active Wait State Register
+   union FBANKWAIT_REG   FBANKWAIT;   // Bank Read Access Wait State Register
+   union FOTPWAIT_REG    FOTPWAIT;    // OTP Read Access Wait State Register
+};
+
+//---------------------------------------------------------------------------
+// System Control External References & Function Declarations:
+//
+extern struct SYS_CTRL_REGS SysCtrlRegs;
+extern struct CSM_REGS CsmRegs;
+extern struct CSM_PWL CsmPwl;
+extern struct FLASH_REGS FlashRegs;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_SYS_CTRL_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_XIntrupt.h b/Inu/main_matlab/device_support/include/DSP281x_XIntrupt.h
new file mode 100644
index 0000000..b25ad8f
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_XIntrupt.h
@@ -0,0 +1,79 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: April 28, 2005   14:57:07 $
+//###########################################################################
+//
+// FILE:  DSP281x_XIntrupt.h
+//
+// TITLE: DSP281x Device External Interrupt Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_XINTRUPT_H
+#define DSP281x_XINTRUPT_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//---------------------------------------------------------------------------
+
+struct XINTCR_BITS {
+    Uint16   ENABLE:1;    // 0      enable/disable
+    Uint16   rsvd1:1;     // 1      reserved
+    Uint16   POLARITY:1;  // 2      pos/neg triggered
+    Uint16   rsvd2:12;    // 15:3   reserved
+};
+
+union XINTCR_REG {
+   Uint16               all;
+   struct XINTCR_BITS   bit;
+};  
+
+struct XNMICR_BITS {
+    Uint16   ENABLE:1;    // 0      enable/disable
+    Uint16   SELECT:1;    // 1      Timer 1 or XNMI connected to INT13
+    Uint16   POLARITY:1;  // 2      pos/neg triggered
+    Uint16   rsvd2:12;    // 15:3   reserved
+};
+
+union XNMICR_REG {
+   Uint16               all;
+   struct XNMICR_BITS   bit;
+};  
+
+
+
+
+//---------------------------------------------------------------------------
+// External Interrupt Register File:
+//
+struct XINTRUPT_REGS {
+   union XINTCR_REG XINT1CR;
+   union XINTCR_REG XINT2CR;
+   Uint16 rsvd1[5];
+   union XNMICR_REG XNMICR;
+   Uint16 XINT1CTR;
+   Uint16 XINT2CTR;
+   Uint16 rsvd[5];
+   Uint16 XNMICTR;
+};
+
+//---------------------------------------------------------------------------
+// External Interrupt References & Function Declarations:
+//
+extern struct XINTRUPT_REGS XIntruptRegs;
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_XINTF_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP281x_Xintf.h b/Inu/main_matlab/device_support/include/DSP281x_Xintf.h
new file mode 100644
index 0000000..73816f6
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP281x_Xintf.h
@@ -0,0 +1,112 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: March 20, 2007   16:30:14 $
+//###########################################################################
+//
+// FILE:   DSP281x_Xintf.h
+//
+// TITLE:  DSP281x Device External Interface Register Definitions.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP281x_XINTF_H
+#define DSP281x_XINTF_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+// XINTF timing register bit definitions:
+struct XTIMING_BITS {    // bits  description
+   Uint16 XWRTRAIL:2;    // 1:0   Write access trail timing
+   Uint16 XWRACTIVE:3;   // 4:2   Write access active timing
+   Uint16 XWRLEAD:2;     // 6:5   Write access lead timing
+   Uint16 XRDTRAIL:2;    // 8:7   Read access trail timing
+   Uint16 XRDACTIVE:3;   // 11:9  Read access active timing
+   Uint16 XRDLEAD:2;     // 13:12 Read access lead timing
+   Uint16 USEREADY:1;    // 14    Extend access using HW waitstates
+   Uint16 READYMODE:1;   // 15    Ready mode
+   Uint16 XSIZE:2;       // 17:16 XINTF bus width - must be written as 11b
+   Uint16 rsvd1:4;       // 21:18 reserved
+   Uint16 X2TIMING:1;    // 22    Double lead/active/trail timing
+   Uint16 rsvd3:9;       // 31:23 reserved
+};
+
+union XTIMING_REG {
+   Uint32               all;
+   struct XTIMING_BITS  bit;
+};
+
+// XINTF control register bit definitions:
+struct XINTCNF2_BITS {    // bits  description
+   Uint16 WRBUFF:2;       // 1:0   Write buffer depth
+   Uint16 CLKMODE:1;      // 2     Ratio for XCLKOUT with respect to XTIMCLK
+   Uint16 CLKOFF:1;       // 3     Disable XCLKOUT
+   Uint16 rsvd1:2;        // 5:4   reserved
+   Uint16 WLEVEL:2;       // 7:6   Current level of the write buffer
+   Uint16 MPNMC:1;        // 8     Micro-processor/micro-computer mode
+   Uint16 HOLD:1;         // 9     Hold enable/disable
+   Uint16 HOLDS:1;        // 10    Current state of HOLDn input
+   Uint16 HOLDAS:1;       // 11    Current state of HOLDAn output
+   Uint16 rsvd2:4;        // 15:12 reserved
+   Uint16 XTIMCLK:3;      // 18:16 Ratio for XTIMCLK
+   Uint16 rsvd3:13;       // 31:19 reserved
+};
+
+union XINTCNF2_REG {
+   Uint32                all;
+   struct XINTCNF2_BITS  bit;
+};
+
+// XINTF bank switching register bit definitions:
+struct XBANK_BITS {      // bits  description
+   Uint16  BANK:3;       // 2:0   Zone for which banking is enabled
+   Uint16  BCYC:3;       // 5:3   XTIMCLK cycles to add
+   Uint16  rsvd:10;      // 15:6  reserved
+};
+
+union XBANK_REG {
+   Uint16             all;
+   struct XBANK_BITS  bit;
+};
+
+
+//---------------------------------------------------------------------------
+// XINTF Register File:
+//
+struct XINTF_REGS {
+   union XTIMING_REG XTIMING0;
+   union XTIMING_REG XTIMING1;
+   union XTIMING_REG XTIMING2;
+   Uint32  rsvd1[3];
+   union XTIMING_REG XTIMING6;
+   union XTIMING_REG XTIMING7;
+   Uint32  rsvd2[2];
+   union XINTCNF2_REG XINTCNF2;
+   Uint32  rsvd3;
+   union XBANK_REG    XBANK;
+   Uint16  rsvd4;
+   Uint16  XREVISION;
+   Uint16  rsvd5[5];
+};
+
+//---------------------------------------------------------------------------
+// XINTF External References & Function Declarations:
+//
+extern struct XINTF_REGS XintfRegs;
+
+
+#ifdef __cplusplus
+}
+#endif /* extern "C" */
+
+#endif  // end of DSP281x_XINTF_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Adc.h b/Inu/main_matlab/device_support/include/DSP2833x_Adc.h
new file mode 100644
index 0000000..cf4f7fd
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Adc.h
@@ -0,0 +1,258 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:51:50 $
+//###########################################################################
+//
+// FILE:   DSP2833x_Adc.h
+//
+// TITLE:  DSP2833x Device ADC Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_ADC_H
+#define DSP2833x_ADC_H
+
+
+
+//---------------------------------------------------------------------------
+// ADC Individual Register Bit Definitions:
+
+struct ADCTRL1_BITS {     // bits  description
+    Uint16  rsvd1:4;      // 3:0   reserved
+    Uint16  SEQ_CASC:1;   // 4     Cascaded sequencer mode
+    Uint16  SEQ_OVRD:1;   // 5     Sequencer override 
+    Uint16  CONT_RUN:1;   // 6     Continuous run
+    Uint16  CPS:1;        // 7     ADC core clock pre-scalar
+    Uint16  ACQ_PS:4;     // 11:8  Acquisition window size
+    Uint16  SUSMOD:2;     // 13:12 Emulation suspend mode
+    Uint16  RESET:1;      // 14    ADC reset
+    Uint16  rsvd2:1;      // 15    reserved
+};
+
+
+union ADCTRL1_REG {
+   Uint16                all;
+   struct ADCTRL1_BITS   bit;
+};
+
+
+struct ADCTRL2_BITS {         // bits  description
+    Uint16  EPWM_SOCB_SEQ2:1; // 0     EPWM compare B SOC mask for SEQ2
+    Uint16  rsvd1:1;          // 1     reserved
+    Uint16  INT_MOD_SEQ2:1;   // 2     SEQ2 Interrupt mode
+    Uint16  INT_ENA_SEQ2:1;   // 3     SEQ2 Interrupt enable
+    Uint16  rsvd2:1;          // 4     reserved
+    Uint16  SOC_SEQ2:1;       // 5     Start of conversion for SEQ2
+    Uint16  RST_SEQ2:1;       // 6     Reset SEQ2
+    Uint16  EXT_SOC_SEQ1:1;   // 7     External start of conversion for SEQ1
+    Uint16  EPWM_SOCA_SEQ1:1; // 8     EPWM compare B SOC mask for SEQ1
+    Uint16  rsvd3:1;          // 9     reserved
+    Uint16  INT_MOD_SEQ1:1;   // 10    SEQ1 Interrupt mode
+    Uint16  INT_ENA_SEQ1:1;   // 11    SEQ1 Interrupt enable
+    Uint16  rsvd4:1;          // 12    reserved
+    Uint16  SOC_SEQ1:1;       // 13    Start of conversion trigger for SEQ1
+    Uint16  RST_SEQ1:1;       // 14    Restart sequencer 1   
+    Uint16  EPWM_SOCB_SEQ:1;  // 15    EPWM compare B SOC enable
+};
+
+
+union ADCTRL2_REG {
+   Uint16                all;
+   struct ADCTRL2_BITS   bit;
+};
+
+
+struct ADCASEQSR_BITS {       // bits   description
+    Uint16  SEQ1_STATE:4;     // 3:0    SEQ1 state
+    Uint16  SEQ2_STATE:3;     // 6:4    SEQ2 state
+    Uint16  rsvd1:1;          // 7      reserved
+    Uint16  SEQ_CNTR:4;       // 11:8   Sequencing counter status 
+    Uint16  rsvd2:4;          // 15:12  reserved  
+};
+
+union ADCASEQSR_REG {
+   Uint16                 all;
+   struct ADCASEQSR_BITS  bit;
+};
+
+
+struct ADCMAXCONV_BITS {      // bits  description
+    Uint16  MAX_CONV1:4;      // 3:0   Max number of conversions
+    Uint16  MAX_CONV2:3;      // 6:4   Max number of conversions    
+    Uint16  rsvd1:9;          // 15:7  reserved 
+};
+
+union ADCMAXCONV_REG {
+   Uint16                  all;
+   struct ADCMAXCONV_BITS  bit;
+};
+
+
+struct ADCCHSELSEQ1_BITS {    // bits   description
+    Uint16  CONV00:4;         // 3:0    Conversion selection 00
+    Uint16  CONV01:4;         // 7:4    Conversion selection 01
+    Uint16  CONV02:4;         // 11:8   Conversion selection 02
+    Uint16  CONV03:4;         // 15:12  Conversion selection 03
+};
+
+union  ADCCHSELSEQ1_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ1_BITS  bit;
+};
+
+struct ADCCHSELSEQ2_BITS {    // bits   description
+    Uint16  CONV04:4;         // 3:0    Conversion selection 04
+    Uint16  CONV05:4;         // 7:4    Conversion selection 05
+    Uint16  CONV06:4;         // 11:8   Conversion selection 06
+    Uint16  CONV07:4;         // 15:12  Conversion selection 07
+};
+
+union  ADCCHSELSEQ2_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ2_BITS  bit;
+};
+
+struct ADCCHSELSEQ3_BITS {    // bits   description
+    Uint16  CONV08:4;         // 3:0    Conversion selection 08
+    Uint16  CONV09:4;         // 7:4    Conversion selection 09
+    Uint16  CONV10:4;         // 11:8   Conversion selection 10
+    Uint16  CONV11:4;         // 15:12  Conversion selection 11
+};
+
+union  ADCCHSELSEQ3_REG{
+   Uint16                    all;
+   struct ADCCHSELSEQ3_BITS  bit;
+};
+
+struct ADCCHSELSEQ4_BITS {    // bits   description
+    Uint16  CONV12:4;         // 3:0    Conversion selection 12
+    Uint16  CONV13:4;         // 7:4    Conversion selection 13
+    Uint16  CONV14:4;         // 11:8   Conversion selection 14
+    Uint16  CONV15:4;         // 15:12  Conversion selection 15
+};
+
+union  ADCCHSELSEQ4_REG {
+   Uint16                    all;
+   struct ADCCHSELSEQ4_BITS  bit;
+};
+
+struct ADCTRL3_BITS {         // bits   description
+    Uint16   SMODE_SEL:1;     // 0      Sampling mode select
+    Uint16   ADCCLKPS:4;      // 4:1    ADC core clock divider
+    Uint16   ADCPWDN:1;       // 5      ADC powerdown
+    Uint16   ADCBGRFDN:2;     // 7:6    ADC bandgap/ref power down
+    Uint16   rsvd1:8;         // 15:8   reserved
+}; 
+
+union  ADCTRL3_REG {
+   Uint16                all;
+   struct ADCTRL3_BITS   bit;
+};
+
+
+struct ADCST_BITS {           // bits   description
+    Uint16   INT_SEQ1:1;      // 0      SEQ1 Interrupt flag  
+    Uint16   INT_SEQ2:1;      // 1      SEQ2 Interrupt flag
+    Uint16   SEQ1_BSY:1;      // 2      SEQ1 busy status
+    Uint16   SEQ2_BSY:1;      // 3      SEQ2 busy status
+    Uint16   INT_SEQ1_CLR:1;  // 4      SEQ1 Interrupt clear
+    Uint16   INT_SEQ2_CLR:1;  // 5      SEQ2 Interrupt clear
+    Uint16   EOS_BUF1:1;      // 6      End of sequence buffer1
+    Uint16   EOS_BUF2:1;      // 7      End of sequence buffer2
+    Uint16   rsvd1:8;         // 15:8   reserved
+};
+
+                             
+union  ADCST_REG {            
+   Uint16             all;    
+   struct ADCST_BITS  bit;    
+};                           
+
+struct ADCREFSEL_BITS {       // bits   description
+	Uint16   rsvd1:14;        // 13:0   reserved  
+	Uint16   REF_SEL:2;       // 15:14  Reference select
+};
+union ADCREFSEL_REG {
+	Uint16		all;
+	struct ADCREFSEL_BITS bit;
+};
+
+struct ADCOFFTRIM_BITS{       // bits   description
+	int16	OFFSET_TRIM:9;    // 8:0    Offset Trim  
+	Uint16	rsvd1:7;          // 15:9   reserved
+};
+
+union ADCOFFTRIM_REG{
+	Uint16		all;
+	struct ADCOFFTRIM_BITS bit;
+};
+struct ADC_REGS {
+    union ADCTRL1_REG      ADCTRL1;       // ADC Control 1
+    union ADCTRL2_REG      ADCTRL2;       // ADC Control 2
+    union ADCMAXCONV_REG   ADCMAXCONV;    // Max conversions
+    union ADCCHSELSEQ1_REG ADCCHSELSEQ1;  // Channel select sequencing control 1
+    union ADCCHSELSEQ2_REG ADCCHSELSEQ2;  // Channel select sequencing control 2
+    union ADCCHSELSEQ3_REG ADCCHSELSEQ3;  // Channel select sequencing control 3
+    union ADCCHSELSEQ4_REG ADCCHSELSEQ4;  // Channel select sequencing control 4
+    union ADCASEQSR_REG    ADCASEQSR;     // Autosequence status register
+    Uint16                 ADCRESULT0;    // Conversion Result Buffer 0
+    Uint16                 ADCRESULT1;    // Conversion Result Buffer 1
+    Uint16                 ADCRESULT2;    // Conversion Result Buffer 2
+    Uint16                 ADCRESULT3;    // Conversion Result Buffer 3
+    Uint16                 ADCRESULT4;    // Conversion Result Buffer 4
+    Uint16                 ADCRESULT5;    // Conversion Result Buffer 5
+    Uint16                 ADCRESULT6;    // Conversion Result Buffer 6
+    Uint16                 ADCRESULT7;    // Conversion Result Buffer 7
+    Uint16                 ADCRESULT8;    // Conversion Result Buffer 8
+    Uint16                 ADCRESULT9;    // Conversion Result Buffer 9
+    Uint16                 ADCRESULT10;   // Conversion Result Buffer 10
+    Uint16                 ADCRESULT11;   // Conversion Result Buffer 11
+    Uint16                 ADCRESULT12;   // Conversion Result Buffer 12
+    Uint16                 ADCRESULT13;   // Conversion Result Buffer 13
+    Uint16                 ADCRESULT14;   // Conversion Result Buffer 14
+    Uint16                 ADCRESULT15;   // Conversion Result Buffer 15
+    union ADCTRL3_REG      ADCTRL3;       // ADC Control 3  
+    union ADCST_REG        ADCST;         // ADC Status Register
+    Uint16				   rsvd1;
+    Uint16                 rsvd2;
+    union ADCREFSEL_REG    ADCREFSEL;     // Reference Select Register
+    union ADCOFFTRIM_REG   ADCOFFTRIM;    // Offset Trim Register
+};
+
+
+struct ADC_RESULT_MIRROR_REGS
+{
+    Uint16                 ADCRESULT0;    // Conversion Result Buffer 0
+    Uint16                 ADCRESULT1;    // Conversion Result Buffer 1
+    Uint16                 ADCRESULT2;    // Conversion Result Buffer 2
+    Uint16                 ADCRESULT3;    // Conversion Result Buffer 3
+    Uint16                 ADCRESULT4;    // Conversion Result Buffer 4
+    Uint16                 ADCRESULT5;    // Conversion Result Buffer 5
+    Uint16                 ADCRESULT6;    // Conversion Result Buffer 6
+    Uint16                 ADCRESULT7;    // Conversion Result Buffer 7
+    Uint16                 ADCRESULT8;    // Conversion Result Buffer 8
+    Uint16                 ADCRESULT9;    // Conversion Result Buffer 9
+    Uint16                 ADCRESULT10;   // Conversion Result Buffer 10
+    Uint16                 ADCRESULT11;   // Conversion Result Buffer 11
+    Uint16                 ADCRESULT12;   // Conversion Result Buffer 12
+    Uint16                 ADCRESULT13;   // Conversion Result Buffer 13
+    Uint16                 ADCRESULT14;   // Conversion Result Buffer 14
+    Uint16                 ADCRESULT15;   // Conversion Result Buffer 15
+};
+
+//---------------------------------------------------------------------------
+// ADC External References & Function Declarations:
+//
+extern struct ADC_REGS AdcRegs;
+extern struct ADC_RESULT_MIRROR_REGS AdcMirror;
+
+
+
+#endif  // end of DSP2833x_ADC_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_CpuTimers.h b/Inu/main_matlab/device_support/include/DSP2833x_CpuTimers.h
new file mode 100644
index 0000000..e79ea52
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_CpuTimers.h
@@ -0,0 +1,184 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: March 20, 2007   15:33:42 $
+//###########################################################################
+//
+// FILE:    DSP2833x_CpuTimers.h
+//
+// TITLE:   DSP2833x CPU 32-bit Timers Register Definitions.
+//
+// NOTES:   CpuTimer1 and CpuTimer2 are reserved for use with DSP BIOS and
+//          other realtime operating systems.
+//
+//          Do not use these two timers in your application if you ever plan
+//          on integrating DSP-BIOS or another realtime OS.
+//
+//          For this reason, comment out the code to manipulate these two timers
+//          if using DSP-BIOS or another realtime OS.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_CPU_TIMERS_H
+#define DSP2833x_CPU_TIMERS_H
+
+
+//---------------------------------------------------------------------------
+// CPU Timer Register Bit Definitions:
+//
+//
+// TCR: Control register bit definitions:
+struct  TCR_BITS {          // bits  description
+   Uint16    rsvd1:4;       // 3:0   reserved
+   Uint16    TSS:1;         // 4     Timer Start/Stop
+   Uint16    TRB:1;         // 5     Timer reload
+   Uint16    rsvd2:4;       // 9:6   reserved
+   Uint16    SOFT:1;        // 10    Emulation modes
+   Uint16    FREE:1;        // 11
+   Uint16    rsvd3:2;       // 12:13 reserved
+   Uint16    TIE:1;         // 14    Output enable
+   Uint16    TIF:1;         // 15    Interrupt flag
+};
+
+union TCR_REG {
+   Uint16           all;
+   struct TCR_BITS  bit;
+};
+
+// TPR: Pre-scale low bit definitions:
+struct  TPR_BITS {        // bits  description
+   Uint16     TDDR:8;     // 7:0   Divide-down low
+   Uint16     PSC:8;      // 15:8  Prescale counter low
+};
+
+union TPR_REG {
+   Uint16           all;
+   struct TPR_BITS  bit;
+};
+
+// TPRH: Pre-scale high bit definitions:
+struct  TPRH_BITS {       // bits  description
+   Uint16     TDDRH:8;      // 7:0   Divide-down high
+   Uint16     PSCH:8;       // 15:8  Prescale counter high
+};
+
+union TPRH_REG {
+   Uint16           all;
+   struct TPRH_BITS bit;
+};
+
+// TIM, TIMH: Timer register definitions:
+struct TIM_REG {
+   Uint16  LSW;
+   Uint16  MSW;
+};
+
+union TIM_GROUP {
+   Uint32          all;
+   struct TIM_REG  half;
+};
+
+// PRD, PRDH: Period register definitions:
+struct PRD_REG {
+   Uint16  LSW;
+   Uint16  MSW;
+};
+
+union PRD_GROUP {
+   Uint32          all;
+   struct PRD_REG  half;
+};
+
+//---------------------------------------------------------------------------
+// CPU Timer Register File:
+//
+struct CPUTIMER_REGS {
+   union TIM_GROUP TIM;   // Timer counter register
+   union PRD_GROUP PRD;   // Period register
+   union TCR_REG   TCR;   // Timer control register
+   Uint16          rsvd1; // reserved
+   union TPR_REG   TPR;   // Timer pre-scale low
+   union TPRH_REG  TPRH;  // Timer pre-scale high
+};
+
+//---------------------------------------------------------------------------
+// CPU Timer Support Variables:
+//
+struct CPUTIMER_VARS {
+   struct  CPUTIMER_REGS  *RegsAddr;
+   Uint32    InterruptCount;
+   float   CPUFreqInMHz;
+   float   PeriodInUSec;
+};
+
+//---------------------------------------------------------------------------
+// Function prototypes and external definitions:
+//
+void InitCpuTimers(void);
+void ConfigCpuTimer(struct CPUTIMER_VARS *Timer, float Freq, float Period);
+
+extern struct CPUTIMER_REGS CpuTimer0Regs;
+extern struct CPUTIMER_VARS CpuTimer0;
+
+// CpuTimer 1 and CpuTimer2 are reserved for DSP BIOS & other RTOS. Comment out CpuTimer1 and CpuTimer2 if using DSP BIOS or other RTOS
+extern struct CPUTIMER_REGS CpuTimer1Regs;
+extern struct CPUTIMER_REGS CpuTimer2Regs;
+
+extern struct CPUTIMER_VARS CpuTimer1;
+extern struct CPUTIMER_VARS CpuTimer2;
+
+//---------------------------------------------------------------------------
+// Usefull Timer Operations:
+//
+// Start Timer:
+#define StartCpuTimer0()   CpuTimer0Regs.TCR.bit.TSS = 0
+
+// Stop Timer:
+#define StopCpuTimer0()   CpuTimer0Regs.TCR.bit.TSS = 1
+
+// Reload Timer With period Value:
+#define ReloadCpuTimer0() CpuTimer0Regs.TCR.bit.TRB = 1
+
+// Read 32-Bit Timer Value:
+#define ReadCpuTimer0Counter() CpuTimer0Regs.TIM.all
+
+// Read 32-Bit Period Value:
+#define ReadCpuTimer0Period() CpuTimer0Regs.PRD.all
+
+// CpuTimer 1 and CpuTimer2 are reserved for DSP BIOS & other RTOS
+// Do not use these two timers if you ever plan on integrating
+// DSP-BIOS or another realtime OS.
+//
+// For this reason, comment out the code to manipulate these two timers
+// if using DSP-BIOS or another realtime OS.
+
+// Start Timer:
+#define StartCpuTimer1()   CpuTimer1Regs.TCR.bit.TSS = 0
+#define StartCpuTimer2()   CpuTimer2Regs.TCR.bit.TSS = 0
+
+
+// Stop Timer:
+#define StopCpuTimer1()   CpuTimer1Regs.TCR.bit.TSS = 1
+#define StopCpuTimer2()   CpuTimer2Regs.TCR.bit.TSS = 1
+
+// Reload Timer With period Value:
+#define ReloadCpuTimer1() CpuTimer1Regs.TCR.bit.TRB = 1
+#define ReloadCpuTimer2() CpuTimer2Regs.TCR.bit.TRB = 1
+
+// Read 32-Bit Timer Value:
+#define ReadCpuTimer1Counter() CpuTimer1Regs.TIM.all
+#define ReadCpuTimer2Counter() CpuTimer2Regs.TIM.all
+
+// Read 32-Bit Period Value:
+#define ReadCpuTimer1Period() CpuTimer1Regs.PRD.all
+#define ReadCpuTimer2Period() CpuTimer2Regs.PRD.all
+
+
+#endif  // end of DSP2833x_CPU_TIMERS_H definition
+
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_DMA.h b/Inu/main_matlab/device_support/include/DSP2833x_DMA.h
new file mode 100644
index 0000000..e253eb9
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_DMA.h
@@ -0,0 +1,290 @@
+// TI File $Revision: /main/11 $
+// Checkin $Date: June 23, 2008   11:34:15 $
+//###########################################################################
+//
+// FILE:   DSP2833x_DMA.h
+//
+// TITLE:  DSP2833x DMA Module Register Bit Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_DMA_H
+#define DSP2833x_DMA_H
+
+
+
+//----------------------------------------------------
+// Channel MODE register bit definitions:
+struct MODE_BITS {           // bits   description
+   Uint16 PERINTSEL:5;       // 4:0    Peripheral Interrupt and Sync Select Bits (R/W):
+                             //        0     no interrupt
+							 //        1     SEQ1INT & ADCSYNC
+                             //        2     SEQ2INT
+							 //        3     XINT1
+							 //        4     XINT2
+							 //        5     XINT3
+							 //        6     XINT4
+							 //        7     XINT5
+							 //        8     XINT6
+							 //        9     XINT7
+							 //        10    XINT13
+							 //        11    TINT0
+							 //        12    TINT1
+							 //        13    TINT2
+							 //        14    MXEVTA & MXSYNCA
+							 //        15    MREVTA & MRSYNCA
+							 //        16    MXEVTB & MXSYNCB
+							 //        17    MREVTB & MRSYNCB
+	                         //        18    ePWM1SOCA
+	                         //        19    ePWM1SOCB
+	                         //        20    ePWM2SOCA
+	                         //        21    ePWM2SOCB
+	                         //        22    ePWM3SOCA
+	                         //        23    ePWM3SOCB
+	                         //        24    ePWM4SOCA
+	                         //        25    ePWM4SOCB
+	                         //        26    ePWM5SOCA
+	                         //        27    ePWM5SOCB
+	                         //        28    ePWM6SOCA
+	                         //        29    ePWM6SOCB
+	                         //        30:31 no interrupt
+   Uint16 rsvd1:2;           // 6:5    (R=0:0)
+   Uint16 OVRINTE:1;         // 7      Overflow Interrupt Enable (R/W):
+                             //        0     overflow interrupt disabled
+                             //        1     overflow interrupt enabled
+   Uint16 PERINTE:1;         // 8      Peripheral Interrupt Enable Bit (R/W):
+                             //        0     peripheral interrupt disabled
+                             //        1     peripheral interrupt enabled
+   Uint16 CHINTMODE:1;       // 9      Channel Interrupt Mode Bit (R/W):
+                             //        0     generate interrupt at beginning of new transfer
+                             //        1     generate interrupt at end of transfer
+   Uint16 ONESHOT:1;         // 10     One Shot Mode Bit (R/W):
+                             //        0     only interrupt event triggers single burst transfer
+                             //        1     first interrupt triggers burst, continue until transfer count is zero
+   Uint16 CONTINUOUS:1;      // 11     Continous Mode Bit (R/W):
+                             //        0     stop when transfer count is zero
+                             //        1     re-initialize when transfer count is zero
+   Uint16 SYNCE:1;           // 12     Sync Enable Bit (R/W):
+                             //        0     ignore selected interrupt sync signal
+                             //        1     enable selected interrupt sync signal
+   Uint16 SYNCSEL:1;         // 13     Sync Select Bit (R/W):
+                             //        0     sync signal controls source wrap counter
+                             //        1     sync signal controls destination wrap counter
+   Uint16 DATASIZE:1;        // 14     Data Size Mode Bit (R/W):
+                             //        0     16-bit data transfer size
+                             //        1     32-bit data transfer size
+   Uint16 CHINTE:1;          // 15     Channel Interrupt Enable Bit (R/W):
+                             //        0     channel interrupt disabled
+                             //        1     channel interrupt enabled
+};
+
+union MODE_REG {
+   Uint16                all;
+   struct MODE_BITS      bit;
+};
+
+//----------------------------------------------------
+// Channel CONTROL register bit definitions:
+struct CONTROL_BITS {        // bits   description
+   Uint16 RUN:1;             // 0      Run Bit (R=0/W=1)
+   Uint16 HALT:1;            // 1      Halt Bit (R=0/W=1)
+   Uint16 SOFTRESET:1;       // 2      Soft Reset Bit (R=0/W=1)
+   Uint16 PERINTFRC:1;       // 3      Interrupt Force Bit (R=0/W=1)
+   Uint16 PERINTCLR:1;       // 4      Interrupt Clear Bit (R=0/W=1)
+   Uint16 SYNCFRC:1;         // 5      Sync Force Bit (R=0/W=1)
+   Uint16 SYNCCLR:1;         // 6      Sync Clear Bit (R=0/W=1)
+   Uint16 ERRCLR:1;          // 7      Error Clear Bit (R=0/W=1)
+   Uint16 PERINTFLG:1;       // 8      Interrupt Flag Bit (R):
+                             //        0     no interrupt pending
+                             //        1     interrupt pending
+   Uint16 SYNCFLG:1;         // 9      Sync Flag Bit (R):
+                             //        0     no sync pending
+                             //        1     sync pending
+   Uint16 SYNCERR:1;         // 10     Sync Error Flag Bit (R):
+                             //        0     no sync error
+                             //        1     sync error detected
+   Uint16 TRANSFERSTS:1;     // 11     Transfer Status Bit (R):
+                             //        0     no transfer in progress or pending
+                             //        1     transfer in progress or pending
+   Uint16 BURSTSTS:1;        // 12     Burst Status Bit (R):
+                             //        0     no burst in progress or pending
+                             //        1     burst in progress or pending
+   Uint16 RUNSTS:1;          // 13     Run Status Bit (R):
+                             //        0     channel not running or halted
+                             //        1     channel running
+   Uint16 OVRFLG:1;          // 14     Overflow Flag Bit(R)
+                             //        0     no overflow event
+                             //        1     overflow event
+   Uint16 rsvd1:1;           // 15     (R=0)
+};
+
+union CONTROL_REG {
+   Uint16                 all;
+   struct CONTROL_BITS    bit;
+};
+
+//----------------------------------------------------
+// DMACTRL register bit definitions:
+struct DMACTRL_BITS {        // bits   description
+   Uint16 HARDRESET:1;       // 0      Hard Reset Bit (R=0/W=1)
+   Uint16 PRIORITYRESET:1;   // 1      Priority Reset Bit (R=0/W=1)
+   Uint16 rsvd1:14;          // 15:2   (R=0:0)
+};
+
+union DMACTRL_REG {
+   Uint16                 all;
+   struct DMACTRL_BITS    bit;
+};
+
+//----------------------------------------------------
+// DEBUGCTRL register bit definitions:
+struct DEBUGCTRL_BITS {      // bits   description
+   Uint16 rsvd1:15;          // 14:0   (R=0:0)
+   Uint16 FREE:1;            // 15     Debug Mode Bit (R/W):
+                             //        0     halt after current read-write operation
+                             //        1     continue running
+};
+
+union DEBUGCTRL_REG {
+   Uint16                 all;
+   struct DEBUGCTRL_BITS  bit;
+};
+
+
+//----------------------------------------------------
+// PRIORITYCTRL1 register bit definitions:
+struct PRIORITYCTRL1_BITS {  // bits   description
+   Uint16 CH1PRIORITY:1;     // 0      Ch1 Priority Bit (R/W):
+                             //        0     same priority as all other channels
+                             //        1     highest priority channel
+   Uint16 rsvd1:15;          // 15:1   (R=0:0)
+};
+
+union PRIORITYCTRL1_REG {
+   Uint16                     all;
+   struct PRIORITYCTRL1_BITS  bit;
+};
+
+
+//----------------------------------------------------
+// PRIORITYSTAT register bit definitions:
+struct PRIORITYSTAT_BITS {    // bits   description
+   Uint16 ACTIVESTS:3;        // 2:0    Active Channel Status Bits (R):
+                              //        0,0,0  no channel active
+                              //        0,0,1  Ch1 channel active
+                              //        0,1,0  Ch2 channel active
+                              //        0,1,1  Ch3 channel active
+                              //        1,0,0  Ch4 channel active
+                              //        1,0,1  Ch5 channel active
+                              //        1,1,0  Ch6 channel active
+   Uint16 rsvd1:1;            // 3      (R=0)
+   Uint16 ACTIVESTS_SHADOW:3; // 6:4    Active Channel Status Shadow Bits (R):
+                              //        0,0,0  no channel active and interrupted by Ch1
+                              //        0,0,1  cannot occur
+                              //        0,1,0  Ch2 was active and interrupted by Ch1
+                              //        0,1,1  Ch3 was active and interrupted by Ch1
+                              //        1,0,0  Ch4 was active and interrupted by Ch1
+                              //        1,0,1  Ch5 was active and interrupted by Ch1
+                              //        1,1,0  Ch6 was active and interrupted by Ch1
+   Uint16 rsvd2:9;            // 15:7   (R=0:0)
+};
+
+union PRIORITYSTAT_REG {
+   Uint16                     all;
+   struct PRIORITYSTAT_BITS   bit;
+};
+
+// Burst Size
+struct BURST_SIZE_BITS {  // bits  description
+   Uint16 BURSTSIZE:5;    // 4:0   Burst transfer size
+   Uint16 rsvd1:11;       // 15:5  reserved
+};
+
+union BURST_SIZE_REG {
+   Uint16                  all;
+   struct BURST_SIZE_BITS  bit;
+};
+
+// Burst Count
+struct BURST_COUNT_BITS { // bits  description
+   Uint16 BURSTCOUNT:5;   // 4:0   Burst transfer size
+   Uint16 rsvd1:11;       // 15:5  reserved
+};
+
+union BURST_COUNT_REG {
+   Uint16                   all;
+   struct BURST_COUNT_BITS  bit;
+};
+
+
+
+//----------------------------------------------------
+// DMA Channel Registers:
+struct CH_REGS {
+   union  MODE_REG            MODE;                 // Mode Register
+   union  CONTROL_REG         CONTROL;              // Control Register
+
+   union  BURST_SIZE_REG      BURST_SIZE;           // Burst Size Register
+   union  BURST_COUNT_REG     BURST_COUNT;          // Burst Count Register
+   int16                      SRC_BURST_STEP;       // Source Burst Step Register
+   int16                      DST_BURST_STEP;       // Destination Burst Step Register
+
+   Uint16                     TRANSFER_SIZE;        // Transfer Size Register
+   Uint16                     TRANSFER_COUNT;       // Transfer Count Register
+   int16                      SRC_TRANSFER_STEP;    // Source Transfer Step Register
+   int16                      DST_TRANSFER_STEP;    // Destination Transfer Step Register
+
+   Uint16                     SRC_WRAP_SIZE;        // Source Wrap Size Register
+   Uint16                     SRC_WRAP_COUNT;       // Source Wrap Count Register
+   int16                      SRC_WRAP_STEP;        // Source Wrap Step Register
+
+   Uint16                     DST_WRAP_SIZE;        // Destination Wrap Size Register
+   Uint16                     DST_WRAP_COUNT;       // Destination Wrap Count Register
+   int16                      DST_WRAP_STEP;        // Destination Wrap Step Register
+
+   Uint32                     SRC_BEG_ADDR_SHADOW;  // Source Begin Address Shadow Register
+   Uint32                     SRC_ADDR_SHADOW;      // Source Address Shadow Register
+   Uint32                     SRC_BEG_ADDR_ACTIVE;  // Source Begin Address Active Register
+   Uint32                     SRC_ADDR_ACTIVE;      // Source Address Active Register
+
+   Uint32                     DST_BEG_ADDR_SHADOW;  // Destination Begin Address Shadow Register
+   Uint32                     DST_ADDR_SHADOW;      // Destination Address Shadow Register
+   Uint32                     DST_BEG_ADDR_ACTIVE;  // Destination Begin Address Active Register
+   Uint32                     DST_ADDR_ACTIVE;      // Destination Address Active Register
+};
+
+//----------------------------------------------------
+// DMA Registers:
+struct DMA_REGS {
+   union  DMACTRL_REG         DMACTRL;              // DMA Control Register
+   union  DEBUGCTRL_REG       DEBUGCTRL;            // Debug Control Register
+   Uint16                     rsvd0;                // reserved
+   Uint16                     rsvd1;                //
+   union  PRIORITYCTRL1_REG   PRIORITYCTRL1;        // Priority Control 1 Register
+   Uint16                     rsvd2;                //
+   union  PRIORITYSTAT_REG    PRIORITYSTAT;         // Priority Status Register
+   Uint16                     rsvd3[25];            //
+   struct CH_REGS             CH1;                  // DMA Channel 1 Registers
+   struct CH_REGS             CH2;                  // DMA Channel 2 Registers
+   struct CH_REGS             CH3;                  // DMA Channel 3 Registers
+   struct CH_REGS             CH4;                  // DMA Channel 4 Registers
+   struct CH_REGS             CH5;                  // DMA Channel 5 Registers
+   struct CH_REGS             CH6;                  // DMA Channel 6 Registers
+};
+
+
+//---------------------------------------------------------------------------
+// External References & Function Declarations:
+//
+extern struct DMA_REGS DmaRegs;
+
+
+#endif  // end of DSP2833x_DMA_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_DevEmu.h b/Inu/main_matlab/device_support/include/DSP2833x_DevEmu.h
new file mode 100644
index 0000000..4bc43ef
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_DevEmu.h
@@ -0,0 +1,88 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: April 15, 2009   10:05:17 $
+//###########################################################################
+//
+// FILE:   DSP2833x_DevEmu.h
+//
+// TITLE:  DSP2833x Device Emulation Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_DEV_EMU_H
+#define DSP2833x_DEV_EMU_H
+
+
+//---------------------------------------------------------------------------
+// Device Emulation Register Bit Definitions:
+//
+// Device Configuration Register Bit Definitions
+struct DEVICECNF_BITS  {     // bits  description
+   Uint16 rsvd1:3;           // 2:0   reserved
+   Uint16 VMAPS:1;           // 3     VMAP Status
+   Uint16 rsvd2:1;           // 4     reserved
+   Uint16 XRSn:1;            // 5     XRSn Signal Status
+   Uint16 rsvd3:10;          // 15:6
+   Uint16 rsvd4:3;           // 18:16
+   Uint16 ENPROT:1;          // 19    Enable/Disable pipeline protection
+   Uint16 rsvd5:7;           // 26:20 reserved
+   Uint16 TRSTN:1;           // 27    Status of TRSTn signal
+   Uint16 rsvd6:4;           // 31:28 reserved
+};
+
+union DEVICECNF_REG {
+   Uint32                 all;
+   struct DEVICECNF_BITS  bit;
+};
+
+// CLASSID
+struct CLASSID_BITS   {  // bits  description
+   Uint16 CLASSNO:8;     // 7:0   Class Number
+   Uint16 PARTTYPE:8;    // 15:8  Part Type
+};
+
+union CLASSID_REG {
+   Uint16               all;
+   struct CLASSID_BITS  bit;
+};
+
+struct DEV_EMU_REGS {
+   union DEVICECNF_REG DEVICECNF;  // device configuration
+   union CLASSID_REG   CLASSID;    // Class ID
+   Uint16              REVID;      // Device ID
+   Uint16              PROTSTART;  // Write-Read protection start
+   Uint16              PROTRANGE;  // Write-Read protection range
+   Uint16              rsvd2[202];
+};
+
+// PARTID
+struct PARTID_BITS   {  // bits  description
+   Uint16 PARTNO:8;     // 7:0   Part Number
+   Uint16 PARTTYPE:8;   // 15:8  Part Type
+};
+
+union PARTID_REG {
+   Uint16               all;
+   struct PARTID_BITS   bit;
+};
+
+struct PARTID_REGS {
+   union PARTID_REG PARTID; // Part ID
+};
+
+
+
+//---------------------------------------------------------------------------
+// Device Emulation Register References & Function Declarations:
+//
+extern struct DEV_EMU_REGS DevEmuRegs;
+extern struct PARTID_REGS PartIdRegs;
+
+#endif  // end of DSP2833x_DEV_EMU_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Device.h b/Inu/main_matlab/device_support/include/DSP2833x_Device.h
new file mode 100644
index 0000000..50be82e
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Device.h
@@ -0,0 +1,203 @@
+// TI File $Revision: /main/5 $
+// Checkin $Date: January 22, 2008   16:55:35 $
+//#########################################################################
+//
+// FILE:   DSP2833x_Device.h
+//
+// TITLE:  DSP2833x Device Definitions.
+//
+//#########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//#########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_DEVICE_H
+#define DSP2833x_DEVICE_H
+
+
+
+#define TARGET	1
+//-------------------------------------------------------------------------
+// User To Select Target Device:
+
+#define DSP28_28335		TARGET	// Selects '28335/'28235
+#define DSP28_28334		0		// Selects '28334/'28234
+#define DSP28_28332		0		// Selects '28332/'28232
+
+
+//-------------------------------------------------------------------------
+// Common CPU Definitions:
+//
+
+unsigned int IFR;
+unsigned int IER;
+
+#define EINT	;
+#define DINT	;
+#define ERTM	;
+#define DRTM	;
+#define EALLOW	;
+#define EDIS	;
+#define ESTOP0	;
+
+#define M_INT1  0x0001
+#define M_INT2  0x0002
+#define M_INT3  0x0004
+#define M_INT4  0x0008
+#define M_INT5  0x0010
+#define M_INT6  0x0020
+#define M_INT7  0x0040
+#define M_INT8  0x0080
+#define M_INT9  0x0100
+#define M_INT10 0x0200
+#define M_INT11 0x0400
+#define M_INT12 0x0800
+#define M_INT13 0x1000
+#define M_INT14 0x2000
+#define M_DLOG  0x4000
+#define M_RTOS  0x8000
+
+#define BIT0    0x0001
+#define BIT1    0x0002
+#define BIT2    0x0004
+#define BIT3    0x0008
+#define BIT4    0x0010
+#define BIT5    0x0020
+#define BIT6    0x0040
+#define BIT7    0x0080
+#define BIT8    0x0100
+#define BIT9    0x0200
+#define BIT10   0x0400
+#define BIT11   0x0800
+#define BIT12   0x1000
+#define BIT13   0x2000
+#define BIT14   0x4000
+#define BIT15   0x8000
+
+
+
+//-------------------------------------------------------------------------
+// For Portability, User Is Recommended To Use Following Data Type Size
+// Definitions For 16-bit and 32-Bit Signed/Unsigned Integers:
+//
+
+#ifndef DSP28_DATA_TYPES
+#define DSP28_DATA_TYPES
+typedef int                int16;
+typedef long               int32;
+typedef unsigned int       Uint16;
+typedef unsigned long      Uint32;
+typedef float              float32;
+typedef long double        float64;
+#endif
+
+
+//-------------------------------------------------------------------------
+// Include All Peripheral Header Files:
+//
+
+#include "DSP2833x_Adc.h"			// ADC Registers
+#include "DSP2833x_DevEmu.h"		// Device Emulation Registers
+#include "DSP2833x_CpuTimers.h"		// 32-bit CPU Timers
+#include "DSP2833x_ECan.h"			// Enhanced eCAN Registers
+#include "DSP2833x_ECap.h"			// Enhanced Capture
+#include "DSP2833x_DMA.h"			// DMA Registers
+#include "DSP2833x_EPwm.h"			// Enhanced PWM
+#include "DSP2833x_EQep.h"			// Enhanced QEP
+#include "DSP2833x_Gpio.h"			// General Purpose I/O Registers
+#include "DSP2833x_I2c.h"			// I2C Registers
+#include "DSP2833x_McBSP.h"			// McBSP
+#include "DSP2833x_PieCtrl.h"		// PIE Control Registers
+#include "DSP2833x_PieVect.h"		// PIE Vector Table
+#include "DSP2833x_Spi.h"			// SPI Registers
+#include "DSP2833x_Sci.h"			// SCI Registers
+#include "DSP2833x_SysCtrl.h"		// System Control/Power Modes
+#include "DSP2833x_XIntrupt.h"		// External Interrupts
+#include "DSP2833x_Xintf.h"			// XINTF External Interface
+
+#if DSP28_28335
+#define DSP28_EPWM1  1
+#define DSP28_EPWM2  1
+#define DSP28_EPWM3  1
+#define DSP28_EPWM4  1
+#define DSP28_EPWM5  1
+#define DSP28_EPWM6  1
+#define DSP28_ECAP1  1
+#define DSP28_ECAP2  1
+#define DSP28_ECAP3  1
+#define DSP28_ECAP4  1
+#define DSP28_ECAP5  1
+#define DSP28_ECAP6  1
+#define DSP28_EQEP1  1
+#define DSP28_EQEP2  1
+#define DSP28_ECANA  1
+#define DSP28_ECANB  1
+#define DSP28_MCBSPA 1
+#define DSP28_MCBSPB 1
+#define DSP28_SPIA   1
+#define DSP28_SCIA   1
+#define DSP28_SCIB   1
+#define DSP28_SCIC   1
+#define DSP28_I2CA   1
+#endif  // end DSP28_28335
+
+#if DSP28_28334
+#define DSP28_EPWM1  1
+#define DSP28_EPWM2  1
+#define DSP28_EPWM3  1
+#define DSP28_EPWM4  1
+#define DSP28_EPWM5  1
+#define DSP28_EPWM6  1
+#define DSP28_ECAP1  1
+#define DSP28_ECAP2  1
+#define DSP28_ECAP3  1
+#define DSP28_ECAP4  1
+#define DSP28_ECAP5  0
+#define DSP28_ECAP6  0
+#define DSP28_EQEP1  1
+#define DSP28_EQEP2  1
+#define DSP28_ECANA  1
+#define DSP28_ECANB  1
+#define DSP28_MCBSPA 1
+#define DSP28_MCBSPB 1
+#define DSP28_SPIA   1
+#define DSP28_SCIA   1
+#define DSP28_SCIB   1
+#define DSP28_SCIC   1
+#define DSP28_I2CA   1
+#endif  // end DSP28_28334
+
+#if DSP28_28332
+#define DSP28_EPWM1  1
+#define DSP28_EPWM2  1
+#define DSP28_EPWM3  1
+#define DSP28_EPWM4  1
+#define DSP28_EPWM5  1
+#define DSP28_EPWM6  1
+#define DSP28_ECAP1  1
+#define DSP28_ECAP2  1
+#define DSP28_ECAP3  1
+#define DSP28_ECAP4  1
+#define DSP28_ECAP5  0
+#define DSP28_ECAP6  0
+#define DSP28_EQEP1  1
+#define DSP28_EQEP2  1
+#define DSP28_ECANA  1
+#define DSP28_ECANB  1
+#define DSP28_MCBSPA 1
+#define DSP28_MCBSPB 0
+#define DSP28_SPIA   1
+#define DSP28_SCIA   1
+#define DSP28_SCIB   1
+#define DSP28_SCIC   0
+#define DSP28_I2CA   1
+#endif  // end DSP28_28332
+
+
+#endif  // end of DSP2833x_DEVICE_H definition
+
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_ECan.h b/Inu/main_matlab/device_support/include/DSP2833x_ECan.h
new file mode 100644
index 0000000..e6e4a49
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_ECan.h
@@ -0,0 +1,1155 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: May 7, 2007   16:05:39 $
+//###########################################################################
+//
+// FILE:   DSP2833x_ECan.h
+//
+// TITLE:  DSP2833x Device eCAN Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_ECAN_H
+#define DSP2833x_ECAN_H
+
+
+
+/* --------------------------------------------------- */
+/* eCAN Control & Status Registers                     */
+/* ----------------------------------------------------*/
+
+/* eCAN Mailbox enable register (CANME) bit definitions */
+struct  CANME_BITS {      // bit  description
+   Uint16      ME0:1;     // 0   Enable Mailbox 0
+   Uint16      ME1:1;     // 1   Enable Mailbox 1
+   Uint16      ME2:1;     // 2   Enable Mailbox 2
+   Uint16      ME3:1;     // 3   Enable Mailbox 3
+   Uint16      ME4:1;     // 4   Enable Mailbox 4
+   Uint16      ME5:1;     // 5   Enable Mailbox 5
+   Uint16      ME6:1;     // 6   Enable Mailbox 6
+   Uint16      ME7:1;     // 7   Enable Mailbox 7
+   Uint16      ME8:1;     // 8   Enable Mailbox 8
+   Uint16      ME9:1;     // 9   Enable Mailbox 9
+   Uint16      ME10:1;    // 10  Enable Mailbox 10
+   Uint16      ME11:1;    // 11  Enable Mailbox 11
+   Uint16      ME12:1;    // 12  Enable Mailbox 12
+   Uint16      ME13:1;    // 13  Enable Mailbox 13
+   Uint16      ME14:1;    // 14  Enable Mailbox 14
+   Uint16      ME15:1;    // 15  Enable Mailbox 15
+   Uint16      ME16:1;    // 16  Enable Mailbox 16
+   Uint16      ME17:1;    // 17  Enable Mailbox 17
+   Uint16      ME18:1;    // 18  Enable Mailbox 18
+   Uint16      ME19:1;    // 19  Enable Mailbox 19
+   Uint16      ME20:1;    // 20  Enable Mailbox 20
+   Uint16      ME21:1;    // 21  Enable Mailbox 21
+   Uint16      ME22:1;    // 22  Enable Mailbox 22
+   Uint16      ME23:1;    // 23  Enable Mailbox 23
+   Uint16      ME24:1;    // 24  Enable Mailbox 24
+   Uint16      ME25:1;    // 25  Enable Mailbox 25
+   Uint16      ME26:1;    // 26  Enable Mailbox 26
+   Uint16      ME27:1;    // 27  Enable Mailbox 27
+   Uint16      ME28:1;    // 28  Enable Mailbox 28
+   Uint16      ME29:1;    // 29  Enable Mailbox 29
+   Uint16      ME30:1;    // 30  Enable Mailbox 30
+   Uint16      ME31:1;    // 31  Enable Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANME_REG {
+   Uint32             all;
+   struct CANME_BITS  bit;
+};
+
+/* eCAN Mailbox direction register (CANMD) bit definitions */
+struct  CANMD_BITS {      // bit  description
+   Uint16      MD0:1;     // 0   0 -> Tx 1 -> Rx
+   Uint16      MD1:1;     // 1   0 -> Tx 1 -> Rx
+   Uint16      MD2:1;     // 2   0 -> Tx 1 -> Rx
+   Uint16      MD3:1;     // 3   0 -> Tx 1 -> Rx
+   Uint16      MD4:1;     // 4   0 -> Tx 1 -> Rx
+   Uint16      MD5:1;     // 5   0 -> Tx 1 -> Rx
+   Uint16      MD6:1;     // 6   0 -> Tx 1 -> Rx
+   Uint16      MD7:1;     // 7   0 -> Tx 1 -> Rx
+   Uint16      MD8:1;     // 8   0 -> Tx 1 -> Rx
+   Uint16      MD9:1;     // 9   0 -> Tx 1 -> Rx
+   Uint16      MD10:1;    // 10  0 -> Tx 1 -> Rx
+   Uint16      MD11:1;    // 11  0 -> Tx 1 -> Rx
+   Uint16      MD12:1;    // 12  0 -> Tx 1 -> Rx
+   Uint16      MD13:1;    // 13  0 -> Tx 1 -> Rx
+   Uint16      MD14:1;    // 14  0 -> Tx 1 -> Rx
+   Uint16      MD15:1;    // 15  0 -> Tx 1 -> Rx
+   Uint16      MD16:1;    // 16  0 -> Tx 1 -> Rx
+   Uint16      MD17:1;    // 17  0 -> Tx 1 -> Rx
+   Uint16      MD18:1;    // 18  0 -> Tx 1 -> Rx
+   Uint16      MD19:1;    // 19  0 -> Tx 1 -> Rx
+   Uint16      MD20:1;    // 20  0 -> Tx 1 -> Rx
+   Uint16      MD21:1;    // 21  0 -> Tx 1 -> Rx
+   Uint16      MD22:1;    // 22  0 -> Tx 1 -> Rx
+   Uint16      MD23:1;    // 23  0 -> Tx 1 -> Rx
+   Uint16      MD24:1;    // 24  0 -> Tx 1 -> Rx
+   Uint16      MD25:1;    // 25  0 -> Tx 1 -> Rx
+   Uint16      MD26:1;    // 26  0 -> Tx 1 -> Rx
+   Uint16      MD27:1;    // 27  0 -> Tx 1 -> Rx
+   Uint16      MD28:1;    // 28  0 -> Tx 1 -> Rx
+   Uint16      MD29:1;    // 29  0 -> Tx 1 -> Rx
+   Uint16      MD30:1;    // 30  0 -> Tx 1 -> Rx
+   Uint16      MD31:1;    // 31  0 -> Tx 1 -> Rx
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMD_REG {
+   Uint32             all;
+   struct CANMD_BITS  bit;
+};
+
+/* eCAN Transmit Request Set register (CANTRS) bit definitions */
+struct  CANTRS_BITS {      // bit  description
+   Uint16      TRS0:1;     // 0   TRS for Mailbox 0
+   Uint16      TRS1:1;     // 1   TRS for Mailbox 1
+   Uint16      TRS2:1;     // 2   TRS for Mailbox 2
+   Uint16      TRS3:1;     // 3   TRS for Mailbox 3
+   Uint16      TRS4:1;     // 4   TRS for Mailbox 4
+   Uint16      TRS5:1;     // 5   TRS for Mailbox 5
+   Uint16      TRS6:1;     // 6   TRS for Mailbox 6
+   Uint16      TRS7:1;     // 7   TRS for Mailbox 7
+   Uint16      TRS8:1;     // 8   TRS for Mailbox 8
+   Uint16      TRS9:1;     // 9   TRS for Mailbox 9
+   Uint16      TRS10:1;    // 10  TRS for Mailbox 10
+   Uint16      TRS11:1;    // 11  TRS for Mailbox 11
+   Uint16      TRS12:1;    // 12  TRS for Mailbox 12
+   Uint16      TRS13:1;    // 13  TRS for Mailbox 13
+   Uint16      TRS14:1;    // 14  TRS for Mailbox 14
+   Uint16      TRS15:1;    // 15  TRS for Mailbox 15
+   Uint16      TRS16:1;    // 16  TRS for Mailbox 16
+   Uint16      TRS17:1;    // 17  TRS for Mailbox 17
+   Uint16      TRS18:1;    // 18  TRS for Mailbox 18
+   Uint16      TRS19:1;    // 19  TRS for Mailbox 19
+   Uint16      TRS20:1;    // 20  TRS for Mailbox 20
+   Uint16      TRS21:1;    // 21  TRS for Mailbox 21
+   Uint16      TRS22:1;    // 22  TRS for Mailbox 22
+   Uint16      TRS23:1;    // 23  TRS for Mailbox 23
+   Uint16      TRS24:1;    // 24  TRS for Mailbox 24
+   Uint16      TRS25:1;    // 25  TRS for Mailbox 25
+   Uint16      TRS26:1;    // 26  TRS for Mailbox 26
+   Uint16      TRS27:1;    // 27  TRS for Mailbox 27
+   Uint16      TRS28:1;    // 28  TRS for Mailbox 28
+   Uint16      TRS29:1;    // 29  TRS for Mailbox 29
+   Uint16      TRS30:1;    // 30  TRS for Mailbox 30
+   Uint16      TRS31:1;    // 31  TRS for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTRS_REG {
+   Uint32              all;
+   struct CANTRS_BITS  bit;
+};
+
+/* eCAN Transmit Request Reset register (CANTRR) bit definitions */
+struct  CANTRR_BITS {      // bit  description
+   Uint16      TRR0:1;     // 0   TRR for Mailbox 0
+   Uint16      TRR1:1;     // 1   TRR for Mailbox 1
+   Uint16      TRR2:1;     // 2   TRR for Mailbox 2
+   Uint16      TRR3:1;     // 3   TRR for Mailbox 3
+   Uint16      TRR4:1;     // 4   TRR for Mailbox 4
+   Uint16      TRR5:1;     // 5   TRR for Mailbox 5
+   Uint16      TRR6:1;     // 6   TRR for Mailbox 6
+   Uint16      TRR7:1;     // 7   TRR for Mailbox 7
+   Uint16      TRR8:1;     // 8   TRR for Mailbox 8
+   Uint16      TRR9:1;     // 9   TRR for Mailbox 9
+   Uint16      TRR10:1;    // 10  TRR for Mailbox 10
+   Uint16      TRR11:1;    // 11  TRR for Mailbox 11
+   Uint16      TRR12:1;    // 12  TRR for Mailbox 12
+   Uint16      TRR13:1;    // 13  TRR for Mailbox 13
+   Uint16      TRR14:1;    // 14  TRR for Mailbox 14
+   Uint16      TRR15:1;    // 15  TRR for Mailbox 15
+   Uint16      TRR16:1;    // 16  TRR for Mailbox 16
+   Uint16      TRR17:1;    // 17  TRR for Mailbox 17
+   Uint16      TRR18:1;    // 18  TRR for Mailbox 18
+   Uint16      TRR19:1;    // 19  TRR for Mailbox 19
+   Uint16      TRR20:1;    // 20  TRR for Mailbox 20
+   Uint16      TRR21:1;    // 21  TRR for Mailbox 21
+   Uint16      TRR22:1;    // 22  TRR for Mailbox 22
+   Uint16      TRR23:1;    // 23  TRR for Mailbox 23
+   Uint16      TRR24:1;    // 24  TRR for Mailbox 24
+   Uint16      TRR25:1;    // 25  TRR for Mailbox 25
+   Uint16      TRR26:1;    // 26  TRR for Mailbox 26
+   Uint16      TRR27:1;    // 27  TRR for Mailbox 27
+   Uint16      TRR28:1;    // 28  TRR for Mailbox 28
+   Uint16      TRR29:1;    // 29  TRR for Mailbox 29
+   Uint16      TRR30:1;    // 30  TRR for Mailbox 30
+   Uint16      TRR31:1;    // 31  TRR for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTRR_REG {
+   Uint32              all;
+   struct CANTRR_BITS  bit;
+};
+
+/* eCAN Transmit Acknowledge register (CANTA) bit definitions */
+struct  CANTA_BITS {      // bit  description
+   Uint16      TA0:1;     // 0   TA for Mailbox 0
+   Uint16      TA1:1;     // 1   TA for Mailbox 1
+   Uint16      TA2:1;     // 2   TA for Mailbox 2
+   Uint16      TA3:1;     // 3   TA for Mailbox 3
+   Uint16      TA4:1;     // 4   TA for Mailbox 4
+   Uint16      TA5:1;     // 5   TA for Mailbox 5
+   Uint16      TA6:1;     // 6   TA for Mailbox 6
+   Uint16      TA7:1;     // 7   TA for Mailbox 7
+   Uint16      TA8:1;     // 8   TA for Mailbox 8
+   Uint16      TA9:1;     // 9   TA for Mailbox 9
+   Uint16      TA10:1;    // 10  TA for Mailbox 10
+   Uint16      TA11:1;    // 11  TA for Mailbox 11
+   Uint16      TA12:1;    // 12  TA for Mailbox 12
+   Uint16      TA13:1;    // 13  TA for Mailbox 13
+   Uint16      TA14:1;    // 14  TA for Mailbox 14
+   Uint16      TA15:1;    // 15  TA for Mailbox 15
+   Uint16      TA16:1;    // 16  TA for Mailbox 16
+   Uint16      TA17:1;    // 17  TA for Mailbox 17
+   Uint16      TA18:1;    // 18  TA for Mailbox 18
+   Uint16      TA19:1;    // 19  TA for Mailbox 19
+   Uint16      TA20:1;    // 20  TA for Mailbox 20
+   Uint16      TA21:1;    // 21  TA for Mailbox 21
+   Uint16      TA22:1;    // 22  TA for Mailbox 22
+   Uint16      TA23:1;    // 23  TA for Mailbox 23
+   Uint16      TA24:1;    // 24  TA for Mailbox 24
+   Uint16      TA25:1;    // 25  TA for Mailbox 25
+   Uint16      TA26:1;    // 26  TA for Mailbox 26
+   Uint16      TA27:1;    // 27  TA for Mailbox 27
+   Uint16      TA28:1;    // 28  TA for Mailbox 28
+   Uint16      TA29:1;    // 29  TA for Mailbox 29
+   Uint16      TA30:1;    // 30  TA for Mailbox 30
+   Uint16      TA31:1;    // 31  TA for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTA_REG {
+   Uint32             all;
+   struct CANTA_BITS  bit;
+};
+
+/* eCAN Transmit Abort Acknowledge register (CANAA) bit definitions */
+struct  CANAA_BITS {      // bit  description
+   Uint16      AA0:1;     // 0   AA for Mailbox 0
+   Uint16      AA1:1;     // 1   AA for Mailbox 1
+   Uint16      AA2:1;     // 2   AA for Mailbox 2
+   Uint16      AA3:1;     // 3   AA for Mailbox 3
+   Uint16      AA4:1;     // 4   AA for Mailbox 4
+   Uint16      AA5:1;     // 5   AA for Mailbox 5
+   Uint16      AA6:1;     // 6   AA for Mailbox 6
+   Uint16      AA7:1;     // 7   AA for Mailbox 7
+   Uint16      AA8:1;     // 8   AA for Mailbox 8
+   Uint16      AA9:1;     // 9   AA for Mailbox 9
+   Uint16      AA10:1;    // 10  AA for Mailbox 10
+   Uint16      AA11:1;    // 11  AA for Mailbox 11
+   Uint16      AA12:1;    // 12  AA for Mailbox 12
+   Uint16      AA13:1;    // 13  AA for Mailbox 13
+   Uint16      AA14:1;    // 14  AA for Mailbox 14
+   Uint16      AA15:1;    // 15  AA for Mailbox 15
+   Uint16      AA16:1;    // 16  AA for Mailbox 16
+   Uint16      AA17:1;    // 17  AA for Mailbox 17
+   Uint16      AA18:1;    // 18  AA for Mailbox 18
+   Uint16      AA19:1;    // 19  AA for Mailbox 19
+   Uint16      AA20:1;    // 20  AA for Mailbox 20
+   Uint16      AA21:1;    // 21  AA for Mailbox 21
+   Uint16      AA22:1;    // 22  AA for Mailbox 22
+   Uint16      AA23:1;    // 23  AA for Mailbox 23
+   Uint16      AA24:1;    // 24  AA for Mailbox 24
+   Uint16      AA25:1;    // 25  AA for Mailbox 25
+   Uint16      AA26:1;    // 26  AA for Mailbox 26
+   Uint16      AA27:1;    // 27  AA for Mailbox 27
+   Uint16      AA28:1;    // 28  AA for Mailbox 28
+   Uint16      AA29:1;    // 29  AA for Mailbox 29
+   Uint16      AA30:1;    // 30  AA for Mailbox 30
+   Uint16      AA31:1;    // 31  AA for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANAA_REG {
+   Uint32             all;
+   struct CANAA_BITS  bit;
+};
+
+/* eCAN Received Message Pending register (CANRMP) bit definitions */
+struct  CANRMP_BITS {      // bit  description
+   Uint16      RMP0:1;     // 0   RMP for Mailbox 0
+   Uint16      RMP1:1;     // 1   RMP for Mailbox 1
+   Uint16      RMP2:1;     // 2   RMP for Mailbox 2
+   Uint16      RMP3:1;     // 3   RMP for Mailbox 3
+   Uint16      RMP4:1;     // 4   RMP for Mailbox 4
+   Uint16      RMP5:1;     // 5   RMP for Mailbox 5
+   Uint16      RMP6:1;     // 6   RMP for Mailbox 6
+   Uint16      RMP7:1;     // 7   RMP for Mailbox 7
+   Uint16      RMP8:1;     // 8   RMP for Mailbox 8
+   Uint16      RMP9:1;     // 9   RMP for Mailbox 9
+   Uint16      RMP10:1;    // 10  RMP for Mailbox 10
+   Uint16      RMP11:1;    // 11  RMP for Mailbox 11
+   Uint16      RMP12:1;    // 12  RMP for Mailbox 12
+   Uint16      RMP13:1;    // 13  RMP for Mailbox 13
+   Uint16      RMP14:1;    // 14  RMP for Mailbox 14
+   Uint16      RMP15:1;    // 15  RMP for Mailbox 15
+   Uint16      RMP16:1;    // 16  RMP for Mailbox 16
+   Uint16      RMP17:1;    // 17  RMP for Mailbox 17
+   Uint16      RMP18:1;    // 18  RMP for Mailbox 18
+   Uint16      RMP19:1;    // 19  RMP for Mailbox 19
+   Uint16      RMP20:1;    // 20  RMP for Mailbox 20
+   Uint16      RMP21:1;    // 21  RMP for Mailbox 21
+   Uint16      RMP22:1;    // 22  RMP for Mailbox 22
+   Uint16      RMP23:1;    // 23  RMP for Mailbox 23
+   Uint16      RMP24:1;    // 24  RMP for Mailbox 24
+   Uint16      RMP25:1;    // 25  RMP for Mailbox 25
+   Uint16      RMP26:1;    // 26  RMP for Mailbox 26
+   Uint16      RMP27:1;    // 27  RMP for Mailbox 27
+   Uint16      RMP28:1;    // 28  RMP for Mailbox 28
+   Uint16      RMP29:1;    // 29  RMP for Mailbox 29
+   Uint16      RMP30:1;    // 30  RMP for Mailbox 30
+   Uint16      RMP31:1;    // 31  RMP for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRMP_REG {
+   Uint32              all;
+   struct CANRMP_BITS  bit;
+};
+
+/* eCAN Received Message Lost register (CANRML) bit definitions */
+struct  CANRML_BITS {      // bit  description
+   Uint16      RML0:1;     // 0   RML for Mailbox 0
+   Uint16      RML1:1;     // 1   RML for Mailbox 1
+   Uint16      RML2:1;     // 2   RML for Mailbox 2
+   Uint16      RML3:1;     // 3   RML for Mailbox 3
+   Uint16      RML4:1;     // 4   RML for Mailbox 4
+   Uint16      RML5:1;     // 5   RML for Mailbox 5
+   Uint16      RML6:1;     // 6   RML for Mailbox 6
+   Uint16      RML7:1;     // 7   RML for Mailbox 7
+   Uint16      RML8:1;     // 8   RML for Mailbox 8
+   Uint16      RML9:1;     // 9   RML for Mailbox 9
+   Uint16      RML10:1;    // 10  RML for Mailbox 10
+   Uint16      RML11:1;    // 11  RML for Mailbox 11
+   Uint16      RML12:1;    // 12  RML for Mailbox 12
+   Uint16      RML13:1;    // 13  RML for Mailbox 13
+   Uint16      RML14:1;    // 14  RML for Mailbox 14
+   Uint16      RML15:1;    // 15  RML for Mailbox 15
+   Uint16      RML16:1;    // 16  RML for Mailbox 16
+   Uint16      RML17:1;    // 17  RML for Mailbox 17
+   Uint16      RML18:1;    // 18  RML for Mailbox 18
+   Uint16      RML19:1;    // 19  RML for Mailbox 19
+   Uint16      RML20:1;    // 20  RML for Mailbox 20
+   Uint16      RML21:1;    // 21  RML for Mailbox 21
+   Uint16      RML22:1;    // 22  RML for Mailbox 22
+   Uint16      RML23:1;    // 23  RML for Mailbox 23
+   Uint16      RML24:1;    // 24  RML for Mailbox 24
+   Uint16      RML25:1;    // 25  RML for Mailbox 25
+   Uint16      RML26:1;    // 26  RML for Mailbox 26
+   Uint16      RML27:1;    // 27  RML for Mailbox 27
+   Uint16      RML28:1;    // 28  RML for Mailbox 28
+   Uint16      RML29:1;    // 29  RML for Mailbox 29
+   Uint16      RML30:1;    // 30  RML for Mailbox 30
+   Uint16      RML31:1;    // 31  RML for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRML_REG {
+   Uint32              all;
+   struct CANRML_BITS  bit;
+};
+
+/* eCAN Remote Frame Pending register (CANRFP) bit definitions */
+struct  CANRFP_BITS {      // bit  description
+   Uint16      RFP0:1;     // 0   RFP for Mailbox 0
+   Uint16      RFP1:1;     // 1   RFP for Mailbox 1
+   Uint16      RFP2:1;     // 2   RFP for Mailbox 2
+   Uint16      RFP3:1;     // 3   RFP for Mailbox 3
+   Uint16      RFP4:1;     // 4   RFP for Mailbox 4
+   Uint16      RFP5:1;     // 5   RFP for Mailbox 5
+   Uint16      RFP6:1;     // 6   RFP for Mailbox 6
+   Uint16      RFP7:1;     // 7   RFP for Mailbox 7
+   Uint16      RFP8:1;     // 8   RFP for Mailbox 8
+   Uint16      RFP9:1;     // 9   RFP for Mailbox 9
+   Uint16      RFP10:1;    // 10  RFP for Mailbox 10
+   Uint16      RFP11:1;    // 11  RFP for Mailbox 11
+   Uint16      RFP12:1;    // 12  RFP for Mailbox 12
+   Uint16      RFP13:1;    // 13  RFP for Mailbox 13
+   Uint16      RFP14:1;    // 14  RFP for Mailbox 14
+   Uint16      RFP15:1;    // 15  RFP for Mailbox 15
+   Uint16      RFP16:1;    // 16  RFP for Mailbox 16
+   Uint16      RFP17:1;    // 17  RFP for Mailbox 17
+   Uint16      RFP18:1;    // 18  RFP for Mailbox 18
+   Uint16      RFP19:1;    // 19  RFP for Mailbox 19
+   Uint16      RFP20:1;    // 20  RFP for Mailbox 20
+   Uint16      RFP21:1;    // 21  RFP for Mailbox 21
+   Uint16      RFP22:1;    // 22  RFP for Mailbox 22
+   Uint16      RFP23:1;    // 23  RFP for Mailbox 23
+   Uint16      RFP24:1;    // 24  RFP for Mailbox 24
+   Uint16      RFP25:1;    // 25  RFP for Mailbox 25
+   Uint16      RFP26:1;    // 26  RFP for Mailbox 26
+   Uint16      RFP27:1;    // 27  RFP for Mailbox 27
+   Uint16      RFP28:1;    // 28  RFP for Mailbox 28
+   Uint16      RFP29:1;    // 29  RFP for Mailbox 29
+   Uint16      RFP30:1;    // 30  RFP for Mailbox 30
+   Uint16      RFP31:1;    // 31  RFP for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRFP_REG {
+   Uint32              all;
+   struct CANRFP_BITS  bit;
+};
+
+/* eCAN Global Acceptance Mask register (CANGAM) bit definitions */
+struct  CANGAM_BITS {   // bits  description
+   Uint16 GAM150:16;    // 15:0  Global acceptance mask bits 0-15
+   Uint16 GAM2816:13;   // 28:16 Global acceptance mask bits 16-28
+   Uint16 rsvd:2;       // 30:29 reserved
+   Uint16 AMI:1;        // 31    AMI bit
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGAM_REG {
+   Uint32              all;
+   struct CANGAM_BITS  bit;
+};
+
+
+/* eCAN Master Control register (CANMC) bit definitions */
+struct  CANMC_BITS {       // bits  description
+   Uint16      MBNR:5;     // 4:0   MBX # for CDR bit
+   Uint16      SRES:1;     // 5     Soft reset
+   Uint16      STM:1;      // 6     Self-test mode
+   Uint16      ABO:1;      // 7     Auto bus-on
+   Uint16      CDR:1;      // 8     Change data request
+   Uint16      WUBA:1;     // 9     Wake-up on bus activity
+   Uint16      DBO:1;      // 10    Data-byte order
+   Uint16      PDR:1;      // 11    Power-down mode request
+   Uint16      CCR:1;      // 12    Change configuration request
+   Uint16      SCB:1;      // 13    SCC compatibility bit
+   Uint16      TCC:1;      // 14    TSC MSB clear bit
+   Uint16      MBCC:1;     // 15    TSC clear bit thru mailbox 16
+   Uint16      SUSP:1;     // 16    SUSPEND free/soft bit
+   Uint16      rsvd:15;    // 31:17  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMC_REG {
+   Uint32             all;
+   struct CANMC_BITS  bit;
+};
+
+/* eCAN Bit -timing configuration register (CANBTC) bit definitions */
+struct  CANBTC_BITS {  // bits  description
+   Uint16  TSEG2REG:3; // 2:0   TSEG2 register value
+   Uint16  TSEG1REG:4; // 6:3   TSEG1 register value
+   Uint16  SAM:1;      // 7     Sample-point setting
+   Uint16  SJWREG:2;   // 9:8   Synchroniztion Jump Width register value
+   Uint16  rsvd1:6;    // 15:10 reserved
+   Uint16  BRPREG:8;   // 23:16 Baudrate prescaler register value
+   Uint16  rsvd2:8;    // 31:24 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANBTC_REG {
+   Uint32              all;
+   struct CANBTC_BITS  bit;
+};
+
+/* eCAN Error & Status register (CANES) bit definitions */
+struct  CANES_BITS {    // bits  description
+   Uint16   TM:1;       // 0     Transmit Mode
+   Uint16   RM:1;       // 1     Receive Mode
+   Uint16   rsvd1:1;    // 2     reserved
+   Uint16   PDA:1;      // 3     Power-down acknowledge
+   Uint16   CCE:1;      // 4     Change Configuration Enable
+   Uint16   SMA:1;      // 5     Suspend Mode Acknowledge
+   Uint16   rsvd2:10;   // 15:6  reserved
+   Uint16   EW:1;       // 16    Warning status
+   Uint16   EP:1;       // 17    Error Passive status
+   Uint16   BO:1;       // 18    Bus-off status
+   Uint16   ACKE:1;     // 19    Acknowledge error
+   Uint16   SE:1;       // 20    Stuff error
+   Uint16   CRCE:1;     // 21    CRC error
+   Uint16   SA1:1;      // 22    Stuck at Dominant error
+   Uint16   BE:1;       // 23    Bit error
+   Uint16   FE:1;       // 24    Framing error
+   Uint16   rsvd3:7;    // 31:25 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANES_REG {
+   Uint32             all;
+   struct CANES_BITS  bit;
+};
+
+
+/* eCAN Transmit Error Counter register (CANTEC) bit definitions */
+struct  CANTEC_BITS {  // bits  description
+   Uint16 TEC:8;       // 7:0   TEC
+   Uint16 rsvd1:8;     // 15:8  reserved
+   Uint16 rsvd2:16;    // 31:16  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTEC_REG {
+   Uint32              all;
+   struct CANTEC_BITS  bit;
+};
+
+/* eCAN Receive Error Counter register (CANREC) bit definitions */
+struct  CANREC_BITS {  // bits  description
+   Uint16 REC:8;       // 7:0   REC
+   Uint16 rsvd1:8;     // 15:8  reserved
+   Uint16 rsvd2:16;    // 31:16 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANREC_REG {
+   Uint32              all;
+   struct CANREC_BITS  bit;
+};
+
+/* eCAN Global Interrupt Flag 0 (CANGIF0) bit definitions */
+struct  CANGIF0_BITS {  // bits  description
+   Uint16   MIV0:5;     // 4:0   Mailbox Interrupt Vector
+   Uint16   rsvd1:3;    // 7:5   reserved
+   Uint16   WLIF0:1;    // 8     Warning level interrupt flag
+   Uint16   EPIF0:1;    // 9     Error-passive interrupt flag
+   Uint16   BOIF0:1;    // 10    Bus-off interrupt flag
+   Uint16   RMLIF0:1;   // 11    Received message lost interrupt flag
+   Uint16   WUIF0:1;    // 12    Wakeup interrupt flag
+   Uint16   WDIF0:1;    // 13    Write denied interrupt flag
+   Uint16   AAIF0:1;    // 14    Abort Ack interrupt flag
+   Uint16   GMIF0:1;    // 15    Global MBX interrupt flag
+   Uint16   TCOF0:1;    // 16    TSC Overflow flag
+   Uint16   MTOF0:1;    // 17    Mailbox Timeout flag
+   Uint16   rsvd2:14;   // 31:18 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIF0_REG {
+   Uint32               all;
+   struct CANGIF0_BITS  bit;
+};
+
+/* eCAN Global Interrupt Mask register (CANGIM) bit definitions */
+struct  CANGIM_BITS { // bits  description
+   Uint16  I0EN:1;    // 0      Interrupt 0 enable
+   Uint16  I1EN:1;    // 1      Interrupt 1 enable
+   Uint16  GIL:1;     // 2      Global Interrupt Level
+   Uint16  rsvd1:5;   // 7:3    reserved
+   Uint16  WLIM:1;    // 8      Warning level interrupt mask
+   Uint16  EPIM:1;    // 9      Error-passive interrupt mask
+   Uint16  BOIM:1;    // 10     Bus-off interrupt mask
+   Uint16  RMLIM:1;   // 11     Received message lost interrupt mask
+   Uint16  WUIM:1;    // 12     Wakeup interrupt mask
+   Uint16  WDIM:1;    // 13     Write denied interrupt mask
+   Uint16  AAIM:1;    // 14     Abort Ack interrupt mask
+   Uint16  rsvd2:1;   // 15     reserved
+   Uint16  TCOM:1;    // 16     TSC overflow interrupt mask
+   Uint16  MTOM:1;    // 17     MBX Timeout interrupt mask
+   Uint16  rsvd3:14;  // 31:18  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIM_REG {
+   Uint32              all;
+   struct CANGIM_BITS  bit;
+};
+
+
+/* eCAN Global Interrupt Flag 1 (eCANGIF1) bit definitions */
+struct  CANGIF1_BITS {     // bits  description
+   Uint16      MIV1:5;     // 4:0   Mailbox Interrupt Vector
+   Uint16      rsvd1:3;    // 7:5   reserved
+   Uint16      WLIF1:1;    // 8     Warning level interrupt flag
+   Uint16      EPIF1:1;    // 9     Error-passive interrupt flag
+   Uint16      BOIF1:1;    // 10    Bus-off interrupt flag
+   Uint16      RMLIF1:1;   // 11    Received message lost interrupt flag
+   Uint16      WUIF1:1;    // 12    Wakeup interrupt flag
+   Uint16      WDIF1:1;    // 13    Write denied interrupt flag
+   Uint16      AAIF1:1;    // 14    Abort Ack interrupt flag
+   Uint16      GMIF1:1;    // 15    Global MBX interrupt flag
+   Uint16      TCOF1:1;    // 16    TSC Overflow flag
+   Uint16      MTOF1:1;    // 17    Mailbox Timeout flag
+   Uint16      rsvd2:14;   // 31:18 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANGIF1_REG {
+   Uint32               all;
+   struct CANGIF1_BITS  bit;
+};
+
+
+/* eCAN Mailbox Interrupt Mask register (CANMIM) bit definitions */
+struct  CANMIM_BITS {      // bit  description
+   Uint16      MIM0:1;     // 0   MIM for Mailbox 0
+   Uint16      MIM1:1;     // 1   MIM for Mailbox 1
+   Uint16      MIM2:1;     // 2   MIM for Mailbox 2
+   Uint16      MIM3:1;     // 3   MIM for Mailbox 3
+   Uint16      MIM4:1;     // 4   MIM for Mailbox 4
+   Uint16      MIM5:1;     // 5   MIM for Mailbox 5
+   Uint16      MIM6:1;     // 6   MIM for Mailbox 6
+   Uint16      MIM7:1;     // 7   MIM for Mailbox 7
+   Uint16      MIM8:1;     // 8   MIM for Mailbox 8
+   Uint16      MIM9:1;     // 9   MIM for Mailbox 9
+   Uint16      MIM10:1;    // 10  MIM for Mailbox 10
+   Uint16      MIM11:1;    // 11  MIM for Mailbox 11
+   Uint16      MIM12:1;    // 12  MIM for Mailbox 12
+   Uint16      MIM13:1;    // 13  MIM for Mailbox 13
+   Uint16      MIM14:1;    // 14  MIM for Mailbox 14
+   Uint16      MIM15:1;    // 15  MIM for Mailbox 15
+   Uint16      MIM16:1;    // 16  MIM for Mailbox 16
+   Uint16      MIM17:1;    // 17  MIM for Mailbox 17
+   Uint16      MIM18:1;    // 18  MIM for Mailbox 18
+   Uint16      MIM19:1;    // 19  MIM for Mailbox 19
+   Uint16      MIM20:1;    // 20  MIM for Mailbox 20
+   Uint16      MIM21:1;    // 21  MIM for Mailbox 21
+   Uint16      MIM22:1;    // 22  MIM for Mailbox 22
+   Uint16      MIM23:1;    // 23  MIM for Mailbox 23
+   Uint16      MIM24:1;    // 24  MIM for Mailbox 24
+   Uint16      MIM25:1;    // 25  MIM for Mailbox 25
+   Uint16      MIM26:1;    // 26  MIM for Mailbox 26
+   Uint16      MIM27:1;    // 27  MIM for Mailbox 27
+   Uint16      MIM28:1;    // 28  MIM for Mailbox 28
+   Uint16      MIM29:1;    // 29  MIM for Mailbox 29
+   Uint16      MIM30:1;    // 30  MIM for Mailbox 30
+   Uint16      MIM31:1;    // 31  MIM for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMIM_REG {
+   Uint32              all;
+   struct CANMIM_BITS  bit;
+};
+
+/* eCAN Mailbox Interrupt Level register (CANMIL) bit definitions */
+struct  CANMIL_BITS {      // bit  description
+   Uint16      MIL0:1;     // 0   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL1:1;     // 1   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL2:1;     // 2   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL3:1;     // 3   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL4:1;     // 4   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL5:1;     // 5   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL6:1;     // 6   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL7:1;     // 7   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL8:1;     // 8   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL9:1;     // 9   0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL10:1;    // 10  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL11:1;    // 11  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL12:1;    // 12  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL13:1;    // 13  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL14:1;    // 14  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL15:1;    // 15  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL16:1;    // 16  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL17:1;    // 17  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL18:1;    // 18  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL19:1;    // 19  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL20:1;    // 20  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL21:1;    // 21  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL22:1;    // 22  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL23:1;    // 23  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL24:1;    // 24  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL25:1;    // 25  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL26:1;    // 26  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL27:1;    // 27  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL28:1;    // 28  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL29:1;    // 29  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL30:1;    // 30  0 -> Int 9.5   1 -> Int 9.6
+   Uint16      MIL31:1;    // 31  0 -> Int 9.5   1 -> Int 9.6
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMIL_REG {
+   Uint32              all;
+   struct CANMIL_BITS  bit;
+};
+
+
+/* eCAN Overwrite Protection Control register (CANOPC) bit definitions */
+struct  CANOPC_BITS {      // bit  description
+   Uint16      OPC0:1;     // 0   OPC for Mailbox 0
+   Uint16      OPC1:1;     // 1   OPC for Mailbox 1
+   Uint16      OPC2:1;     // 2   OPC for Mailbox 2
+   Uint16      OPC3:1;     // 3   OPC for Mailbox 3
+   Uint16      OPC4:1;     // 4   OPC for Mailbox 4
+   Uint16      OPC5:1;     // 5   OPC for Mailbox 5
+   Uint16      OPC6:1;     // 6   OPC for Mailbox 6
+   Uint16      OPC7:1;     // 7   OPC for Mailbox 7
+   Uint16      OPC8:1;     // 8   OPC for Mailbox 8
+   Uint16      OPC9:1;     // 9   OPC for Mailbox 9
+   Uint16      OPC10:1;    // 10  OPC for Mailbox 10
+   Uint16      OPC11:1;    // 11  OPC for Mailbox 11
+   Uint16      OPC12:1;    // 12  OPC for Mailbox 12
+   Uint16      OPC13:1;    // 13  OPC for Mailbox 13
+   Uint16      OPC14:1;    // 14  OPC for Mailbox 14
+   Uint16      OPC15:1;    // 15  OPC for Mailbox 15
+   Uint16      OPC16:1;    // 16  OPC for Mailbox 16
+   Uint16      OPC17:1;    // 17  OPC for Mailbox 17
+   Uint16      OPC18:1;    // 18  OPC for Mailbox 18
+   Uint16      OPC19:1;    // 19  OPC for Mailbox 19
+   Uint16      OPC20:1;    // 20  OPC for Mailbox 20
+   Uint16      OPC21:1;    // 21  OPC for Mailbox 21
+   Uint16      OPC22:1;    // 22  OPC for Mailbox 22
+   Uint16      OPC23:1;    // 23  OPC for Mailbox 23
+   Uint16      OPC24:1;    // 24  OPC for Mailbox 24
+   Uint16      OPC25:1;    // 25  OPC for Mailbox 25
+   Uint16      OPC26:1;    // 26  OPC for Mailbox 26
+   Uint16      OPC27:1;    // 27  OPC for Mailbox 27
+   Uint16      OPC28:1;    // 28  OPC for Mailbox 28
+   Uint16      OPC29:1;    // 29  OPC for Mailbox 29
+   Uint16      OPC30:1;    // 30  OPC for Mailbox 30
+   Uint16      OPC31:1;    // 31  OPC for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANOPC_REG {
+   Uint32              all;
+   struct CANOPC_BITS  bit;
+};
+
+
+/* eCAN TX I/O Control Register (CANTIOC) bit definitions */
+struct  CANTIOC_BITS { // bits  description
+   Uint16  rsvd1:3;    // 2:0   reserved
+   Uint16  TXFUNC:1;   // 3     TXFUNC
+   Uint16  rsvd2:12;   // 15:4  reserved
+   Uint16  rsvd3:16;   // 31:16 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTIOC_REG {
+   Uint32               all;
+   struct CANTIOC_BITS  bit;
+};
+
+/* eCAN RX I/O Control Register (CANRIOC) bit definitions */
+struct  CANRIOC_BITS { // bits  description
+   Uint16  rsvd1:3;    // 2:0   reserved
+   Uint16  RXFUNC:1;   // 3     RXFUNC
+   Uint16  rsvd2:12;   // 15:4  reserved
+   Uint16  rsvd3:16;   // 31:16 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANRIOC_REG {
+   Uint32               all;
+   struct CANRIOC_BITS  bit;
+};
+
+
+/* eCAN Time-out Control register (CANTOC) bit definitions */
+struct  CANTOC_BITS {      // bit  description
+   Uint16      TOC0:1;     // 0   TOC for Mailbox 0
+   Uint16      TOC1:1;     // 1   TOC for Mailbox 1
+   Uint16      TOC2:1;     // 2   TOC for Mailbox 2
+   Uint16      TOC3:1;     // 3   TOC for Mailbox 3
+   Uint16      TOC4:1;     // 4   TOC for Mailbox 4
+   Uint16      TOC5:1;     // 5   TOC for Mailbox 5
+   Uint16      TOC6:1;     // 6   TOC for Mailbox 6
+   Uint16      TOC7:1;     // 7   TOC for Mailbox 7
+   Uint16      TOC8:1;     // 8   TOC for Mailbox 8
+   Uint16      TOC9:1;     // 9   TOC for Mailbox 9
+   Uint16      TOC10:1;    // 10  TOC for Mailbox 10
+   Uint16      TOC11:1;    // 11  TOC for Mailbox 11
+   Uint16      TOC12:1;    // 12  TOC for Mailbox 12
+   Uint16      TOC13:1;    // 13  TOC for Mailbox 13
+   Uint16      TOC14:1;    // 14  TOC for Mailbox 14
+   Uint16      TOC15:1;    // 15  TOC for Mailbox 15
+   Uint16      TOC16:1;    // 16  TOC for Mailbox 16
+   Uint16      TOC17:1;    // 17  TOC for Mailbox 17
+   Uint16      TOC18:1;    // 18  TOC for Mailbox 18
+   Uint16      TOC19:1;    // 19  TOC for Mailbox 19
+   Uint16      TOC20:1;    // 20  TOC for Mailbox 20
+   Uint16      TOC21:1;    // 21  TOC for Mailbox 21
+   Uint16      TOC22:1;    // 22  TOC for Mailbox 22
+   Uint16      TOC23:1;    // 23  TOC for Mailbox 23
+   Uint16      TOC24:1;    // 24  TOC for Mailbox 24
+   Uint16      TOC25:1;    // 25  TOC for Mailbox 25
+   Uint16      TOC26:1;    // 26  TOC for Mailbox 26
+   Uint16      TOC27:1;    // 27  TOC for Mailbox 27
+   Uint16      TOC28:1;    // 28  TOC for Mailbox 28
+   Uint16      TOC29:1;    // 29  TOC for Mailbox 29
+   Uint16      TOC30:1;    // 30  TOC for Mailbox 30
+   Uint16      TOC31:1;    // 31  TOC for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTOC_REG {
+   Uint32              all;
+   struct CANTOC_BITS  bit;
+};
+
+
+/* eCAN Time-out Status register (CANTOS) bit definitions */
+struct  CANTOS_BITS {            // bit  description
+   Uint16      TOS0:1;     // 0   TOS for Mailbox 0
+   Uint16      TOS1:1;     // 1   TOS for Mailbox 1
+   Uint16      TOS2:1;     // 2   TOS for Mailbox 2
+   Uint16      TOS3:1;     // 3   TOS for Mailbox 3
+   Uint16      TOS4:1;     // 4   TOS for Mailbox 4
+   Uint16      TOS5:1;     // 5   TOS for Mailbox 5
+   Uint16      TOS6:1;     // 6   TOS for Mailbox 6
+   Uint16      TOS7:1;     // 7   TOS for Mailbox 7
+   Uint16      TOS8:1;     // 8   TOS for Mailbox 8
+   Uint16      TOS9:1;     // 9   TOS for Mailbox 9
+   Uint16      TOS10:1;    // 10  TOS for Mailbox 10
+   Uint16      TOS11:1;    // 11  TOS for Mailbox 11
+   Uint16      TOS12:1;    // 12  TOS for Mailbox 12
+   Uint16      TOS13:1;    // 13  TOS for Mailbox 13
+   Uint16      TOS14:1;    // 14  TOS for Mailbox 14
+   Uint16      TOS15:1;    // 15  TOS for Mailbox 15
+   Uint16      TOS16:1;    // 16  TOS for Mailbox 16
+   Uint16      TOS17:1;    // 17  TOS for Mailbox 17
+   Uint16      TOS18:1;    // 18  TOS for Mailbox 18
+   Uint16      TOS19:1;    // 19  TOS for Mailbox 19
+   Uint16      TOS20:1;    // 20  TOS for Mailbox 20
+   Uint16      TOS21:1;    // 21  TOS for Mailbox 21
+   Uint16      TOS22:1;    // 22  TOS for Mailbox 22
+   Uint16      TOS23:1;    // 23  TOS for Mailbox 23
+   Uint16      TOS24:1;    // 24  TOS for Mailbox 24
+   Uint16      TOS25:1;    // 25  TOS for Mailbox 25
+   Uint16      TOS26:1;    // 26  TOS for Mailbox 26
+   Uint16      TOS27:1;    // 27  TOS for Mailbox 27
+   Uint16      TOS28:1;    // 28  TOS for Mailbox 28
+   Uint16      TOS29:1;    // 29  TOS for Mailbox 29
+   Uint16      TOS30:1;    // 30  TOS for Mailbox 30
+   Uint16      TOS31:1;    // 31  TOS for Mailbox 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANTOS_REG {
+   Uint32              all;
+   struct CANTOS_BITS  bit;
+};
+
+/**************************************/
+/* eCAN Control & Status register file */
+/**************************************/
+
+struct ECAN_REGS {
+   union CANME_REG   CANME;          // Mailbox Enable
+   union CANMD_REG   CANMD;          // Mailbox Direction
+   union CANTRS_REG  CANTRS;         // Transmit Request Set
+   union CANTRR_REG  CANTRR;         // Transmit Request Reset
+   union CANTA_REG   CANTA;          // Transmit Acknowledge
+   union CANAA_REG   CANAA;          // Abort Acknowledge
+   union CANRMP_REG  CANRMP;         // Received Message Pending
+   union CANRML_REG  CANRML;         // Received Message Lost
+   union CANRFP_REG  CANRFP;         // Remote Frame Pending
+   union CANGAM_REG  CANGAM;         // Global Acceptance Mask
+   union CANMC_REG   CANMC;          // Master Control
+   union CANBTC_REG  CANBTC;         // Bit Timing
+   union CANES_REG   CANES;          // Error Status
+   union CANTEC_REG  CANTEC;         // Transmit Error Counter
+   union CANREC_REG  CANREC;         // Receive Error Counter
+   union CANGIF0_REG CANGIF0;        // Global Interrupt Flag 0
+   union CANGIM_REG  CANGIM;         // Global Interrupt Mask 0
+   union CANGIF1_REG CANGIF1;        // Global Interrupt Flag 1
+   union CANMIM_REG  CANMIM;         // Mailbox Interrupt Mask
+   union CANMIL_REG  CANMIL;         // Mailbox Interrupt Level
+   union CANOPC_REG  CANOPC;         // Overwrite Protection Control
+   union CANTIOC_REG CANTIOC;        // TX I/O Control
+   union CANRIOC_REG CANRIOC;        // RX I/O Control
+   Uint32            CANTSC;         // Time-stamp counter
+   union CANTOC_REG  CANTOC;         // Time-out Control
+   union CANTOS_REG  CANTOS;         // Time-out Status
+
+};
+
+/* --------------------------------------------------- */
+/* eCAN Mailbox Registers                               */
+/* ----------------------------------------------------*/
+
+/* eCAN Message ID (MSGID) bit definitions */
+struct  CANMSGID_BITS {        // bits  description
+   Uint16      EXTMSGID_L:16;  // 0:15
+   Uint16      EXTMSGID_H:2;   // 16:17
+   Uint16      STDMSGID:11;    // 18:28
+   Uint16      AAM:1;          // 29
+   Uint16      AME:1;          // 30
+   Uint16      IDE:1;          // 31
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMSGID_REG {
+   Uint32                all;
+   struct CANMSGID_BITS  bit;
+};
+
+/* eCAN Message Control Register (MSGCTRL) bit definitions */
+struct  CANMSGCTRL_BITS {     // bits  description
+   Uint16 DLC:4;          // 0:3
+   Uint16 RTR:1;          // 4
+   Uint16 rsvd1:3;        // 7:5   reserved
+   Uint16 TPL:5;          // 12:8
+   Uint16 rsvd2:3;        // 15:13 reserved
+   Uint16 rsvd3:16;       // 31:16 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMSGCTRL_REG {
+   Uint32                  all;
+   struct CANMSGCTRL_BITS  bit;
+};
+
+/* eCAN Message Data Register low (MDR_L) word definitions */
+struct  CANMDL_WORDS {      // bits  description
+   Uint16      LOW_WORD:16; // 0:15
+   Uint16      HI_WORD:16;  // 31:16
+};
+
+/* eCAN Message Data Register low (MDR_L) byte definitions */
+struct  CANMDL_BYTES {      // bits   description
+   Uint16      BYTE3:8;     // 31:24
+   Uint16      BYTE2:8;     // 23:16
+   Uint16      BYTE1:8;     // 15:8
+   Uint16      BYTE0:8;     // 7:0
+};
+
+
+/* Allow access to the bit fields or entire register */
+
+union CANMDL_REG {
+   Uint32                all;
+   struct CANMDL_WORDS   word;
+   struct CANMDL_BYTES   byte;
+};
+
+
+
+/* eCAN Message Data Register high  (MDR_H) word definitions */
+struct  CANMDH_WORDS {         // bits  description
+   Uint16      LOW_WORD:16;    // 0:15
+   Uint16      HI_WORD:16;     // 31:16
+};
+
+/* eCAN Message Data Register low (MDR_H) byte definitions */
+struct  CANMDH_BYTES {      // bits   description
+   Uint16      BYTE7:8;     // 63:56
+   Uint16      BYTE6:8;     // 55:48
+   Uint16      BYTE5:8;     // 47:40
+   Uint16      BYTE4:8;     // 39:32
+};
+
+/* Allow access to the bit fields or entire register */
+union CANMDH_REG {
+   Uint32                  all;
+   struct CANMDH_WORDS     word;
+   struct CANMDH_BYTES     byte;
+};
+
+
+struct MBOX {
+   union CANMSGID_REG     MSGID;
+   union CANMSGCTRL_REG   MSGCTRL;
+   union CANMDL_REG       MDL;
+   union CANMDH_REG       MDH;
+};
+
+/**************************************/
+/*          eCAN Mailboxes             */
+/**************************************/
+
+struct ECAN_MBOXES {
+   struct MBOX MBOX0;
+   struct MBOX MBOX1;
+   struct MBOX MBOX2;
+   struct MBOX MBOX3;
+   struct MBOX MBOX4;
+   struct MBOX MBOX5;
+   struct MBOX MBOX6;
+   struct MBOX MBOX7;
+   struct MBOX MBOX8;
+   struct MBOX MBOX9;
+   struct MBOX MBOX10;
+   struct MBOX MBOX11;
+   struct MBOX MBOX12;
+   struct MBOX MBOX13;
+   struct MBOX MBOX14;
+   struct MBOX MBOX15;
+   struct MBOX MBOX16;
+   struct MBOX MBOX17;
+   struct MBOX MBOX18;
+   struct MBOX MBOX19;
+   struct MBOX MBOX20;
+   struct MBOX MBOX21;
+   struct MBOX MBOX22;
+   struct MBOX MBOX23;
+   struct MBOX MBOX24;
+   struct MBOX MBOX25;
+   struct MBOX MBOX26;
+   struct MBOX MBOX27;
+   struct MBOX MBOX28;
+   struct MBOX MBOX29;
+   struct MBOX MBOX30;
+   struct MBOX MBOX31;
+};
+
+/* eCAN Local Acceptance Mask (LAM) bit definitions */
+struct  CANLAM_BITS {                // bits  description
+   Uint16      LAM_L:16;     // 0:15
+   Uint16      LAM_H:13;     // 16:28
+   Uint16 rsvd1:2;           // 29:30   reserved
+   Uint16      LAMI:1;       // 31
+};
+
+/* Allow access to the bit fields or entire register */
+union CANLAM_REG {
+   Uint32        all;
+   struct CANLAM_BITS  bit;
+};
+
+
+/**************************************/
+/*    eCAN Local Acceptance Masks      */
+/**************************************/
+
+/* eCAN LAM File */
+struct LAM_REGS {
+   union CANLAM_REG LAM0;
+   union CANLAM_REG LAM1;
+   union CANLAM_REG LAM2;
+   union CANLAM_REG LAM3;
+   union CANLAM_REG LAM4;
+   union CANLAM_REG LAM5;
+   union CANLAM_REG LAM6;
+   union CANLAM_REG LAM7;
+   union CANLAM_REG LAM8;
+   union CANLAM_REG LAM9;
+   union CANLAM_REG LAM10;
+   union CANLAM_REG LAM11;
+   union CANLAM_REG LAM12;
+   union CANLAM_REG LAM13;
+   union CANLAM_REG LAM14;
+   union CANLAM_REG LAM15;
+   union CANLAM_REG LAM16;
+   union CANLAM_REG LAM17;
+   union CANLAM_REG LAM18;
+   union CANLAM_REG LAM19;
+   union CANLAM_REG LAM20;
+   union CANLAM_REG LAM21;
+   union CANLAM_REG LAM22;
+   union CANLAM_REG LAM23;
+   union CANLAM_REG LAM24;
+   union CANLAM_REG LAM25;
+   union CANLAM_REG LAM26;
+   union CANLAM_REG LAM27;
+   union CANLAM_REG LAM28;
+   union CANLAM_REG LAM29;
+   union CANLAM_REG LAM30;
+   union CANLAM_REG LAM31;
+};
+
+/* Mailbox MOTS File */
+
+struct MOTS_REGS {
+   Uint32 MOTS0;
+   Uint32 MOTS1;
+   Uint32 MOTS2;
+   Uint32 MOTS3;
+   Uint32 MOTS4;
+   Uint32 MOTS5;
+   Uint32 MOTS6;
+   Uint32 MOTS7;
+   Uint32 MOTS8;
+   Uint32 MOTS9;
+   Uint32 MOTS10;
+   Uint32 MOTS11;
+   Uint32 MOTS12;
+   Uint32 MOTS13;
+   Uint32 MOTS14;
+   Uint32 MOTS15;
+   Uint32 MOTS16;
+   Uint32 MOTS17;
+   Uint32 MOTS18;
+   Uint32 MOTS19;
+   Uint32 MOTS20;
+   Uint32 MOTS21;
+   Uint32 MOTS22;
+   Uint32 MOTS23;
+   Uint32 MOTS24;
+   Uint32 MOTS25;
+   Uint32 MOTS26;
+   Uint32 MOTS27;
+   Uint32 MOTS28;
+   Uint32 MOTS29;
+   Uint32 MOTS30;
+   Uint32 MOTS31;
+};
+
+/* Mailbox MOTO File */
+
+struct MOTO_REGS {
+   Uint32 MOTO0;
+   Uint32 MOTO1;
+   Uint32 MOTO2;
+   Uint32 MOTO3;
+   Uint32 MOTO4;
+   Uint32 MOTO5;
+   Uint32 MOTO6;
+   Uint32 MOTO7;
+   Uint32 MOTO8;
+   Uint32 MOTO9;
+   Uint32 MOTO10;
+   Uint32 MOTO11;
+   Uint32 MOTO12;
+   Uint32 MOTO13;
+   Uint32 MOTO14;
+   Uint32 MOTO15;
+   Uint32 MOTO16;
+   Uint32 MOTO17;
+   Uint32 MOTO18;
+   Uint32 MOTO19;
+   Uint32 MOTO20;
+   Uint32 MOTO21;
+   Uint32 MOTO22;
+   Uint32 MOTO23;
+   Uint32 MOTO24;
+   Uint32 MOTO25;
+   Uint32 MOTO26;
+   Uint32 MOTO27;
+   Uint32 MOTO28;
+   Uint32 MOTO29;
+   Uint32 MOTO30;
+   Uint32 MOTO31;
+};
+
+
+//---------------------------------------------------------------------------
+// eCAN External References & Function Declarations:
+//
+extern struct ECAN_REGS ECanaRegs;
+extern struct ECAN_MBOXES ECanaMboxes;
+extern struct LAM_REGS ECanaLAMRegs;
+extern struct MOTO_REGS ECanaMOTORegs;
+extern struct MOTS_REGS ECanaMOTSRegs;
+
+extern struct ECAN_REGS ECanbRegs;
+extern struct ECAN_MBOXES ECanbMboxes;
+extern struct LAM_REGS ECanbLAMRegs;
+extern struct MOTO_REGS ECanbMOTORegs;
+extern struct MOTS_REGS ECanbMOTSRegs;
+
+
+#endif  // end of DSP2833x_ECAN.H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_ECap.h b/Inu/main_matlab/device_support/include/DSP2833x_ECap.h
new file mode 100644
index 0000000..4ba692e
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_ECap.h
@@ -0,0 +1,145 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:52:07 $
+//###########################################################################
+//
+// FILE:   DSP2833x_ECap.h
+//
+// TITLE:  DSP2833x Enhanced Capture Module Register Bit Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_ECAP_H
+#define DSP2833x_ECAP_H
+
+
+
+//----------------------------------------------------
+// Capture control register 1 bit definitions */                                    
+struct ECCTL1_BITS {          // bits   description
+   Uint16 CAP1POL:1;          // 0      Capture Event 1 Polarity select
+   Uint16 CTRRST1:1;          // 1      Counter Reset on Capture Event 1
+   Uint16 CAP2POL:1;          // 2      Capture Event 2 Polarity select
+   Uint16 CTRRST2:1;          // 3      Counter Reset on Capture Event 2
+   Uint16 CAP3POL:1;          // 4      Capture Event 3 Polarity select
+   Uint16 CTRRST3:1;          // 5      Counter Reset on Capture Event 3
+   Uint16 CAP4POL:1;          // 6      Capture Event 4 Polarity select
+   Uint16 CTRRST4:1;          // 7      Counter Reset on Capture Event 4
+   Uint16 CAPLDEN:1;          // 8      Enable Loading CAP1-4 regs on a Cap Event
+   Uint16 PRESCALE:5;         // 13:9   Event Filter prescale select
+   Uint16 FREE_SOFT:2;        // 15:14  Emulation mode
+};
+
+union ECCTL1_REG {
+   Uint16              all;
+   struct ECCTL1_BITS  bit;
+};
+
+
+// In V1.1 the STOPVALUE bit field was changed to 
+// STOP_WRAP.  This correlated to a silicon change from
+// F2833x Rev 0 to Rev A. 
+//----------------------------------------------------
+// Capture control register 2 bit definitions */                                    
+struct ECCTL2_BITS {          // bits   description
+   Uint16 CONT_ONESHT:1;      // 0      Continuous or one-shot
+   Uint16 STOP_WRAP:2;        // 2:1    Stop value for one-shot, Wrap for continuous
+   Uint16 REARM:1;            // 3      One-shot re-arm
+   Uint16 TSCTRSTOP:1;        // 4      TSCNT counter stop
+   Uint16 SYNCI_EN:1;         // 5      Counter sync-in select
+   Uint16 SYNCO_SEL:2;        // 7:6    Sync-out mode
+   Uint16 SWSYNC:1;           // 8      SW forced counter sync
+   Uint16 CAP_APWM:1;         // 9      CAP/APWM operating mode select
+   Uint16 APWMPOL:1;          // 10     APWM output polarity select
+   Uint16 rsvd1:5;            // 15:11  
+};
+
+
+union ECCTL2_REG {
+   Uint16              all;
+   struct ECCTL2_BITS  bit;
+};
+
+
+//----------------------------------------------------
+// ECAP interrupt enable register bit definitions */                                    
+struct ECEINT_BITS {          // bits   description
+   Uint16 rsvd1:1;            // 0      reserved
+   Uint16 CEVT1:1;            // 1      Capture Event 1 Interrupt Enable
+   Uint16 CEVT2:1;            // 2      Capture Event 2 Interrupt Enable
+   Uint16 CEVT3:1;            // 3      Capture Event 3 Interrupt Enable
+   Uint16 CEVT4:1;            // 4      Capture Event 4 Interrupt Enable         
+   Uint16 CTROVF:1;           // 5      Counter Overflow Interrupt Enable
+   Uint16 CTR_EQ_PRD:1;       // 6      Period Equal Interrupt Enable
+   Uint16 CTR_EQ_CMP:1;       // 7      Compare Equal Interrupt Enable
+   Uint16 rsvd2:8;            // 15:8   reserved
+};
+
+
+union ECEINT_REG {
+   Uint16              all;
+   struct ECEINT_BITS  bit;
+};
+
+//----------------------------------------------------
+// ECAP interrupt flag register bit definitions */                                    
+struct ECFLG_BITS {           // bits   description
+   Uint16 INT:1;              // 0      Global Flag
+   Uint16 CEVT1:1;            // 1      Capture Event 1 Interrupt Flag
+   Uint16 CEVT2:1;            // 2      Capture Event 2 Interrupt Flag
+   Uint16 CEVT3:1;            // 3      Capture Event 3 Interrupt Flag
+   Uint16 CEVT4:1;            // 4      Capture Event 4 Interrupt Flag         
+   Uint16 CTROVF:1;           // 5      Counter Overflow Interrupt Flag
+   Uint16 CTR_EQ_PRD:1;       // 6      Period Equal Interrupt Flag
+   Uint16 CTR_EQ_CMP:1;       // 7      Compare Equal Interrupt Flag
+   Uint16 rsvd2:8;            // 15:8   reserved
+};
+
+
+union ECFLG_REG {
+   Uint16              all;
+   struct ECFLG_BITS   bit;
+};
+
+
+//----------------------------------------------------
+
+struct ECAP_REGS {
+   Uint32              TSCTR;    // Time stamp counter 
+   Uint32              CTRPHS;   // Counter phase
+   Uint32              CAP1;     // Capture 1 
+   Uint32              CAP2;     // Capture 2    
+   Uint32              CAP3;     // Capture 3 
+   Uint32              CAP4;     // Capture 4   
+   Uint16              rsvd1[8]; // reserved
+   union   ECCTL1_REG  ECCTL1;   // Capture Control Reg 1
+   union   ECCTL2_REG  ECCTL2;   // Capture Control Reg 2
+   union   ECEINT_REG  ECEINT;   // ECAP interrupt enable
+   union   ECFLG_REG   ECFLG;    // ECAP interrupt flags
+   union   ECFLG_REG   ECCLR;    // ECAP interrupt clear
+   union   ECEINT_REG  ECFRC;    // ECAP interrupt force
+   Uint16              rsvd2[6]; // reserved   
+};
+
+    
+ 
+
+//---------------------------------------------------------------------------
+// GPI/O External References & Function Declarations:
+//
+extern struct ECAP_REGS ECap1Regs;
+extern struct ECAP_REGS ECap2Regs;
+extern struct ECAP_REGS ECap3Regs;
+extern struct ECAP_REGS ECap4Regs;
+extern struct ECAP_REGS ECap5Regs;
+extern struct ECAP_REGS ECap6Regs;
+
+
+#endif  // end of DSP2833x_ECAP_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_EPwm.h b/Inu/main_matlab/device_support/include/DSP2833x_EPwm.h
new file mode 100644
index 0000000..c3fa4d6
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_EPwm.h
@@ -0,0 +1,424 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:52:10 $
+//###########################################################################
+//
+// FILE:   DSP2833x_EPwm.h
+//
+// TITLE:  DSP2833x Enhanced PWM Module Register Bit Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_EPWM_H
+#define DSP2833x_EPWM_H
+
+
+//----------------------------------------------------
+// Time base control register bit definitions */                                    
+struct TBCTL_BITS {          // bits   description
+   Uint16 CTRMODE:2;         // 1:0    Counter Mode
+   Uint16 PHSEN:1;           // 2      Phase load enable
+   Uint16 PRDLD:1;           // 3      Active period load
+   Uint16 SYNCOSEL:2;        // 5:4    Sync output select
+   Uint16 SWFSYNC:1;         // 6      Software force sync pulse
+   Uint16 HSPCLKDIV:3;       // 9:7    High speed time pre-scale
+   Uint16 CLKDIV:3;          // 12:10  Timebase clock pre-scale
+   Uint16 PHSDIR:1;          // 13     Phase Direction
+   Uint16 FREE_SOFT:2;       // 15:14  Emulation mode 
+};
+
+union TBCTL_REG {
+   Uint16              all;
+   struct TBCTL_BITS   bit;
+};
+
+//----------------------------------------------------
+// Time base status register bit definitions */                                    
+struct TBSTS_BITS {          // bits   description
+   Uint16 CTRDIR:1;          // 0      Counter direction status
+   Uint16 SYNCI:1;           // 1      External input sync status
+   Uint16 CTRMAX:1;          // 2      Counter max latched status
+   Uint16 rsvd1:13;          // 15:3   reserved
+};
+
+union TBSTS_REG {
+   Uint16              all;
+   struct TBSTS_BITS   bit;
+};
+
+//----------------------------------------------------
+// Compare control register bit definitions */                                    
+struct CMPCTL_BITS {          // bits   description
+   Uint16 LOADAMODE:2;        // 0:1    Active compare A
+   Uint16 LOADBMODE:2;        // 3:2    Active compare B
+   Uint16 SHDWAMODE:1;        // 4      Compare A block operating mode
+   Uint16 rsvd1:1;            // 5      reserved
+   Uint16 SHDWBMODE:1;        // 6      Compare B block operating mode
+   Uint16 rsvd2:1;            // 7      reserved
+   Uint16 SHDWAFULL:1;        // 8      Compare A Shadow registers full Status
+   Uint16 SHDWBFULL:1;        // 9      Compare B Shadow registers full Status
+   Uint16 rsvd3:6;            // 15:10  reserved
+};
+
+
+union CMPCTL_REG {
+   Uint16                all;
+   struct CMPCTL_BITS    bit;
+};
+
+//----------------------------------------------------
+// Action qualifier register bit definitions */                                    
+struct AQCTL_BITS {           // bits   description
+   Uint16 ZRO:2;              // 1:0    Action Counter = Zero
+   Uint16 PRD:2;              // 3:2    Action Counter = Period
+   Uint16 CAU:2;              // 5:4    Action Counter = Compare A up
+   Uint16 CAD:2;              // 7:6    Action Counter = Compare A down
+   Uint16 CBU:2;              // 9:8    Action Counter = Compare B up
+   Uint16 CBD:2;              // 11:10  Action Counter = Compare B down
+   Uint16 rsvd:4;             // 15:12  reserved
+};
+
+union AQCTL_REG {
+   Uint16                all;
+   struct AQCTL_BITS     bit;
+};
+
+//----------------------------------------------------
+// Action qualifier SW force register bit definitions */                                    
+struct AQSFRC_BITS {           // bits   description
+   Uint16 ACTSFA:2;            // 1:0    Action when One-time SW Force A invoked
+   Uint16 OTSFA:1;             // 2      One-time SW Force A output
+   Uint16 ACTSFB:2;            // 4:3    Action when One-time SW Force B invoked
+   Uint16 OTSFB:1;             // 5      One-time SW Force A output
+   Uint16 RLDCSF:2;            // 7:6    Reload from Shadow options
+   Uint16 rsvd1:8;             // 15:8   reserved
+};
+
+union AQSFRC_REG {
+   Uint16                 all;
+   struct AQSFRC_BITS     bit;
+};
+
+//----------------------------------------------------
+// Action qualifier continuous SW force register bit definitions */                                    
+struct AQCSFRC_BITS {          // bits   description
+   Uint16 CSFA:2;              // 1:0    Continuous Software Force on output A
+   Uint16 CSFB:2;              // 3:2    Continuous Software Force on output B
+   Uint16 rsvd1:12;            // 15:4   reserved
+};
+
+union AQCSFRC_REG {
+   Uint16                  all;
+   struct AQCSFRC_BITS     bit;
+};
+
+
+// As of version 1.1
+// Changed the MODE bit-field to OUT_MODE
+// Added the bit-field IN_MODE
+// This corresponds to changes in silicon as of F2833x devices
+// Rev A silicon.
+//----------------------------------------------------
+// Dead-band generator control register bit definitions                                    
+struct DBCTL_BITS {          // bits   description
+   Uint16 OUT_MODE:2;      	 // 1:0    Dead Band Output Mode Control 
+   Uint16 POLSEL:2;          // 3:2    Polarity Select Control 
+   Uint16 IN_MODE:2;         // 5:4    Dead Band Input Select Mode Control
+   Uint16 rsvd1:10;          // 15:4   reserved
+};
+
+union DBCTL_REG {
+   Uint16                  all;
+   struct DBCTL_BITS       bit;
+};
+
+
+//----------------------------------------------------
+// Trip zone select register bit definitions                                   
+struct TZSEL_BITS {           // bits   description
+   Uint16  CBC1:1;            // 0      TZ1 CBC select
+   Uint16  CBC2:1;            // 1      TZ2 CBC select
+   Uint16  CBC3:1;            // 2      TZ3 CBC select
+   Uint16  CBC4:1;            // 3      TZ4 CBC select
+   Uint16  CBC5:1;            // 4      TZ5 CBC select
+   Uint16  CBC6:1;            // 5      TZ6 CBC select
+   Uint16  rsvd1:2;           // 7:6    reserved
+   Uint16  OSHT1:1;           // 8      One-shot TZ1 select             
+   Uint16  OSHT2:1;           // 9      One-shot TZ2 select             
+   Uint16  OSHT3:1;           // 10     One-shot TZ3 select             
+   Uint16  OSHT4:1;           // 11     One-shot TZ4 select             
+   Uint16  OSHT5:1;           // 12     One-shot TZ5 select             
+   Uint16  OSHT6:1;           // 13     One-shot TZ6 select             
+   Uint16  rsvd2:2;           // 15:14  reserved
+};
+
+union TZSEL_REG {
+   Uint16                  all;
+   struct TZSEL_BITS       bit;
+};
+
+
+//----------------------------------------------------
+// Trip zone control register bit definitions */                                    
+struct TZCTL_BITS {         // bits   description
+   Uint16 TZA:2;            // 1:0    TZ1 to TZ6 Trip Action On EPWMxA
+   Uint16 TZB:2;            // 3:2    TZ1 to TZ6 Trip Action On EPWMxB
+   Uint16 rsvd:12;          // 15:4   reserved
+};
+
+union TZCTL_REG {
+   Uint16                  all;
+   struct TZCTL_BITS       bit;
+};
+
+
+//----------------------------------------------------
+// Trip zone control register bit definitions */                                    
+struct TZEINT_BITS {         // bits   description
+   Uint16  rsvd1:1;          // 0      reserved
+   Uint16  CBC:1;            // 1      Trip Zones Cycle By Cycle Int Enable
+   Uint16  OST:1;            // 2      Trip Zones One Shot Int Enable
+   Uint16  rsvd2:13;         // 15:3   reserved
+};   
+
+
+union TZEINT_REG {
+   Uint16                  all;
+   struct TZEINT_BITS      bit;
+};
+
+
+//----------------------------------------------------
+// Trip zone flag register bit definitions */                                    
+struct TZFLG_BITS {         // bits   description
+   Uint16  INT:1;           // 0      Global status
+   Uint16  CBC:1;           // 1      Trip Zones Cycle By Cycle Int
+   Uint16  OST:1;           // 2      Trip Zones One Shot Int
+   Uint16  rsvd2:13;        // 15:3   reserved
+};
+
+union TZFLG_REG {
+   Uint16                  all;
+   struct TZFLG_BITS       bit;
+};
+
+//----------------------------------------------------
+// Trip zone flag clear register bit definitions */                                    
+struct TZCLR_BITS {         // bits   description
+   Uint16  INT:1;           // 0      Global status
+   Uint16  CBC:1;           // 1      Trip Zones Cycle By Cycle Int
+   Uint16  OST:1;           // 2      Trip Zones One Shot Int
+   Uint16  rsvd2:13;        // 15:3   reserved
+};
+
+union TZCLR_REG {
+   Uint16                  all;
+   struct TZCLR_BITS       bit;
+};
+
+//----------------------------------------------------
+// Trip zone flag force register bit definitions */                                    
+struct TZFRC_BITS {         // bits   description
+   Uint16  rsvd1:1;         // 0      reserved
+   Uint16  CBC:1;           // 1      Trip Zones Cycle By Cycle Int
+   Uint16  OST:1;           // 2      Trip Zones One Shot Int
+   Uint16  rsvd2:13;        // 15:3   reserved
+};
+
+union TZFRC_REG {
+   Uint16                  all;
+   struct TZFRC_BITS       bit;
+};
+
+//----------------------------------------------------
+// Event trigger select register bit definitions */                                    
+struct ETSEL_BITS {         // bits   description
+   Uint16  INTSEL:3;        // 2:0    EPWMxINTn Select
+   Uint16  INTEN:1;         // 3      EPWMxINTn Enable
+   Uint16  rsvd1:4;         // 7:4    reserved
+   Uint16  SOCASEL:3;       // 10:8   Start of conversion A Select
+   Uint16  SOCAEN:1;        // 11     Start of conversion A Enable
+   Uint16  SOCBSEL:3;       // 14:12  Start of conversion B Select
+   Uint16  SOCBEN:1;        // 15     Start of conversion B Enable
+};
+
+union ETSEL_REG {
+   Uint16                  all;
+   struct ETSEL_BITS       bit;
+};
+
+
+//----------------------------------------------------
+// Event trigger pre-scale register bit definitions */                                    
+struct ETPS_BITS {         // bits   description
+   Uint16  INTPRD:2;       // 1:0    EPWMxINTn Period Select
+   Uint16  INTCNT:2;       // 3:2    EPWMxINTn Counter Register
+   Uint16  rsvd1:4;        // 7:4    reserved
+   Uint16  SOCAPRD:2;      // 9:8    EPWMxSOCA Period Select
+   Uint16  SOCACNT:2;      // 11:10  EPWMxSOCA Counter Register
+   Uint16  SOCBPRD:2;      // 13:12  EPWMxSOCB Period Select
+   Uint16  SOCBCNT:2;      // 15:14  EPWMxSOCB Counter Register
+};
+
+union ETPS_REG {
+   Uint16                  all;
+   struct ETPS_BITS        bit;
+};
+
+//----------------------------------------------------
+// Event trigger Flag register bit definitions */                                    
+struct ETFLG_BITS {         // bits   description
+   Uint16  INT:1;           // 0	EPWMxINTn Flag
+   Uint16  rsvd1:1;         // 1	reserved
+   Uint16  SOCA:1;          // 2	EPWMxSOCA Flag
+   Uint16  SOCB:1;          // 3	EPWMxSOCB Flag
+   Uint16  rsvd2:12;        // 15:4	reserved
+};
+
+union ETFLG_REG {
+   Uint16                   all;
+   struct ETFLG_BITS        bit;
+};
+
+
+//----------------------------------------------------
+// Event trigger Clear register bit definitions */                                    
+struct ETCLR_BITS {         // bits   description
+   Uint16  INT:1;           // 0	EPWMxINTn Clear
+   Uint16  rsvd1:1;         // 1	reserved
+   Uint16  SOCA:1;          // 2	EPWMxSOCA Clear
+   Uint16  SOCB:1;          // 3	EPWMxSOCB Clear
+   Uint16  rsvd2:12;        // 15:4	reserved
+};
+
+union ETCLR_REG {
+   Uint16                   all;
+   struct ETCLR_BITS        bit;
+};
+
+//----------------------------------------------------
+// Event trigger Force register bit definitions */                                    
+struct ETFRC_BITS {         // bits   description
+   Uint16  INT:1;           // 0	EPWMxINTn Force
+   Uint16  rsvd1:1;         // 1	reserved
+   Uint16  SOCA:1;          // 2	EPWMxSOCA Force
+   Uint16  SOCB:1;          // 3	EPWMxSOCB Force
+   Uint16  rsvd2:12;        // 15:4	reserved
+};
+
+union ETFRC_REG {
+   Uint16                  all;
+   struct ETFRC_BITS        bit;
+};
+//----------------------------------------------------
+// PWM chopper control register bit definitions */                                    
+struct PCCTL_BITS {         // bits   description
+   Uint16  CHPEN:1;         // 0      PWM chopping enable
+   Uint16  OSHTWTH:4;       // 4:1    One-shot pulse width
+   Uint16  CHPFREQ:3;       // 7:5    Chopping clock frequency
+   Uint16  CHPDUTY:3;       // 10:8   Chopping clock Duty cycle
+   Uint16  rsvd1:5;         // 15:11  reserved
+};
+
+
+union PCCTL_REG {
+   Uint16                  all;
+   struct PCCTL_BITS       bit;
+};
+
+struct HRCNFG_BITS {       	// bits   description
+   Uint16  EDGMODE:2;     	// 1:0    Edge Mode select Bits
+   Uint16  CTLMODE:1;     	// 2      Control mode Select Bit
+   Uint16  HRLOAD:1;      	// 3      Shadow mode Select Bit
+   Uint16  rsvd1:12;      	// 15:4   reserved
+};
+
+union HRCNFG_REG {
+   Uint16                  	all;
+   struct HRCNFG_BITS       bit;
+};
+
+
+struct TBPHS_HRPWM_REG {   	// bits   description
+   Uint16  TBPHSHR;     	// 15:0   Extension register for HRPWM Phase (8 bits)
+   Uint16  TBPHS;           // 31:16  Phase offset register
+};
+
+union TBPHS_HRPWM_GROUP {
+   Uint32                  all;
+   struct TBPHS_HRPWM_REG  half;
+};
+
+struct CMPA_HRPWM_REG {   	// bits   description
+   Uint16  CMPAHR;     	    // 15:0   Extension register for HRPWM compare (8 bits)
+   Uint16  CMPA;            // 31:16  Compare A reg
+};
+
+union CMPA_HRPWM_GROUP {
+   Uint32                 all;
+   struct CMPA_HRPWM_REG  half;
+};
+
+
+struct EPWM_REGS {
+   union  TBCTL_REG           TBCTL;   // 
+   union  TBSTS_REG           TBSTS;   // 
+   union  TBPHS_HRPWM_GROUP   TBPHS;   // Union of TBPHS:TBPHSHR
+   Uint16                     TBCTR;   // Counter
+   Uint16                     TBPRD;   // Period register set 
+   Uint16                     rsvd1;   // 
+   union  CMPCTL_REG          CMPCTL;  // Compare control
+   union  CMPA_HRPWM_GROUP    CMPA;    // Union of CMPA:CMPAHR
+   Uint16                     CMPB;    // Compare B reg
+   union  AQCTL_REG           AQCTLA;  // Action qual output A
+   union  AQCTL_REG           AQCTLB;  // Action qual output B
+   union  AQSFRC_REG          AQSFRC;  // Action qual SW force
+   union  AQCSFRC_REG         AQCSFRC; // Action qualifier continuous SW force 
+   union  DBCTL_REG           DBCTL;   // Dead-band control
+   Uint16                     DBRED;   // Dead-band rising edge delay
+   Uint16                     DBFED;   // Dead-band falling edge delay
+   union  TZSEL_REG           TZSEL;   // Trip zone select
+   Uint16                     rsvd2;   
+   union  TZCTL_REG           TZCTL;   // Trip zone control
+   union  TZEINT_REG          TZEINT;  // Trip zone interrupt enable
+   union  TZFLG_REG           TZFLG;   // Trip zone interrupt flags
+   union  TZCLR_REG           TZCLR;   // Trip zone clear   
+   union  TZFRC_REG    	      TZFRC;   // Trip zone force interrupt
+   union  ETSEL_REG           ETSEL;   // Event trigger selection
+   union  ETPS_REG            ETPS;    // Event trigger pre-scaler
+   union  ETFLG_REG           ETFLG;   // Event trigger flags
+   union  ETCLR_REG           ETCLR;   // Event trigger clear   
+   union  ETFRC_REG           ETFRC;   // Event trigger force
+   union  PCCTL_REG           PCCTL;   // PWM chopper control
+   Uint16                     rsvd3;   // 
+   union  HRCNFG_REG          HRCNFG;  // HRPWM Config Reg
+};
+    
+ 
+
+//---------------------------------------------------------------------------
+// External References & Function Declarations:
+//
+extern struct EPWM_REGS EPwm1Regs;
+extern struct EPWM_REGS EPwm2Regs;
+extern struct EPWM_REGS EPwm3Regs;
+extern struct EPWM_REGS EPwm4Regs;
+extern struct EPWM_REGS EPwm5Regs;
+extern struct EPWM_REGS EPwm6Regs;
+
+extern struct EPWM_REGS EPwm7Regs;
+extern struct EPWM_REGS EPwm8Regs;
+extern struct EPWM_REGS EPwm9Regs;
+extern struct EPWM_REGS EPwm10Regs;
+extern struct EPWM_REGS EPwm11Regs;
+extern struct EPWM_REGS EPwm12Regs;
+
+
+#endif  // end of DSP2833x_EPWM_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_EQep.h b/Inu/main_matlab/device_support/include/DSP2833x_EQep.h
new file mode 100644
index 0000000..3bf71f4
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_EQep.h
@@ -0,0 +1,236 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:52:13 $
+//###########################################################################
+//
+// FILE:   DSP2833x_EQep.h
+//
+// TITLE:  DSP2833x Enhanced Quadrature Encoder Pulse Module 
+//         Register Bit Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_EQEP_H
+#define DSP2833x_EQEP_H
+
+
+
+//----------------------------------------------------
+// Capture decoder control register bit definitions */                                    
+struct QDECCTL_BITS {         // bits   description
+   Uint16 rsvd1:5;            // 4:0    reserved
+   Uint16 QSP:1;              // 5      QEPS input polarity
+   Uint16 QIP:1;              // 6      QEPI input polarity
+   Uint16 QBP:1;              // 7      QEPB input polarity
+   Uint16 QAP:1;              // 8      QEPA input polarity
+   Uint16 IGATE:1;            // 9      Index pulse gating option
+   Uint16 SWAP:1;             // 10     CLK/DIR signal source for Position Counter
+   Uint16 XCR:1;              // 11     External clock rate
+   Uint16 SPSEL:1;            // 12     Sync output pin select
+   Uint16 SOEN:1;             // 13     Enable position compare sync
+   Uint16 QSRC:2;             // 15:14  Position counter source
+};
+
+union QDECCTL_REG {
+   Uint16              all;
+   struct QDECCTL_BITS   bit;
+};
+
+
+//----------------------------------------------------
+// QEP control register bit definitions */                                    
+struct QEPCTL_BITS {           // bits   description
+   Uint16 WDE:1;               // 0      QEP watchdog enable
+   Uint16 UTE:1;               // 1      QEP unit timer enable
+   Uint16 QCLM:1;              // 2      QEP capture latch mode
+   Uint16 QPEN:1;              // 3      Quadrature position counter enable
+   Uint16 IEL:2;               // 5:4    Index event latch
+   Uint16 SEL:1;               // 6      Strobe event latch
+   Uint16 SWI:1;               // 7      Software init position counter
+   Uint16 IEI:2;               // 9:8    Index event init of position count
+   Uint16 SEI:2;               // 11:10  Strobe event init
+   Uint16 PCRM:2;              // 13:12  Position counter reset
+   Uint16 FREE_SOFT:2;         // 15:14  Emulation mode
+};
+
+union QEPCTL_REG {
+   Uint16               all;
+   struct QEPCTL_BITS   bit;
+};         
+
+
+//----------------------------------------------------
+// Quadrature capture control register bit definitions */                                    
+struct QCAPCTL_BITS {          // bits   description
+   Uint16 UPPS:4;              // 3:0    Unit position pre-scale         
+   Uint16 CCPS:3;              // 6:4    QEP capture timer pre-scale
+   Uint16 rsvd1:8;             // 14:7   reserved
+   Uint16 CEN:1;               // 15     Enable QEP capture
+};
+
+
+union QCAPCTL_REG {
+   Uint16               all;
+   struct QCAPCTL_BITS  bit;
+}; 
+
+
+
+//----------------------------------------------------
+// Position compare control register bit definitions */                                    
+struct QPOSCTL_BITS {          // bits   description
+   Uint16 PCSPW:12;            // 11:0   Position compare sync pulse width
+   Uint16 PCE:1;               // 12     Position compare enable/disable
+   Uint16 PCPOL:1;             // 13     Polarity of sync output
+   Uint16 PCLOAD:1;            // 14     Position compare of shadow load
+   Uint16 PCSHDW:1;            // 15     Position compare shadow enable
+};
+
+union QPOSCTL_REG {
+   Uint16               all;
+   struct QPOSCTL_BITS  bit;
+};         
+
+//----------------------------------------------------
+// QEP interrupt control register bit definitions */                                    
+struct QEINT_BITS {          // bits   description
+   Uint16 rsvd1:1;           // 0      reserved
+   Uint16 PCE:1;             // 1      Position counter error
+   Uint16 QPE:1;             // 2      Quadrature phase error
+   Uint16 QDC:1;             // 3      Quadrature dir change
+   Uint16 WTO:1;             // 4      Watchdog timeout
+   Uint16 PCU:1;             // 5      Position counter underflow
+   Uint16 PCO:1;             // 6      Position counter overflow
+   Uint16 PCR:1;             // 7      Position compare ready
+   Uint16 PCM:1;             // 8      Position compare match
+   Uint16 SEL:1;             // 9      Strobe event latch
+   Uint16 IEL:1;             // 10     Event latch
+   Uint16 UTO:1;             // 11     Unit timeout
+   Uint16 rsvd2:4;           // 15:12  reserved
+};
+
+
+union QEINT_REG {
+   Uint16               all;
+   struct QEINT_BITS    bit;
+};
+
+
+//----------------------------------------------------
+// QEP interrupt status register bit definitions */                                    
+struct QFLG_BITS {          // bits   description
+   Uint16 INT:1;            // 0      Global interrupt 
+   Uint16 PCE:1;            // 1      Position counter error
+   Uint16 PHE:1;            // 2      Quadrature phase error
+   Uint16 QDC:1;            // 3      Quadrature dir change
+   Uint16 WTO:1;            // 4      Watchdog timeout
+   Uint16 PCU:1;            // 5      Position counter underflow
+   Uint16 PCO:1;            // 6      Position counter overflow
+   Uint16 PCR:1;            // 7      Position compare ready
+   Uint16 PCM:1;            // 8      Position compare match
+   Uint16 SEL:1;            // 9      Strobe event latch
+   Uint16 IEL:1;            // 10     Event latch
+   Uint16 UTO:1;            // 11     Unit timeout
+   Uint16 rsvd2:4;          // 15:12  reserved
+};
+
+
+union QFLG_REG {
+   Uint16               all;
+   struct QFLG_BITS     bit;
+};
+
+//----------------------------------------------------
+// QEP interrupt force register bit definitions */                                    
+struct QFRC_BITS {          // bits   description
+   Uint16 reserved:1;       // 0      Reserved
+   Uint16 PCE:1;            // 1      Position counter error
+   Uint16 PHE:1;            // 2      Quadrature phase error
+   Uint16 QDC:1;            // 3      Quadrature dir change
+   Uint16 WTO:1;            // 4      Watchdog timeout
+   Uint16 PCU:1;            // 5      Position counter underflow
+   Uint16 PCO:1;            // 6      Position counter overflow
+   Uint16 PCR:1;            // 7      Position compare ready
+   Uint16 PCM:1;            // 8      Position compare match
+   Uint16 SEL:1;            // 9      Strobe event latch
+   Uint16 IEL:1;            // 10     Event latch
+   Uint16 UTO:1;            // 11     Unit timeout
+   Uint16 rsvd2:4;          // 15:12  reserved
+};
+
+
+union QFRC_REG {
+   Uint16               all;
+   struct QFRC_BITS     bit;
+};
+
+// V1.1 Added UPEVNT (bit 7) This reflects changes 
+// made as of F2833x Rev A devices
+//----------------------------------------------------
+// QEP status register bit definitions */                                    
+struct QEPSTS_BITS {          // bits   description
+   Uint16 PCEF:1;             // 0      Position counter error
+   Uint16 FIMF:1;             // 1      First index marker
+   Uint16 CDEF:1;             // 2      Capture direction error
+   Uint16 COEF:1;             // 3      Capture overflow error
+   Uint16 QDLF:1;             // 4      QEP direction latch
+   Uint16 QDF:1;              // 5      Quadrature direction
+   Uint16 FIDF:1;             // 6      Direction on first index marker
+   Uint16 UPEVNT:1;           // 7      Unit position event flag
+   Uint16 rsvd1:8;            // 15:8   reserved
+};
+
+union QEPSTS_REG {
+   Uint16               all;
+   struct QEPSTS_BITS   bit;
+};
+
+//----------------------------------------------------
+
+struct EQEP_REGS {
+   Uint32              QPOSCNT;   // Position counter 
+   Uint32              QPOSINIT;  // Position counter init
+   Uint32              QPOSMAX;   // Maximum position count
+   Uint32              QPOSCMP;   // Position compare
+   Uint32              QPOSILAT;  // Index position latch
+   Uint32              QPOSSLAT;  // Strobe position latch
+   Uint32              QPOSLAT;   // Position latch
+   Uint32              QUTMR;     // Unit timer
+   Uint32              QUPRD;     // Unit period
+   Uint16              QWDTMR;    // QEP watchdog timer
+   Uint16              QWDPRD;    // QEP watchdog period
+   union  QDECCTL_REG  QDECCTL;   // Quadrature decoder control
+   union  QEPCTL_REG   QEPCTL;    // QEP control 
+   union  QCAPCTL_REG  QCAPCTL;   // Quadrature capture control     
+   union  QPOSCTL_REG  QPOSCTL;   // Position compare control
+   union  QEINT_REG    QEINT;     // QEP interrupt control        
+   union  QFLG_REG     QFLG;      // QEP interrupt flag
+   union  QFLG_REG     QCLR;      // QEP interrupt clear                   
+   union  QFRC_REG     QFRC;      // QEP interrupt force                   
+   union  QEPSTS_REG   QEPSTS;    // QEP status
+   Uint16              QCTMR;     // QEP capture timer
+   Uint16              QCPRD;     // QEP capture period
+   Uint16              QCTMRLAT;  // QEP capture latch
+   Uint16              QCPRDLAT;  // QEP capture period latch
+   Uint16              rsvd1[30]; // reserved
+};
+
+    
+ 
+
+//---------------------------------------------------------------------------
+// GPI/O External References & Function Declarations:
+//
+extern struct EQEP_REGS EQep1Regs;
+extern struct EQEP_REGS EQep2Regs;
+
+
+
+#endif  // end of DSP2833x_EQEP_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Gpio.h b/Inu/main_matlab/device_support/include/DSP2833x_Gpio.h
new file mode 100644
index 0000000..8584011
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Gpio.h
@@ -0,0 +1,385 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: November 15, 2007   09:58:53 $
+//###########################################################################
+//
+// FILE:   DSP2833x_Gpio.h
+//
+// TITLE:  DSP2833x General Purpose I/O Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_GPIO_H
+#define DSP2833x_GPIO_H
+
+
+
+//----------------------------------------------------
+// GPIO A control register bit definitions */
+struct GPACTRL_BITS {        // bits   description
+   Uint16 QUALPRD0:8;        // 7:0    Qual period
+   Uint16 QUALPRD1:8;        // 15:8   Qual period
+   Uint16 QUALPRD2:8;        // 23:16  Qual period
+   Uint16 QUALPRD3:8;        // 31:24  Qual period
+};
+
+union GPACTRL_REG {
+   Uint32              all;
+   struct GPACTRL_BITS bit;
+};
+
+//----------------------------------------------------
+// GPIO B control register bit definitions */
+struct GPBCTRL_BITS {        // bits   description
+   Uint16 QUALPRD0:8;        // 7:0    Qual period
+   Uint16 QUALPRD1:8;        // 15:8   Qual period
+   Uint16 QUALPRD2:8;        // 23:16  Qual period
+   Uint16 QUALPRD3:8;        // 31:24
+};
+
+union GPBCTRL_REG {
+   Uint32              all;
+   struct GPBCTRL_BITS bit;
+};
+
+//----------------------------------------------------
+// GPIO A Qual/MUX select register bit definitions */
+struct GPA1_BITS {            // bits   description
+   Uint16 GPIO0:2;            // 1:0    GPIO0
+   Uint16 GPIO1:2;            // 3:2    GPIO1
+   Uint16 GPIO2:2;            // 5:4    GPIO2
+   Uint16 GPIO3:2;            // 7:6    GPIO3
+   Uint16 GPIO4:2;            // 9:8    GPIO4
+   Uint16 GPIO5:2;            // 11:10  GPIO5
+   Uint16 GPIO6:2;            // 13:12  GPIO6
+   Uint16 GPIO7:2;            // 15:14  GPIO7
+   Uint16 GPIO8:2;            // 17:16  GPIO8
+   Uint16 GPIO9:2;            // 19:18  GPIO9
+   Uint16 GPIO10:2;           // 21:20  GPIO10
+   Uint16 GPIO11:2;           // 23:22  GPIO11
+   Uint16 GPIO12:2;           // 25:24  GPIO12
+   Uint16 GPIO13:2;           // 27:26  GPIO13
+   Uint16 GPIO14:2;           // 29:28  GPIO14
+   Uint16 GPIO15:2;           // 31:30  GPIO15
+};
+
+
+struct GPA2_BITS {            // bits   description
+   Uint16 GPIO16:2;           // 1:0    GPIO16
+   Uint16 GPIO17:2;           // 3:2    GPIO17
+   Uint16 GPIO18:2;           // 5:4    GPIO18
+   Uint16 GPIO19:2;           // 7:6    GPIO19
+   Uint16 GPIO20:2;           // 9:8    GPIO20
+   Uint16 GPIO21:2;           // 11:10  GPIO21
+   Uint16 GPIO22:2;           // 13:12  GPIO22
+   Uint16 GPIO23:2;           // 15:14  GPIO23
+   Uint16 GPIO24:2;           // 17:16  GPIO24
+   Uint16 GPIO25:2;           // 19:18  GPIO25
+   Uint16 GPIO26:2;           // 21:20  GPIO26
+   Uint16 GPIO27:2;           // 23:22  GPIO27
+   Uint16 GPIO28:2;           // 25:24  GPIO28
+   Uint16 GPIO29:2;           // 27:26  GPIO29
+   Uint16 GPIO30:2;           // 29:28  GPIO30
+   Uint16 GPIO31:2;           // 31:30  GPIO31
+};
+
+struct GPB1_BITS {            // bits   description
+   Uint16 GPIO32:2;           // 1:0    GPIO32
+   Uint16 GPIO33:2;           // 3:2    GPIO33
+   Uint16 GPIO34:2;           // 5:4    GPIO34
+   Uint16 GPIO35:2;           // 7:6    GPIO35
+   Uint16 GPIO36:2;           // 9:8    GPIO36
+   Uint16 GPIO37:2;           // 11:10  GPIO37
+   Uint16 GPIO38:2;           // 13:12  GPIO38
+   Uint16 GPIO39:2;           // 15:14  GPIO39
+   Uint16 GPIO40:2;           // 17:16  GPIO40
+   Uint16 GPIO41:2;           // 19:16  GPIO41
+   Uint16 GPIO42:2;           // 21:20  GPIO42
+   Uint16 GPIO43:2;           // 23:22  GPIO43
+   Uint16 GPIO44:2;           // 25:24  GPIO44
+   Uint16 GPIO45:2;           // 27:26  GPIO45
+   Uint16 GPIO46:2;           // 29:28  GPIO46
+   Uint16 GPIO47:2;           // 31:30  GPIO47
+};
+
+struct GPB2_BITS  {           // bits   description
+   Uint16 GPIO48:2;           // 1:0    GPIO48
+   Uint16 GPIO49:2;           // 3:2    GPIO49
+   Uint16 GPIO50:2;           // 5:4    GPIO50
+   Uint16 GPIO51:2;           // 7:6    GPIO51
+   Uint16 GPIO52:2;           // 9:8    GPIO52
+   Uint16 GPIO53:2;           // 11:10  GPIO53
+   Uint16 GPIO54:2;           // 13:12  GPIO54
+   Uint16 GPIO55:2;           // 15:14  GPIO55
+   Uint16 GPIO56:2;           // 17:16  GPIO56
+   Uint16 GPIO57:2;           // 19:18  GPIO57
+   Uint16 GPIO58:2;           // 21:20  GPIO58
+   Uint16 GPIO59:2;           // 23:22  GPIO59
+   Uint16 GPIO60:2;           // 25:24  GPIO60
+   Uint16 GPIO61:2;           // 27:26  GPIO61
+   Uint16 GPIO62:2;           // 29:28  GPIO62
+   Uint16 GPIO63:2;           // 31:30  GPIO63
+};
+
+struct GPC1_BITS {            // bits   description
+   Uint16 GPIO64:2;           // 1:0    GPIO64
+   Uint16 GPIO65:2;           // 3:2    GPIO65
+   Uint16 GPIO66:2;           // 5:4    GPIO66
+   Uint16 GPIO67:2;           // 7:6    GPIO67
+   Uint16 GPIO68:2;           // 9:8    GPIO68
+   Uint16 GPIO69:2;           // 11:10  GPIO69
+   Uint16 GPIO70:2;           // 13:12  GPIO70
+   Uint16 GPIO71:2;           // 15:14  GPIO71
+   Uint16 GPIO72:2;           // 17:16  GPIO72
+   Uint16 GPIO73:2;           // 19:18  GPIO73
+   Uint16 GPIO74:2;           // 21:20  GPIO74
+   Uint16 GPIO75:2;           // 23:22  GPIO75
+   Uint16 GPIO76:2;           // 25:24  GPIO76
+   Uint16 GPIO77:2;           // 27:26  GPIO77
+   Uint16 GPIO78:2;           // 29:28  GPIO78
+   Uint16 GPIO79:2;           // 31:30  GPIO79
+};
+
+
+struct GPC2_BITS {            // bits   description
+   Uint16 GPIO80:2;           // 1:0    GPIO80
+   Uint16 GPIO81:2;           // 3:2    GPIO81
+   Uint16 GPIO82:2;           // 5:4    GPIO82
+   Uint16 GPIO83:2;           // 7:6    GPIO83
+   Uint16 GPIO84:2;           // 9:8    GPIO84
+   Uint16 GPIO85:2;           // 11:10  GPIO85
+   Uint16 GPIO86:2;           // 13:12  GPIO86
+   Uint16 GPIO87:2;           // 15:14  GPIO87
+   Uint16 rsvd:16;            // 31:16  reserved
+};
+
+
+union GPA1_REG {
+   Uint32              all;
+   struct GPA1_BITS    bit;
+};
+
+union GPA2_REG {
+   Uint32              all;
+   struct GPA2_BITS    bit;
+};
+
+union GPB1_REG {
+   Uint32              all;
+   struct GPB1_BITS    bit;
+};
+
+union GPB2_REG {
+   Uint32              all;
+   struct GPB2_BITS    bit;
+};
+
+union GPC1_REG {
+   Uint32              all;
+   struct GPC1_BITS    bit;
+};
+
+union GPC2_REG {
+   Uint32              all;
+   struct GPC2_BITS    bit;
+};
+
+//----------------------------------------------------
+// GPIO A DIR/TOGGLE/SET/CLEAR register bit definitions */
+struct GPADAT_BITS {          // bits   description
+   Uint16 GPIO0:1;            // 0      GPIO0
+   Uint16 GPIO1:1;            // 1      GPIO1
+   Uint16 GPIO2:1;            // 2      GPIO2
+   Uint16 GPIO3:1;            // 3      GPIO3
+   Uint16 GPIO4:1;            // 4      GPIO4
+   Uint16 GPIO5:1;            // 5      GPIO5
+   Uint16 GPIO6:1;            // 6      GPIO6
+   Uint16 GPIO7:1;            // 7      GPIO7
+   Uint16 GPIO8:1;            // 8      GPIO8
+   Uint16 GPIO9:1;            // 9      GPIO9
+   Uint16 GPIO10:1;           // 10     GPIO10
+   Uint16 GPIO11:1;           // 11     GPIO11
+   Uint16 GPIO12:1;           // 12     GPIO12
+   Uint16 GPIO13:1;           // 13     GPIO13
+   Uint16 GPIO14:1;           // 14     GPIO14
+   Uint16 GPIO15:1;           // 15     GPIO15
+   Uint16 GPIO16:1;           // 16     GPIO16
+   Uint16 GPIO17:1;           // 17     GPIO17
+   Uint16 GPIO18:1;           // 18     GPIO18
+   Uint16 GPIO19:1;           // 19     GPIO19
+   Uint16 GPIO20:1;           // 20     GPIO20
+   Uint16 GPIO21:1;           // 21     GPIO21
+   Uint16 GPIO22:1;           // 22     GPIO22
+   Uint16 GPIO23:1;           // 23     GPIO23
+   Uint16 GPIO24:1;           // 24     GPIO24
+   Uint16 GPIO25:1;           // 25     GPIO25
+   Uint16 GPIO26:1;           // 26     GPIO26
+   Uint16 GPIO27:1;           // 27     GPIO27
+   Uint16 GPIO28:1;           // 28     GPIO28
+   Uint16 GPIO29:1;           // 29     GPIO29
+   Uint16 GPIO30:1;           // 30     GPIO30
+   Uint16 GPIO31:1;           // 31     GPIO31
+};
+
+struct GPBDAT_BITS {          // bits   description
+   Uint16 GPIO32:1;           // 0      GPIO32
+   Uint16 GPIO33:1;           // 1      GPIO33
+   Uint16 GPIO34:1;           // 2      GPIO34
+   Uint16 GPIO35:1;           // 3      GPIO35
+   Uint16 GPIO36:1;           // 4      GPIO36
+   Uint16 GPIO37:1;           // 5      GPIO37
+   Uint16 GPIO38:1;           // 6      GPIO38
+   Uint16 GPIO39:1;           // 7      GPIO39
+   Uint16 GPIO40:1;           // 8      GPIO40
+   Uint16 GPIO41:1;           // 9      GPIO41
+   Uint16 GPIO42:1;           // 10     GPIO42
+   Uint16 GPIO43:1;           // 11     GPIO43
+   Uint16 GPIO44:1;           // 12     GPIO44
+   Uint16 GPIO45:1;           // 13     GPIO45
+   Uint16 GPIO46:1;           // 14     GPIO46
+   Uint16 GPIO47:1;           // 15     GPIO47
+   Uint16 GPIO48:1;           // 16     GPIO48
+   Uint16 GPIO49:1;           // 17     GPIO49
+   Uint16 GPIO50:1;           // 18     GPIO50
+   Uint16 GPIO51:1;           // 19     GPIO51
+   Uint16 GPIO52:1;           // 20     GPIO52
+   Uint16 GPIO53:1;           // 21     GPIO53
+   Uint16 GPIO54:1;           // 22     GPIO54
+   Uint16 GPIO55:1;           // 23     GPIO55
+   Uint16 GPIO56:1;           // 24     GPIO56
+   Uint16 GPIO57:1;           // 25     GPIO57
+   Uint16 GPIO58:1;           // 26     GPIO58
+   Uint16 GPIO59:1;           // 27     GPIO59
+   Uint16 GPIO60:1;           // 28     GPIO60
+   Uint16 GPIO61:1;           // 29     GPIO61
+   Uint16 GPIO62:1;           // 30     GPIO62
+   Uint16 GPIO63:1;           // 31     GPIO63
+};
+
+struct GPCDAT_BITS {          // bits   description
+   Uint16 GPIO64:1;           // 0      GPIO64
+   Uint16 GPIO65:1;           // 1      GPIO65
+   Uint16 GPIO66:1;           // 2      GPIO66
+   Uint16 GPIO67:1;           // 3      GPIO67
+   Uint16 GPIO68:1;           // 4      GPIO68
+   Uint16 GPIO69:1;           // 5      GPIO69
+   Uint16 GPIO70:1;           // 6      GPIO70
+   Uint16 GPIO71:1;           // 7      GPIO71
+   Uint16 GPIO72:1;           // 8      GPIO72
+   Uint16 GPIO73:1;           // 9      GPIO73
+   Uint16 GPIO74:1;           // 10     GPIO74
+   Uint16 GPIO75:1;           // 11     GPIO75
+   Uint16 GPIO76:1;           // 12     GPIO76
+   Uint16 GPIO77:1;           // 13     GPIO77
+   Uint16 GPIO78:1;           // 14     GPIO78
+   Uint16 GPIO79:1;           // 15     GPIO79
+   Uint16 GPIO80:1;           // 16     GPIO80
+   Uint16 GPIO81:1;           // 17     GPIO81
+   Uint16 GPIO82:1;           // 18     GPIO82
+   Uint16 GPIO83:1;           // 19     GPIO83
+   Uint16 GPIO84:1;           // 20     GPIO84
+   Uint16 GPIO85:1;           // 21     GPIO85
+   Uint16 GPIO86:1;           // 22     GPIO86
+   Uint16 GPIO87:1;           // 23     GPIO87
+   Uint16 rsvd1:8;            // 31:24  reserved
+};
+
+
+union GPADAT_REG {
+   Uint32              all;
+   struct GPADAT_BITS  bit;
+};
+
+union GPBDAT_REG {
+   Uint32              all;
+   struct GPBDAT_BITS  bit;
+};
+
+union GPCDAT_REG {
+   Uint32              all;
+   struct GPCDAT_BITS  bit;
+};
+
+
+
+
+//----------------------------------------------------
+// GPIO Xint1/XINT2/XNMI select register bit definitions */
+struct GPIOXINT_BITS {        // bits   description
+    Uint16 GPIOSEL:5;         // 4:0    Select GPIO interrupt input source
+    Uint16 rsvd1:11;          // 15:5   reserved
+};
+
+union GPIOXINT_REG {
+   Uint16                all;
+   struct GPIOXINT_BITS  bit;
+};
+
+
+struct GPIO_CTRL_REGS {
+   union  GPACTRL_REG  GPACTRL;   // GPIO A Control Register (GPIO0 to 31)
+   union  GPA1_REG     GPAQSEL1;  // GPIO A Qualifier Select 1 Register (GPIO0 to 15)
+   union  GPA2_REG     GPAQSEL2;  // GPIO A Qualifier Select 2 Register (GPIO16 to 31)
+   union  GPA1_REG     GPAMUX1;   // GPIO A Mux 1 Register (GPIO0 to 15)
+   union  GPA2_REG     GPAMUX2;   // GPIO A Mux 2 Register (GPIO16 to 31)
+   union  GPADAT_REG   GPADIR;    // GPIO A Direction Register (GPIO0 to 31)
+   union  GPADAT_REG   GPAPUD;    // GPIO A Pull Up Disable Register (GPIO0 to 31)
+   Uint32              rsvd1;
+   union  GPBCTRL_REG  GPBCTRL;   // GPIO B Control Register (GPIO32 to 63)
+   union  GPB1_REG     GPBQSEL1;  // GPIO B Qualifier Select 1 Register (GPIO32 to 47)
+   union  GPB2_REG     GPBQSEL2;  // GPIO B Qualifier Select 2 Register (GPIO48 to 63)
+   union  GPB1_REG     GPBMUX1;   // GPIO B Mux 1 Register (GPIO32 to 47)
+   union  GPB2_REG     GPBMUX2;   // GPIO B Mux 2 Register (GPIO48 to 63)
+   union  GPBDAT_REG   GPBDIR;    // GPIO B Direction Register (GPIO32 to 63)
+   union  GPBDAT_REG   GPBPUD;    // GPIO B Pull Up Disable Register (GPIO32 to 63)
+   Uint16              rsvd2[8];
+   union  GPC1_REG     GPCMUX1;   // GPIO C Mux 1 Register (GPIO64 to 79)
+   union  GPC2_REG     GPCMUX2;   // GPIO C Mux 2 Register (GPIO80 to 95)
+   union  GPCDAT_REG   GPCDIR;    // GPIO C Direction Register (GPIO64 to 95)
+   union  GPCDAT_REG   GPCPUD;    // GPIO C Pull Up Disable Register (GPIO64 to 95)
+};
+
+struct GPIO_DATA_REGS {
+   union  GPADAT_REG       GPADAT;       // GPIO Data Register (GPIO0 to 31)
+   union  GPADAT_REG       GPASET;       // GPIO Data Set Register (GPIO0 to 31)
+   union  GPADAT_REG       GPACLEAR;     // GPIO Data Clear Register (GPIO0 to 31)
+   union  GPADAT_REG       GPATOGGLE;    // GPIO Data Toggle Register (GPIO0 to 31)
+   union  GPBDAT_REG       GPBDAT;       // GPIO Data Register (GPIO32 to 63)
+   union  GPBDAT_REG       GPBSET;       // GPIO Data Set Register (GPIO32 to 63)
+   union  GPBDAT_REG       GPBCLEAR;     // GPIO Data Clear Register (GPIO32 to 63)
+   union  GPBDAT_REG       GPBTOGGLE;    // GPIO Data Toggle Register (GPIO32 to 63)
+   union  GPCDAT_REG       GPCDAT;       // GPIO Data Register (GPIO64 to 95)
+   union  GPCDAT_REG       GPCSET;       // GPIO Data Set Register (GPIO64 to 95)
+   union  GPCDAT_REG       GPCCLEAR;     // GPIO Data Clear Register (GPIO64 to 95)
+   union  GPCDAT_REG       GPCTOGGLE;    // GPIO Data Toggle Register (GPIO64 to 95)
+   Uint16                  rsvd1[8];
+};
+
+struct GPIO_INT_REGS {
+   union  GPIOXINT_REG     GPIOXINT1SEL; // XINT1 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT2SEL; // XINT2 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXNMISEL;  // XNMI_Xint13 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT3SEL; // XINT3 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT4SEL; // XINT4 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT5SEL; // XINT5 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT6SEL; // XINT6 GPIO Input Selection
+   union  GPIOXINT_REG     GPIOXINT7SEL; // XINT7 GPIO Input Selection
+   union  GPADAT_REG       GPIOLPMSEL;   // Low power modes GP I/O input select
+};
+
+
+//---------------------------------------------------------------------------
+// GPI/O External References & Function Declarations:
+//
+extern struct GPIO_CTRL_REGS GpioCtrlRegs;
+extern struct GPIO_DATA_REGS GpioDataRegs;
+extern struct GPIO_INT_REGS GpioIntRegs;
+
+#endif  // end of DSP2833x_GPIO_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_I2c.h b/Inu/main_matlab/device_support/include/DSP2833x_I2c.h
new file mode 100644
index 0000000..b510f0d
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_I2c.h
@@ -0,0 +1,187 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: March 22, 2007   10:40:22 $
+//###########################################################################
+//
+// FILE:   DSP2833x_I2c.h
+//
+// TITLE:  DSP2833x Enhanced Quadrature Encoder Pulse Module
+//         Register Bit Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_I2C_H
+#define DSP2833x_I2C_H
+
+
+
+//----------------------------------------------------
+// I2C interrupt vector register bit definitions */
+struct I2CISRC_BITS {         // bits   description
+   Uint16 INTCODE:3;          // 2:0    Interrupt code
+   Uint16 rsvd1:13;           // 15:3   reserved
+};
+
+union I2CISRC_REG {
+   Uint16                 all;
+   struct I2CISRC_BITS    bit;
+};
+
+//----------------------------------------------------
+// I2C interrupt mask register bit definitions */
+struct I2CIER_BITS {          // bits   description
+   Uint16 ARBL:1;             // 0      Arbitration lost interrupt
+   Uint16 NACK:1;             // 1      No ack interrupt
+   Uint16 ARDY:1;             // 2      Register access ready interrupt
+   Uint16 RRDY:1;             // 3      Recieve data ready interrupt
+   Uint16 XRDY:1;             // 4      Transmit data ready interrupt
+   Uint16 SCD:1;              // 5      Stop condition detection
+   Uint16 AAS:1;              // 6      Address as slave
+   Uint16 rsvd:9;             // 15:7   reserved
+};
+
+union I2CIER_REG {
+   Uint16                 all;
+   struct I2CIER_BITS     bit;
+};
+
+//----------------------------------------------------
+// I2C status register bit definitions */
+struct I2CSTR_BITS {          // bits   description
+   Uint16 ARBL:1;             // 0      Arbitration lost interrupt
+   Uint16 NACK:1;             // 1      No ack interrupt
+   Uint16 ARDY:1;             // 2      Register access ready interrupt
+   Uint16 RRDY:1;             // 3      Recieve data ready interrupt
+   Uint16 XRDY:1;             // 4      Transmit data ready interrupt
+   Uint16 SCD:1;              // 5      Stop condition detection
+   Uint16 rsvd1:2;            // 7:6    reserved
+   Uint16 AD0:1;              // 8      Address Zero
+   Uint16 AAS:1;              // 9      Address as slave
+   Uint16 XSMT:1;             // 10     XMIT shift empty
+   Uint16 RSFULL:1;           // 11     Recieve shift full
+   Uint16 BB:1;               // 12     Bus busy
+   Uint16 NACKSNT:1;          // 13     A no ack sent
+   Uint16 SDIR:1;             // 14     Slave direction
+   Uint16 rsvd2:1;            // 15     reserved
+};
+
+union I2CSTR_REG {
+   Uint16                 all;
+   struct I2CSTR_BITS     bit;
+};
+
+
+//----------------------------------------------------
+// I2C mode control register bit definitions */
+struct I2CMDR_BITS {          // bits   description
+   Uint16 BC:3;               // 2:0    Bit count
+   Uint16 FDF:1;              // 3      Free data format
+   Uint16 STB:1;              // 4      Start byte
+   Uint16 IRS:1;              // 5      I2C Reset not
+   Uint16 DLB:1;              // 6      Digital loopback
+   Uint16 RM:1;               // 7      Repeat mode
+   Uint16 XA:1;               // 8      Expand address
+   Uint16 TRX:1;              // 9      Transmitter/reciever
+   Uint16 MST:1;              // 10     Master/slave
+   Uint16 STP:1;              // 11     Stop condition
+   Uint16 rsvd1:1;            // 12     reserved
+   Uint16 STT:1;              // 13     Start condition
+   Uint16 FREE:1;             // 14     Emulation mode
+   Uint16 NACKMOD:1;          // 15     No Ack mode
+};
+
+union I2CMDR_REG {
+   Uint16                 all;
+   struct I2CMDR_BITS     bit;
+};
+
+//----------------------------------------------------
+// I2C pre-scaler register bit definitions */
+struct I2CPSC_BITS {         // bits   description
+   Uint16 IPSC:8;            // 7:0    pre-scaler
+   Uint16 rsvd1:8;           // 15:8   reserved
+};
+
+
+union I2CPSC_REG {
+   Uint16                 all;
+   struct I2CPSC_BITS     bit;
+};
+
+
+//----------------------------------------------------
+// TX FIFO control register bit definitions */
+struct I2CFFTX_BITS {         // bits   description
+   Uint16 TXFFIL:5;           // 4:0    FIFO interrupt level
+   Uint16 TXFFIENA:1;         // 5      FIFO interrupt enable/disable
+   Uint16 TXFFINTCLR:1;       // 6      FIFO clear
+   Uint16 TXFFINT:1;          // 7      FIFO interrupt flag
+   Uint16 TXFFST:5;           // 12:8   FIFO level status
+   Uint16 TXFFRST:1;          // 13     FIFO reset
+   Uint16 I2CFFEN:1;          // 14     enable/disable TX & RX FIFOs
+   Uint16 rsvd1:1;            // 15     reserved
+
+};
+
+union I2CFFTX_REG {
+   Uint16                 all;
+   struct I2CFFTX_BITS    bit;
+};
+
+//----------------------------------------------------
+// RX FIFO control register bit definitions */
+struct I2CFFRX_BITS {         // bits   description
+   Uint16 RXFFIL:5;           // 4:0    FIFO interrupt level
+   Uint16 RXFFIENA:1;         // 5      FIFO interrupt enable/disable
+   Uint16 RXFFINTCLR:1;       // 6      FIFO clear
+   Uint16 RXFFINT:1;          // 7      FIFO interrupt flag
+   Uint16 RXFFST:5;           // 12:8   FIFO level
+   Uint16 RXFFRST:1;          // 13     FIFO reset
+   Uint16 rsvd1:2;            // 15:14  reserved
+};
+
+union I2CFFRX_REG {
+   Uint16                 all;
+   struct I2CFFRX_BITS    bit;
+};
+
+
+//----------------------------------------------------
+
+struct I2C_REGS {
+   Uint16              I2COAR;    // Own address register
+   union  I2CIER_REG   I2CIER;    // Interrupt enable
+   union  I2CSTR_REG   I2CSTR;    // Interrupt status
+   Uint16              I2CCLKL;   // Clock divider low
+   Uint16              I2CCLKH;   // Clock divider high
+   Uint16              I2CCNT;    // Data count
+   Uint16              I2CDRR;    // Data recieve
+   Uint16              I2CSAR;    // Slave address
+   Uint16              I2CDXR;    // Data transmit
+   union  I2CMDR_REG   I2CMDR;    // Mode
+   union  I2CISRC_REG  I2CISRC;   // Interrupt source
+   Uint16              rsvd1;     // reserved
+   union  I2CPSC_REG   I2CPSC;    // Pre-scaler
+   Uint16              rsvd2[19]; // reserved
+   union  I2CFFTX_REG  I2CFFTX;   // Transmit FIFO
+   union  I2CFFRX_REG  I2CFFRX;   // Recieve FIFO
+};
+
+
+
+
+//---------------------------------------------------------------------------
+// External References & Function Declarations:
+//
+extern struct I2C_REGS I2caRegs;
+
+
+
+#endif  // end of DSP2833x_I2C_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Mcbsp.h b/Inu/main_matlab/device_support/include/DSP2833x_Mcbsp.h
new file mode 100644
index 0000000..a9cf175
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Mcbsp.h
@@ -0,0 +1,709 @@
+// TI File $Revision: /main/5 $
+// Checkin $Date: May 14, 2008   16:30:31 $
+//###########################################################################
+//
+// FILE:   DSP2833x_Mcbsp.h
+//
+// TITLE:  DSP2833x Device McBSP Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_MCBSP_H
+#define DSP2833x_MCBSP_H
+
+
+//---------------------------------------------------------------------------
+// McBSP Individual Register Bit Definitions:
+//
+// McBSP DRR2 register bit definitions:
+struct  DRR2_BITS {       // bit   description
+   Uint16     HWLB:8;     // 16:23 High word low byte
+   Uint16     HWHB:8;     // 24:31 High word high byte
+};
+
+union DRR2_REG {
+   Uint16            all;
+   struct DRR2_BITS  bit;
+};
+
+// McBSP DRR1 register bit definitions:
+struct  DRR1_BITS {       // bit   description
+   Uint16     LWLB:8;     // 16:23 Low word low byte
+   Uint16     LWHB:8;     // 24:31 low word high byte
+};
+
+union DRR1_REG {
+   Uint16            all;
+   struct DRR1_BITS  bit;
+};
+
+// McBSP DXR2 register bit definitions:
+struct  DXR2_BITS {       // bit   description
+   Uint16     HWLB:8;     // 16:23 High word low byte
+   Uint16     HWHB:8;     // 24:31 High word high byte
+};
+
+union DXR2_REG {
+   Uint16            all;
+   struct DXR2_BITS  bit;
+};
+
+// McBSP DXR1 register bit definitions:
+struct  DXR1_BITS {       // bit   description
+   Uint16     LWLB:8;     // 16:23 Low word low byte
+   Uint16     LWHB:8;     // 24:31 low word high byte
+};
+
+union DXR1_REG {
+   Uint16              all;
+   struct DXR1_BITS  bit;
+};
+
+// SPCR2 control register bit definitions:
+struct  SPCR2_BITS {       // bit   description
+   Uint16     XRST:1;      // 0     transmit reset
+   Uint16     XRDY:1;      // 1     transmit ready
+   Uint16     XEMPTY:1;    // 2     Transmit empty
+   Uint16     XSYNCERR:1;  // 3     Transmit syn errorINT flag
+   Uint16     XINTM:2;     // 5:4   Transmit interrupt types
+   Uint16     GRST:1;      // 6     CLKG reset
+   Uint16     FRST:1;      // 7     Frame sync reset
+   Uint16     SOFT:1;      // 8     SOFT bit
+   Uint16     FREE:1;      // 9     FREE bit
+   Uint16     rsvd:6;      // 15:10 reserved
+};
+
+union SPCR2_REG {
+   Uint16               all;
+   struct SPCR2_BITS  bit;
+};
+
+// SPCR1 control register bit definitions:
+struct  SPCR1_BITS {       // bit   description
+   Uint16     RRST:1;      // 0     Receive reset
+   Uint16     RRDY:1;      // 1     Receive  ready
+   Uint16     RFULL:1;     // 2     Receive  full
+   Uint16     RSYNCERR:1;  // 7     Receive  syn error
+   Uint16     RINTM:2;     // 5:4   Receive  interrupt types
+   Uint16     ABIS:1;      // 6     ABIS mode select
+   Uint16     DXENA:1;     // 7     DX hi-z enable
+   Uint16     rsvd:3;      // 10:8  reserved
+   Uint16     CLKSTP:2;    // 12:11 CLKSTOP mode bit
+   Uint16     RJUST:2;     // 13:14 Right justified
+   Uint16     DLB:1;       // 15    Digital loop back
+};
+
+union SPCR1_REG {
+   Uint16              all;
+   struct SPCR1_BITS bit;
+};
+
+// RCR2 control register bit definitions:
+struct  RCR2_BITS {         // bit    description
+   Uint16     RDATDLY:2;    // 1:0    Receive data delay
+   Uint16     RFIG:1;       // 2      Receive  frame sync ignore
+   Uint16     RCOMPAND:2;   // 4:3    Receive  Companding Mode selects
+   Uint16     RWDLEN2:3;    // 7:5    Receive  word length
+   Uint16     RFRLEN2:7;    // 14:8   Receive  Frame sync
+   Uint16     RPHASE:1;     // 15     Receive Phase
+};
+
+union RCR2_REG {
+   Uint16           all;
+   struct RCR2_BITS bit;
+};
+
+// RCR1 control register bit definitions:
+struct  RCR1_BITS {         // bit   description
+   Uint16     rsvd1:5;      // 4:0   reserved
+   Uint16     RWDLEN1:3;    // 7:5   Receive word length
+   Uint16     RFRLEN1:7;    // 14:8  Receive frame length
+   Uint16     rsvd2:1;      // 15    reserved
+};
+
+union RCR1_REG {
+   Uint16           all;
+   struct RCR1_BITS bit;
+};
+
+// XCR2 control register bit definitions:
+
+struct  XCR2_BITS {         // bit    description
+   Uint16     XDATDLY:2;    // 1:0    Transmit data delay
+   Uint16     XFIG:1;       // 2      Transmit frame sync ignore
+   Uint16     XCOMPAND:2;   // 4:3    Transmit Companding Mode selects
+   Uint16     XWDLEN2:3;    // 7:5    Transmit  word length
+   Uint16     XFRLEN2:7;    // 14:8   Transmit  Frame sync
+   Uint16     XPHASE:1;     // 15     Transmit Phase
+};
+
+union XCR2_REG {
+   Uint16           all;
+   struct XCR2_BITS bit;
+};
+
+// XCR1 control register bit definitions:
+struct  XCR1_BITS {         // bit   description
+   Uint16     rsvd1:5;      // 4:0   reserved
+   Uint16     XWDLEN1:3;    // 7:5   Transmit word length
+   Uint16     XFRLEN1:7;    // 14:8  Transmit frame length
+   Uint16     rsvd2:1;      // 15    reserved
+};
+
+union XCR1_REG {
+   Uint16             all;
+   struct XCR1_BITS bit;
+};
+
+// SRGR2 Sample rate generator control register bit definitions:
+struct  SRGR2_BITS {        // bit  description
+   Uint16     FPER:12;      // 11:0 Frame period
+   Uint16     FSGM:1;       // 12   Frame sync generator mode
+   Uint16     CLKSM:1;      // 13   Sample rate generator mode
+   Uint16     rsvd:1;       // 14   reserved
+   Uint16     GSYNC:1;      // 15   CLKG sync
+};
+
+union  SRGR2_REG {
+   Uint16              all;
+   struct  SRGR2_BITS  bit;
+};
+
+// SRGR1 control register bit definitions:
+struct  SRGR1_BITS {        // bit   description
+   Uint16     CLKGDV:8;     // 7:0   CLKG divider
+   Uint16     FWID:8;       // 15:8  Frame width
+};
+
+union  SRGR1_REG {
+   Uint16              all;
+   struct  SRGR1_BITS  bit;
+};
+
+// MCR2 Multichannel control register bit definitions:
+struct  MCR2_BITS {         // bit   description
+   Uint16     XMCM:2;       // 1:0   Transmit multichannel mode
+   Uint16     XCBLK:3;      // 2:4   Transmit current block
+   Uint16     XPABLK:2;     // 5:6   Transmit partition A Block
+   Uint16     XPBBLK:2;     // 7:8   Transmit partition B Block
+   Uint16     XMCME:1;      // 9     Transmit multi-channel enhance mode
+   Uint16     rsvd:6;       // 15:10 reserved
+};
+
+union  MCR2_REG {
+   Uint16             all;
+   struct  MCR2_BITS  bit;
+};
+
+// MCR1 Multichannel control register bit definitions:
+struct  MCR1_BITS {         // bit   description
+   Uint16     RMCM:1;       // 0     Receive multichannel mode
+   Uint16     rsvd:1;       // 1     reserved
+   Uint16     RCBLK:3;      // 4:2   Receive current block
+   Uint16     RPABLK:2;     // 6:5   Receive partition A Block
+   Uint16     RPBBLK:2;     // 7:8   Receive partition B Block
+   Uint16     RMCME:1;      // 9     Receive multi-channel enhance mode
+   Uint16     rsvd1:6;      // 15:10 reserved
+};
+
+union  MCR1_REG {
+   Uint16             all;
+   struct  MCR1_BITS  bit;
+};
+
+// RCERA control register bit definitions:
+struct  RCERA_BITS {         // bit description
+   Uint16     RCEA0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEA1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEA2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEA3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEA4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEA5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEA6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEA7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEA8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEA9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEA10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEA11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEA12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEA13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEA14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEA15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERA_REG {
+   Uint16              all;
+   struct  RCERA_BITS  bit;
+};
+
+// RCERB control register bit definitions:
+struct  RCERB_BITS {         // bit description
+   Uint16     RCEB0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEB1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEB2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEB3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEB4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEB5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEB6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEB7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEB8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEB9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEB10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEB11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEB12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEB13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEB14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEB15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERB_REG {
+   Uint16              all;
+   struct  RCERB_BITS  bit;
+};
+
+// XCERA control register bit definitions:
+struct  XCERA_BITS {         // bit description
+   Uint16     XCERA0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERA1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERA2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERA3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERA4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERA5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERA6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERA7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERA8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERA9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERA10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERA11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERA12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERA13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERA14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERA15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERA_REG {
+   Uint16              all;
+   struct  XCERA_BITS  bit;
+};
+
+// XCERB control register bit definitions:
+struct  XCERB_BITS {         // bit description
+   Uint16     XCERB0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERB1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERB2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERB3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERB4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERB5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERB6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERB7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERB8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERB9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERB10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERB11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERB12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERB13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERB14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERB15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERB_REG {
+   Uint16              all;
+   struct  XCERB_BITS  bit;
+};
+
+// PCR control register bit definitions:
+struct  PCR_BITS {          // bit description
+   Uint16     CLKRP:1;       // 0   Receive Clock polarity
+   Uint16     CLKXP:1;       // 1   Transmit clock polarity
+   Uint16     FSRP:1;        // 2   Receive Frame synchronization polarity
+   Uint16     FSXP:1;        // 3   Transmit Frame synchronization polarity
+   Uint16     DR_STAT:1;     // 4   DR pin status - reserved for this McBSP
+   Uint16     DX_STAT:1;     // 5   DX pin status - reserved for this McBSP
+   Uint16     CLKS_STAT:1;   // 6   CLKS pin status - reserved for 28x -McBSP
+   Uint16     SCLKME:1;      // 7   Enhanced sample clock mode selection bit.
+   Uint16     CLKRM:1;       // 8   Receiver Clock Mode
+   Uint16     CLKXM:1;       // 9   Transmitter Clock Mode.
+   Uint16     FSRM:1;        // 10  Receive Frame Synchronization Mode
+   Uint16     FSXM:1;        // 11  Transmit Frame Synchronization Mode
+   Uint16     RIOEN:1;       // 12  General Purpose I/O Mode - reserved in this 28x-McBSP
+   Uint16     XIOEN:1;       // 13  General Purpose I/O Mode - reserved in this 28x-McBSP
+   Uint16     IDEL_EN:1;     // 14  reserved in this 28x-McBSP
+   Uint16     rsvd:1  ;      // 15  reserved
+};
+
+union PCR_REG {
+   Uint16            all;
+   struct  PCR_BITS  bit;
+};
+
+// RCERC control register bit definitions:
+struct  RCERC_BITS {         // bit description
+   Uint16     RCEC0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEC1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEC2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEC3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEC4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEC5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEC6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEC7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEC8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEC9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEC10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEC11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEC12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEC13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEC14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEC15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERC_REG {
+   Uint16              all;
+   struct  RCERC_BITS  bit;
+};
+
+// RCERD control register bit definitions:
+struct  RCERD_BITS {         // bit description
+   Uint16     RCED0:1;       // 0   Receive Channel enable bit
+   Uint16     RCED1:1;       // 1   Receive Channel enable bit
+   Uint16     RCED2:1;       // 2   Receive Channel enable bit
+   Uint16     RCED3:1;       // 3   Receive Channel enable bit
+   Uint16     RCED4:1;       // 4   Receive Channel enable bit
+   Uint16     RCED5:1;       // 5   Receive Channel enable bit
+   Uint16     RCED6:1;       // 6   Receive Channel enable bit
+   Uint16     RCED7:1;       // 7   Receive Channel enable bit
+   Uint16     RCED8:1;       // 8   Receive Channel enable bit
+   Uint16     RCED9:1;       // 9   Receive Channel enable bit
+   Uint16     RCED10:1;      // 10  Receive Channel enable bit
+   Uint16     RCED11:1;      // 11  Receive Channel enable bit
+   Uint16     RCED12:1;      // 12  Receive Channel enable bit
+   Uint16     RCED13:1;      // 13  Receive Channel enable bit
+   Uint16     RCED14:1;      // 14  Receive Channel enable bit
+   Uint16     RCED15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERD_REG {
+   Uint16              all;
+   struct  RCERD_BITS  bit;
+};
+
+// XCERC control register bit definitions:
+struct  XCERC_BITS {         // bit description
+   Uint16     XCERC0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERC1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERC2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERC3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERC4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERC5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERC6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERC7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERC8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERC9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERC10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERC11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERC12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERC13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERC14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERC15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERC_REG {
+   Uint16              all;
+   struct  XCERC_BITS  bit;
+};
+
+// XCERD control register bit definitions:
+struct  XCERD_BITS {         // bit description
+   Uint16     XCERD0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERD1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERD2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERD3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERD4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERD5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERD6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERD7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERD8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERD9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERD10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERD11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERD12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERD13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERD14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERD15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERD_REG {
+   Uint16              all;
+   struct  XCERD_BITS  bit;
+};
+
+// RCERE control register bit definitions:
+struct  RCERE_BITS {         // bit description
+   Uint16     RCEE0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEE1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEE2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEE3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEE4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEE5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEE6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEE7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEE8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEE9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEE10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEE11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEE12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEE13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEE14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEE15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERE_REG {
+   Uint16              all;
+   struct  RCERE_BITS  bit;
+};
+
+// RCERF control register bit definitions:
+struct  RCERF_BITS {         // bit   description
+   Uint16     RCEF0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEF1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEF2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEF3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEF4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEF5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEF6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEF7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEF8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEF9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEF10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEF11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEF12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEF13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEF14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEF15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERF_REG {
+   Uint16              all;
+   struct  RCERF_BITS  bit;
+};
+
+// XCERE control register bit definitions:
+struct  XCERE_BITS {         // bit description
+   Uint16     XCERE0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERE1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERE2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERE3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERE4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERE5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERE6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERE7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERE8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERE9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERE10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERE11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERE12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERE13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERE14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERE15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERE_REG {
+   Uint16              all;
+   struct  XCERE_BITS  bit;
+};
+
+// XCERF control register bit definitions:
+struct  XCERF_BITS {         // bit description
+   Uint16     XCERF0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERF1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERF2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERF3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERF4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERF5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERF6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERF7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERF8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERF9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERF10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERF11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERF12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERF13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERF14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERF15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERF_REG {
+   Uint16              all;
+   struct  XCERF_BITS  bit;
+};
+
+// RCERG control register bit definitions:
+struct  RCERG_BITS {         // bit description
+   Uint16     RCEG0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEG1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEG2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEG3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEG4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEG5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEG6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEG7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEG8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEG9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEG10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEG11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEG12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEG13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEG14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEG15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERG_REG {
+   Uint16              all;
+   struct  RCERG_BITS  bit;
+};
+
+// RCERH control register bit definitions:
+struct  RCERH_BITS {         // bit description
+   Uint16     RCEH0:1;       // 0   Receive Channel enable bit
+   Uint16     RCEH1:1;       // 1   Receive Channel enable bit
+   Uint16     RCEH2:1;       // 2   Receive Channel enable bit
+   Uint16     RCEH3:1;       // 3   Receive Channel enable bit
+   Uint16     RCEH4:1;       // 4   Receive Channel enable bit
+   Uint16     RCEH5:1;       // 5   Receive Channel enable bit
+   Uint16     RCEH6:1;       // 6   Receive Channel enable bit
+   Uint16     RCEH7:1;       // 7   Receive Channel enable bit
+   Uint16     RCEH8:1;       // 8   Receive Channel enable bit
+   Uint16     RCEH9:1;       // 9   Receive Channel enable bit
+   Uint16     RCEH10:1;      // 10  Receive Channel enable bit
+   Uint16     RCEH11:1;      // 11  Receive Channel enable bit
+   Uint16     RCEH12:1;      // 12  Receive Channel enable bit
+   Uint16     RCEH13:1;      // 13  Receive Channel enable bit
+   Uint16     RCEH14:1;      // 14  Receive Channel enable bit
+   Uint16     RCEH15:1;      // 15  Receive Channel enable bit
+};
+
+union RCERH_REG {
+   Uint16              all;
+   struct  RCERH_BITS  bit;
+};
+
+// XCERG control register bit definitions:
+struct  XCERG_BITS {         // bit description
+   Uint16     XCERG0:1;       // 0   Receive Channel enable bit
+   Uint16     XCERG1:1;       // 1   Receive Channel enable bit
+   Uint16     XCERG2:1;       // 2   Receive Channel enable bit
+   Uint16     XCERG3:1;       // 3   Receive Channel enable bit
+   Uint16     XCERG4:1;       // 4   Receive Channel enable bit
+   Uint16     XCERG5:1;       // 5   Receive Channel enable bit
+   Uint16     XCERG6:1;       // 6   Receive Channel enable bit
+   Uint16     XCERG7:1;       // 7   Receive Channel enable bit
+   Uint16     XCERG8:1;       // 8   Receive Channel enable bit
+   Uint16     XCERG9:1;       // 9   Receive Channel enable bit
+   Uint16     XCERG10:1;      // 10  Receive Channel enable bit
+   Uint16     XCERG11:1;      // 11  Receive Channel enable bit
+   Uint16     XCERG12:1;      // 12  Receive Channel enable bit
+   Uint16     XCERG13:1;      // 13  Receive Channel enable bit
+   Uint16     XCERG14:1;      // 14  Receive Channel enable bit
+   Uint16     XCERG15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERG_REG {
+   Uint16              all;
+   struct  XCERG_BITS  bit;
+};
+
+// XCERH control register bit definitions:
+struct  XCERH_BITS {         // bit description
+   Uint16     XCEH0:1;       // 0   Receive Channel enable bit
+   Uint16     XCEH1:1;       // 1   Receive Channel enable bit
+   Uint16     XCEH2:1;       // 2   Receive Channel enable bit
+   Uint16     XCEH3:1;       // 3   Receive Channel enable bit
+   Uint16     XCEH4:1;       // 4   Receive Channel enable bit
+   Uint16     XCEH5:1;       // 5   Receive Channel enable bit
+   Uint16     XCEH6:1;       // 6   Receive Channel enable bit
+   Uint16     XCEH7:1;       // 7   Receive Channel enable bit
+   Uint16     XCEH8:1;       // 8   Receive Channel enable bit
+   Uint16     XCEH9:1;       // 9   Receive Channel enable bit
+   Uint16     XCEH10:1;      // 10  Receive Channel enable bit
+   Uint16     XCEH11:1;      // 11  Receive Channel enable bit
+   Uint16     XCEH12:1;      // 12  Receive Channel enable bit
+   Uint16     XCEH13:1;      // 13  Receive Channel enable bit
+   Uint16     XCEH14:1;      // 14  Receive Channel enable bit
+   Uint16     XCEH15:1;      // 15  Receive Channel enable bit
+};
+
+union XCERH_REG {
+   Uint16              all;
+   struct  XCERH_BITS  bit;
+};
+
+
+// McBSP Interrupt enable register for RINT/XINT
+struct  MFFINT_BITS {       // bits description
+    Uint16     XINT:1;      // 0    XINT  interrupt enable
+    Uint16     rsvd1:1;     // 1    reserved
+    Uint16     RINT:1;      // 2    RINT  interrupt enable
+    Uint16     rsvd2:13;    // 15:3 reserved
+};
+
+union MFFINT_REG {
+   Uint16              all;
+   struct MFFINT_BITS  bit;
+};
+
+
+//---------------------------------------------------------------------------
+// McBSP Register File:
+//
+struct  MCBSP_REGS {
+   union DRR2_REG    DRR2;       // MCBSP Data receive register bits 31-16
+   union DRR1_REG    DRR1;       // MCBSP Data receive register bits 15-0
+   union DXR2_REG    DXR2;       // MCBSP Data transmit register bits 31-16
+   union DXR1_REG    DXR1;       // MCBSP Data transmit register bits 15-0
+   union SPCR2_REG   SPCR2;      // MCBSP control register bits 31-16
+   union SPCR1_REG   SPCR1;      // MCBSP control register bits 15-0
+   union RCR2_REG    RCR2;       // MCBSP receive control register bits 31-16
+   union RCR1_REG    RCR1;       // MCBSP receive control register bits 15-0
+   union XCR2_REG    XCR2;       // MCBSP transmit control register bits 31-16
+   union XCR1_REG    XCR1;       // MCBSP transmit control register bits 15-0
+   union SRGR2_REG   SRGR2;      // MCBSP sample rate gen register bits 31-16
+   union SRGR1_REG   SRGR1;      // MCBSP sample rate gen register bits 15-0
+   union MCR2_REG    MCR2;       // MCBSP multichannel register bits 31-16
+   union MCR1_REG    MCR1;       // MCBSP multichannel register bits 15-0
+   union RCERA_REG   RCERA;      // MCBSP Receive channel enable partition A
+   union RCERB_REG   RCERB;      // MCBSP Receive channel enable partition B
+   union XCERA_REG   XCERA;      // MCBSP Transmit channel enable partition A
+   union XCERB_REG   XCERB;      // MCBSP Transmit channel enable partition B
+   union PCR_REG     PCR;        // MCBSP Pin control register bits 15-0
+   union RCERC_REG   RCERC;      // MCBSP Receive channel enable partition C
+   union RCERD_REG   RCERD;      // MCBSP Receive channel enable partition D
+   union XCERC_REG   XCERC;      // MCBSP Transmit channel enable partition C
+   union XCERD_REG   XCERD;      // MCBSP Transmit channel enable partition D
+   union RCERE_REG   RCERE;      // MCBSP Receive channel enable partition E
+   union RCERF_REG   RCERF;      // MCBSP Receive channel enable partition F
+   union XCERE_REG   XCERE;      // MCBSP Transmit channel enable partition E
+   union XCERF_REG   XCERF;      // MCBSP Transmit channel enable partition F
+   union RCERG_REG   RCERG;      // MCBSP Receive channel enable partition G
+   union RCERH_REG   RCERH;      // MCBSP Receive channel enable partition H
+   union XCERG_REG   XCERG;      // MCBSP Transmit channel enable partition G
+   union XCERH_REG   XCERH;      // MCBSP Transmit channel enable partition H
+   Uint16            rsvd1[4];   // reserved
+   union MFFINT_REG  MFFINT;     // MCBSP Interrupt enable register for RINT/XINT
+   Uint16            rsvd2;      // reserved
+};
+
+//---------------------------------------------------------------------------
+// McBSP External References & Function Declarations:
+//
+extern struct MCBSP_REGS McbspaRegs;
+extern struct MCBSP_REGS McbspbRegs;
+
+
+#endif  // end of DSP2833x_MCBSP_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_PieCtrl.h b/Inu/main_matlab/device_support/include/DSP2833x_PieCtrl.h
new file mode 100644
index 0000000..028bed6
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_PieCtrl.h
@@ -0,0 +1,148 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:52:24 $
+//###########################################################################
+//
+// FILE:   DSP2833x_PieCtrl.h
+//
+// TITLE:  DSP2833x Device PIE Control Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+
+#ifndef DSP2833x_PIE_CTRL_H
+#define DSP2833x_PIE_CTRL_H
+
+
+//---------------------------------------------------------------------------
+// PIE Control Register Bit Definitions:
+//
+// PIECTRL: Register bit definitions:
+struct PIECTRL_BITS {      // bits description
+   Uint16  ENPIE:1;        // 0    Enable PIE block
+   Uint16  PIEVECT:15;     // 15:1 Fetched vector address
+};
+
+union PIECTRL_REG {
+   Uint16                 all;
+   struct PIECTRL_BITS  bit;
+};  
+
+// PIEIER: Register bit definitions:
+struct PIEIER_BITS {       // bits description
+   Uint16 INTx1:1;         // 0    INTx.1
+   Uint16 INTx2:1;         // 1    INTx.2
+   Uint16 INTx3:1;         // 2    INTx.3
+   Uint16 INTx4:1;         // 3    INTx.4
+   Uint16 INTx5:1;         // 4    INTx.5
+   Uint16 INTx6:1;         // 5    INTx.6
+   Uint16 INTx7:1;         // 6    INTx.7
+   Uint16 INTx8:1;         // 7    INTx.8
+   Uint16 rsvd:8;          // 15:8 reserved
+};
+
+union PIEIER_REG {
+   Uint16              all;
+   struct PIEIER_BITS  bit;
+}; 
+
+// PIEIFR: Register bit definitions:
+struct PIEIFR_BITS {       // bits description
+   Uint16 INTx1:1;         // 0    INTx.1
+   Uint16 INTx2:1;         // 1    INTx.2
+   Uint16 INTx3:1;         // 2    INTx.3
+   Uint16 INTx4:1;         // 3    INTx.4
+   Uint16 INTx5:1;         // 4    INTx.5
+   Uint16 INTx6:1;         // 5    INTx.6
+   Uint16 INTx7:1;         // 6    INTx.7
+   Uint16 INTx8:1;         // 7    INTx.8
+   Uint16 rsvd:8;          // 15:8 reserved
+};
+
+union PIEIFR_REG {
+   Uint16              all;
+   struct PIEIFR_BITS  bit;
+};
+
+// PIEACK: Register bit definitions:
+struct PIEACK_BITS {       // bits description
+   Uint16 ACK1:1;          // 0    Acknowledge PIE interrupt group 1
+   Uint16 ACK2:1;          // 1    Acknowledge PIE interrupt group 2
+   Uint16 ACK3:1;          // 2    Acknowledge PIE interrupt group 3
+   Uint16 ACK4:1;          // 3    Acknowledge PIE interrupt group 4
+   Uint16 ACK5:1;          // 4    Acknowledge PIE interrupt group 5
+   Uint16 ACK6:1;          // 5    Acknowledge PIE interrupt group 6
+   Uint16 ACK7:1;          // 6    Acknowledge PIE interrupt group 7
+   Uint16 ACK8:1;          // 7    Acknowledge PIE interrupt group 8
+   Uint16 ACK9:1;          // 8    Acknowledge PIE interrupt group 9
+   Uint16 ACK10:1;         // 9    Acknowledge PIE interrupt group 10
+   Uint16 ACK11:1;         // 10   Acknowledge PIE interrupt group 11
+   Uint16 ACK12:1;         // 11   Acknowledge PIE interrupt group 12
+   Uint16 rsvd:4;          // 15:12 reserved
+};
+
+union PIEACK_REG {
+   Uint16              all;
+   struct PIEACK_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// PIE Control Register File:
+//
+struct PIE_CTRL_REGS {
+   union PIECTRL_REG PIECTRL;       // PIE control register
+   union PIEACK_REG  PIEACK;        // PIE acknowledge
+   union PIEIER_REG  PIEIER1;       // PIE int1 IER register  
+   union PIEIFR_REG  PIEIFR1;       // PIE int1 IFR register
+   union PIEIER_REG  PIEIER2;       // PIE INT2 IER register 
+   union PIEIFR_REG  PIEIFR2;       // PIE INT2 IFR register
+   union PIEIER_REG  PIEIER3;       // PIE INT3 IER register 
+   union PIEIFR_REG  PIEIFR3;       // PIE INT3 IFR register
+   union PIEIER_REG  PIEIER4;       // PIE INT4 IER register             
+   union PIEIFR_REG  PIEIFR4;       // PIE INT4 IFR register
+   union PIEIER_REG  PIEIER5;       // PIE INT5 IER register  
+   union PIEIFR_REG  PIEIFR5;       // PIE INT5 IFR register
+   union PIEIER_REG  PIEIER6;       // PIE INT6 IER register 
+   union PIEIFR_REG  PIEIFR6;       // PIE INT6 IFR register
+   union PIEIER_REG  PIEIER7;       // PIE INT7 IER register 
+   union PIEIFR_REG  PIEIFR7;       // PIE INT7 IFR register
+   union PIEIER_REG  PIEIER8;       // PIE INT8 IER register
+   union PIEIFR_REG  PIEIFR8;       // PIE INT8 IFR register
+   union PIEIER_REG  PIEIER9;       // PIE INT9 IER register  
+   union PIEIFR_REG  PIEIFR9;       // PIE INT9 IFR register
+   union PIEIER_REG  PIEIER10;      // PIE int10 IER register 
+   union PIEIFR_REG  PIEIFR10;      // PIE int10 IFR register
+   union PIEIER_REG  PIEIER11;      // PIE int11 IER register 
+   union PIEIFR_REG  PIEIFR11;      // PIE int11 IFR register
+   union PIEIER_REG  PIEIER12;      // PIE int12 IER register
+   union PIEIFR_REG  PIEIFR12;      // PIE int12 IFR register
+};     
+
+#define PIEACK_GROUP1   0x0001
+#define PIEACK_GROUP2   0x0002
+#define PIEACK_GROUP3   0x0004
+#define PIEACK_GROUP4   0x0008
+#define PIEACK_GROUP5   0x0010
+#define PIEACK_GROUP6   0x0020
+#define PIEACK_GROUP7   0x0040
+#define PIEACK_GROUP8   0x0080
+#define PIEACK_GROUP9   0x0100
+#define PIEACK_GROUP10  0x0200
+#define PIEACK_GROUP11  0x0400
+#define PIEACK_GROUP12  0x0800
+
+//---------------------------------------------------------------------------
+// PIE Control Registers External References & Function Declarations:
+//
+extern struct PIE_CTRL_REGS PieCtrlRegs;
+
+
+
+#endif  // end of DSP2833x_PIE_CTRL_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_PieVect.h b/Inu/main_matlab/device_support/include/DSP2833x_PieVect.h
new file mode 100644
index 0000000..d625dc3
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_PieVect.h
@@ -0,0 +1,202 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: March 16, 2007   09:00:21 $
+//###########################################################################
+//
+// FILE:   DSP2833x_PieVect.h
+//
+// TITLE:  DSP2833x Devices PIE Vector Table Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_PIE_VECT_H
+#define DSP2833x_PIE_VECT_H
+
+
+
+
+//---------------------------------------------------------------------------
+// PIE Interrupt Vector Table Definition:
+//
+// Create a user type called PINT (pointer to interrupt):
+
+typedef void(*PINT)(void);
+
+// Define Vector Table:
+struct PIE_VECT_TABLE {
+
+// Reset is never fetched from this table.
+// It will always be fetched from 0x3FFFC0 in
+// boot ROM
+
+      PINT     PIE1_RESERVED;
+      PINT     PIE2_RESERVED;
+      PINT     PIE3_RESERVED;
+      PINT     PIE4_RESERVED;
+      PINT     PIE5_RESERVED;
+      PINT     PIE6_RESERVED;
+      PINT     PIE7_RESERVED;
+      PINT     PIE8_RESERVED;
+      PINT     PIE9_RESERVED;
+      PINT     PIE10_RESERVED;
+      PINT     PIE11_RESERVED;
+      PINT     PIE12_RESERVED;
+      PINT     PIE13_RESERVED;
+
+// Non-Peripheral Interrupts:
+      PINT     XINT13;    // XINT13 / CPU-Timer1
+      PINT     TINT2;     // CPU-Timer2
+      PINT     DATALOG;   // Datalogging interrupt
+      PINT     RTOSINT;   // RTOS interrupt
+      PINT     EMUINT;    // Emulation interrupt
+      PINT     XNMI;      // Non-maskable interrupt
+      PINT     ILLEGAL;   // Illegal operation TRAP
+      PINT     USER1;     // User Defined trap 1
+      PINT     USER2;     // User Defined trap 2
+      PINT     USER3;     // User Defined trap 3
+      PINT     USER4;     // User Defined trap 4
+      PINT     USER5;     // User Defined trap 5
+      PINT     USER6;     // User Defined trap 6
+      PINT     USER7;     // User Defined trap 7
+      PINT     USER8;     // User Defined trap 8
+      PINT     USER9;     // User Defined trap 9
+      PINT     USER10;    // User Defined trap 10
+      PINT     USER11;    // User Defined trap 11
+      PINT     USER12;    // User Defined trap 12
+
+// Group 1 PIE Peripheral Vectors:
+      PINT     SEQ1INT;
+      PINT     SEQ2INT;
+      PINT     rsvd1_3;
+      PINT     XINT1;
+      PINT     XINT2;
+      PINT     ADCINT;    // ADC
+      PINT     TINT0;     // Timer 0
+      PINT     WAKEINT;   // WD
+
+// Group 2 PIE Peripheral Vectors:
+      PINT     EPWM1_TZINT; // EPWM-1
+      PINT     EPWM2_TZINT; // EPWM-2
+      PINT     EPWM3_TZINT; // EPWM-3
+      PINT     EPWM4_TZINT; // EPWM-4
+      PINT     EPWM5_TZINT; // EPWM-5
+      PINT     EPWM6_TZINT; // EPWM-6
+      PINT     rsvd2_7;
+      PINT     rsvd2_8;
+
+// Group 3 PIE Peripheral Vectors:
+      PINT     EPWM1_INT;  // EPWM-1
+      PINT     EPWM2_INT;  // EPWM-2
+      PINT     EPWM3_INT;  // EPWM-3
+      PINT     EPWM4_INT;  // EPWM-4
+      PINT     EPWM5_INT;  // EPWM-5
+      PINT     EPWM6_INT;  // EPWM-6
+      PINT     rsvd3_7;
+      PINT     rsvd3_8;
+
+// Group 4 PIE Peripheral Vectors:
+      PINT     ECAP1_INT; // ECAP-1
+      PINT     ECAP2_INT; // ECAP-2
+      PINT     ECAP3_INT; // ECAP-3
+      PINT     ECAP4_INT; // ECAP-4
+      PINT     ECAP5_INT; // ECAP-5
+      PINT     ECAP6_INT; // ECAP-6
+      PINT     rsvd4_7;
+      PINT     rsvd4_8;
+
+// Group 5 PIE Peripheral Vectors:
+      PINT     EQEP1_INT; // EQEP-1
+      PINT     EQEP2_INT; // EQEP-2
+      PINT     rsvd5_3;
+      PINT     rsvd5_4;
+      PINT     rsvd5_5;
+      PINT     rsvd5_6;
+      PINT     rsvd5_7;
+      PINT     rsvd5_8;
+
+// Group 6 PIE Peripheral Vectors:
+      PINT     SPIRXINTA; // SPI-A
+      PINT     SPITXINTA; // SPI-A
+      PINT     MRINTB;    // McBSP-B
+      PINT     MXINTB;    // McBSP-B
+	  PINT     MRINTA;    // McBSP-A
+      PINT     MXINTA;    // McBSP-A
+      PINT     rsvd6_7;
+      PINT     rsvd6_8;
+
+// Group 7 PIE Peripheral Vectors:
+      PINT     DINTCH1;   // DMA
+      PINT     DINTCH2;   // DMA
+      PINT     DINTCH3;   // DMA
+      PINT     DINTCH4;   // DMA
+      PINT     DINTCH5;   // DMA
+      PINT     DINTCH6;   // DMA
+      PINT     rsvd7_7;
+      PINT     rsvd7_8;
+
+// Group 8 PIE Peripheral Vectors:
+      PINT     I2CINT1A;  // I2C-A
+      PINT     I2CINT2A;  // I2C-A
+      PINT     rsvd8_3;
+      PINT     rsvd8_4;
+      PINT     SCIRXINTC;  // SCI-C
+      PINT     SCITXINTC;  // SCI-C
+      PINT     rsvd8_7;
+      PINT     rsvd8_8;
+
+// Group 9 PIE Peripheral Vectors:
+      PINT     SCIRXINTA;  // SCI-A
+      PINT     SCITXINTA;  // SCI-A
+      PINT     SCIRXINTB;  // SCI-B
+      PINT     SCITXINTB;  // SCI-B
+      PINT     ECAN0INTA;  // eCAN-A
+      PINT     ECAN1INTA;  // eCAN-A
+      PINT     ECAN0INTB;  // eCAN-B
+      PINT     ECAN1INTB;  // eCAN-B
+
+// Group 10 PIE Peripheral Vectors:
+      PINT     rsvd10_1;
+      PINT     rsvd10_2;
+      PINT     rsvd10_3;
+      PINT     rsvd10_4;
+      PINT     rsvd10_5;
+      PINT     rsvd10_6;
+      PINT     rsvd10_7;
+      PINT     rsvd10_8;
+
+// Group 11 PIE Peripheral Vectors:
+      PINT     rsvd11_1;
+      PINT     rsvd11_2;
+      PINT     rsvd11_3;
+      PINT     rsvd11_4;
+      PINT     rsvd11_5;
+      PINT     rsvd11_6;
+      PINT     rsvd11_7;
+      PINT     rsvd11_8;
+
+// Group 12 PIE Peripheral Vectors:
+      PINT     XINT3;      // External interrupt
+      PINT     XINT4;
+      PINT     XINT5;
+      PINT     XINT6;
+      PINT     XINT7;
+      PINT     rsvd12_6;
+      PINT     LVF;        // Latched overflow
+      PINT     LUF;        // Latched underflow
+};
+
+//---------------------------------------------------------------------------
+// PIE Interrupt Vector Table External References & Function Declarations:
+//
+extern struct PIE_VECT_TABLE PieVectTable;
+
+
+#endif    // end of DSP2833x_PIE_VECT_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Sci.h b/Inu/main_matlab/device_support/include/DSP2833x_Sci.h
new file mode 100644
index 0000000..15a194f
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Sci.h
@@ -0,0 +1,229 @@
+// TI File $Revision: /main/2 $
+// Checkin $Date: March 1, 2007   15:57:02 $
+//###########################################################################
+//
+// FILE:	DSP2833x_Sci.h
+//
+// TITLE:	DSP2833x Device SCI Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_SCI_H
+#define DSP2833x_SCI_H
+
+
+
+//---------------------------------------------------------------------------
+// SCI Individual Register Bit Definitions
+
+//----------------------------------------------------------
+// SCICCR communication control register bit definitions:
+//
+
+struct  SCICCR_BITS {        // bit    description
+   Uint16 SCICHAR:3;         // 2:0    Character length control        
+   Uint16 ADDRIDLE_MODE:1;   // 3      ADDR/IDLE Mode control
+   Uint16 LOOPBKENA:1;       // 4      Loop Back enable
+   Uint16 PARITYENA:1;       // 5      Parity enable   
+   Uint16 PARITY:1;          // 6      Even or Odd Parity
+   Uint16 STOPBITS:1;        // 7      Number of Stop Bits
+   Uint16 rsvd1:8;           // 15:8   reserved
+}; 
+
+
+union SCICCR_REG {
+   Uint16              all;
+   struct SCICCR_BITS  bit;
+};
+
+//-------------------------------------------
+// SCICTL1 control register 1 bit definitions:
+//
+                       
+struct  SCICTL1_BITS {       // bit    description
+   Uint16 RXENA:1;           // 0      SCI receiver enable
+   Uint16 TXENA:1;           // 1      SCI transmitter enable
+   Uint16 SLEEP:1;           // 2      SCI sleep  
+   Uint16 TXWAKE:1;          // 3      Transmitter wakeup method
+   Uint16 rsvd:1;            // 4      reserved
+   Uint16 SWRESET:1;         // 5      Software reset   
+   Uint16 RXERRINTENA:1;     // 6      Recieve interrupt enable
+   Uint16 rsvd1:9;           // 15:7   reserved
+
+}; 
+
+union SCICTL1_REG {
+   Uint16               all;
+   struct SCICTL1_BITS  bit;
+};
+
+//---------------------------------------------
+// SCICTL2 control register 2 bit definitions:
+// 
+
+struct  SCICTL2_BITS {       // bit    description
+   Uint16 TXINTENA:1;        // 0      Transmit interrupt enable    
+   Uint16 RXBKINTENA:1;      // 1      Receiver-buffer break enable
+   Uint16 rsvd:4;            // 5:2    reserved
+   Uint16 TXEMPTY:1;         // 6      Transmitter empty flag
+   Uint16 TXRDY:1;           // 7      Transmitter ready flag  
+   Uint16 rsvd1:8;           // 15:8   reserved
+
+}; 
+
+union SCICTL2_REG {
+   Uint16               all;
+   struct SCICTL2_BITS  bit;
+};
+
+//---------------------------------------------------
+// SCIRXST Receiver status register bit definitions:
+//
+
+struct  SCIRXST_BITS {       // bit    description
+   Uint16 rsvd:1;            // 0      reserved
+   Uint16 RXWAKE:1;          // 1      Receiver wakeup detect flag
+   Uint16 PE:1;              // 2      Parity error flag
+   Uint16 OE:1;              // 3      Overrun error flag
+   Uint16 FE:1;              // 4      Framing error flag
+   Uint16 BRKDT:1;           // 5      Break-detect flag   
+   Uint16 RXRDY:1;           // 6      Receiver ready flag
+   Uint16 RXERROR:1;         // 7      Receiver error flag
+
+}; 
+
+union SCIRXST_REG {
+   Uint16               all;
+   struct SCIRXST_BITS  bit;
+};
+
+//----------------------------------------------------
+// SCIRXBUF Receiver Data Buffer with FIFO bit definitions:
+// 
+
+struct  SCIRXBUF_BITS {      // bits   description
+   Uint16 RXDT:8;            // 7:0    Receive word
+   Uint16 rsvd:6;            // 13:8   reserved
+   Uint16 SCIFFPE:1;         // 14     SCI PE error in FIFO mode
+   Uint16 SCIFFFE:1;         // 15     SCI FE error in FIFO mode
+};
+
+union SCIRXBUF_REG {
+   Uint16                all;
+   struct SCIRXBUF_BITS  bit;
+};
+
+//--------------------------------------------------
+// SCIPRI Priority control register bit definitions:
+// 
+//
+                                                   
+struct  SCIPRI_BITS {        // bit    description
+   Uint16 rsvd:3;            // 2:0    reserved
+   Uint16 FREE:1;            // 3      Free emulation suspend mode
+   Uint16 SOFT:1;            // 4      Soft emulation suspend mode
+   Uint16 rsvd1:3;           // 7:5    reserved
+}; 
+
+union SCIPRI_REG {
+   Uint16              all;
+   struct SCIPRI_BITS  bit;
+};
+
+//-------------------------------------------------
+// SCI FIFO Transmit register bit definitions:
+// 
+//
+                                                  
+struct  SCIFFTX_BITS {       // bit    description
+   Uint16 TXFFIL:5;          // 4:0    Interrupt level
+   Uint16 TXFFIENA:1;        // 5      Interrupt enable
+   Uint16 TXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 TXFFINT:1;         // 7      INT flag
+   Uint16 TXFFST:5;          // 12:8   FIFO status
+   Uint16 TXFIFOXRESET:1;    // 13     FIFO reset
+   Uint16 SCIFFENA:1;        // 14     Enhancement enable
+   Uint16 SCIRST:1;          // 15     SCI reset rx/tx channels 
+
+}; 
+
+union SCIFFTX_REG {
+   Uint16               all;
+   struct SCIFFTX_BITS  bit;
+};
+
+//------------------------------------------------
+// SCI FIFO recieve register bit definitions:
+// 
+//
+                                               
+struct  SCIFFRX_BITS {       // bits   description
+   Uint16 RXFFIL:5;          // 4:0    Interrupt level
+   Uint16 RXFFIENA:1;        // 5      Interrupt enable
+   Uint16 RXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 RXFFINT:1;         // 7      INT flag
+   Uint16 RXFFST:5;          // 12:8   FIFO status
+   Uint16 RXFIFORESET:1;     // 13     FIFO reset
+   Uint16 RXFFOVRCLR:1;      // 14     Clear overflow
+   Uint16 RXFFOVF:1;         // 15     FIFO overflow
+
+}; 
+
+union SCIFFRX_REG {
+   Uint16               all;
+   struct SCIFFRX_BITS  bit;
+};
+
+// SCI FIFO control register bit definitions:
+struct  SCIFFCT_BITS {     // bits   description
+   Uint16 FFTXDLY:8;         // 7:0    FIFO transmit delay
+   Uint16 rsvd:5;            // 12:8   reserved
+   Uint16 CDC:1;             // 13     Auto baud mode enable
+   Uint16 ABDCLR:1;          // 14     Auto baud clear
+   Uint16 ABD:1;             // 15     Auto baud detect
+};
+
+union SCIFFCT_REG {
+   Uint16               all;
+   struct SCIFFCT_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// SCI Register File:
+//
+struct  SCI_REGS {
+   union SCICCR_REG     SCICCR;     // Communications control register
+   union SCICTL1_REG    SCICTL1;    // Control register 1
+   Uint16               SCIHBAUD;   // Baud rate (high) register
+   Uint16               SCILBAUD;   // Baud rate (low) register
+   union SCICTL2_REG    SCICTL2;    // Control register 2
+   union SCIRXST_REG    SCIRXST;    // Recieve status register
+   Uint16               SCIRXEMU;   // Recieve emulation buffer register
+   union SCIRXBUF_REG   SCIRXBUF;   // Recieve data buffer  
+   Uint16               rsvd1;      // reserved
+   Uint16               SCITXBUF;   // Transmit data buffer 
+   union SCIFFTX_REG    SCIFFTX;    // FIFO transmit register
+   union SCIFFRX_REG    SCIFFRX;    // FIFO recieve register
+   union SCIFFCT_REG    SCIFFCT;    // FIFO control register
+   Uint16               rsvd2;      // reserved
+   Uint16               rsvd3;      // reserved
+   union SCIPRI_REG     SCIPRI;     // FIFO Priority control   
+};
+
+//---------------------------------------------------------------------------
+// SCI External References & Function Declarations:
+//
+extern struct SCI_REGS SciaRegs;
+extern struct SCI_REGS ScibRegs;
+extern struct SCI_REGS ScicRegs;
+
+#endif  // end of DSP2833x_SCI_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Spi.h b/Inu/main_matlab/device_support/include/DSP2833x_Spi.h
new file mode 100644
index 0000000..68be21a
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Spi.h
@@ -0,0 +1,177 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: April 17, 2008   11:08:27 $
+//###########################################################################
+//
+// FILE:   DSP2833x_Spi.h
+//
+// TITLE:  DSP2833x Device SPI Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_SPI_H
+#define DSP2833x_SPI_H
+
+
+
+//---------------------------------------------------------------------------
+// SPI Individual Register Bit Definitions:
+//
+// SPI FIFO Transmit register bit    definitions:
+struct  SPIFFTX_BITS {       // bit    description
+   Uint16 TXFFIL:5;          // 4:0    Interrupt level
+   Uint16 TXFFIENA:1;        // 5      Interrupt enable
+   Uint16 TXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 TXFFINT:1;         // 7      INT flag
+   Uint16 TXFFST:5;          // 12:8   FIFO status
+   Uint16 TXFIFO:1;          // 13     FIFO reset
+   Uint16 SPIFFENA:1;        // 14     Enhancement enable
+   Uint16 SPIRST:1;          // 15     Reset SPI
+};
+
+union SPIFFTX_REG {
+   Uint16               all;
+   struct SPIFFTX_BITS  bit;
+};
+
+//--------------------------------------------
+// SPI FIFO recieve register bit definitions:
+//
+//
+struct  SPIFFRX_BITS {       // bits   description
+   Uint16 RXFFIL:5;          // 4:0    Interrupt level
+   Uint16 RXFFIENA:1;        // 5      Interrupt enable
+   Uint16 RXFFINTCLR:1;      // 6      Clear INT flag
+   Uint16 RXFFINT:1;         // 7      INT flag
+   Uint16 RXFFST:5;          // 12:8   FIFO status
+   Uint16 RXFIFORESET:1;     // 13     FIFO reset
+   Uint16 RXFFOVFCLR:1;      // 14     Clear overflow
+   Uint16 RXFFOVF:1;         // 15     FIFO overflow
+
+};
+
+union SPIFFRX_REG {
+   Uint16               all;
+   struct SPIFFRX_BITS  bit;
+};
+
+//--------------------------------------------
+// SPI FIFO control register bit definitions:
+//
+//
+struct  SPIFFCT_BITS {       // bits   description
+   Uint16 TXDLY:8;           // 7:0    FIFO transmit delay
+   Uint16 rsvd:8;            // 15:8   reserved
+};
+
+union SPIFFCT_REG {
+   Uint16               all;
+   struct SPIFFCT_BITS  bit;
+};
+
+//---------------------------------------------
+// SPI configuration register bit definitions:
+//
+//
+struct  SPICCR_BITS {        // bits   description
+   Uint16 SPICHAR:4;         // 3:0    Character length control
+   Uint16 SPILBK:1;          // 4      Loop-back enable/disable
+   Uint16 rsvd1:1;           // 5      reserved
+   Uint16 CLKPOLARITY:1;     // 6      Clock polarity
+   Uint16 SPISWRESET:1;      // 7      SPI SW Reset
+   Uint16 rsvd2:8;           // 15:8   reserved
+};
+
+union SPICCR_REG {
+   Uint16              all;
+   struct SPICCR_BITS  bit;
+};
+
+//-------------------------------------------------
+// SPI operation control register bit definitions:
+//
+//
+struct  SPICTL_BITS {        // bits   description
+   Uint16 SPIINTENA:1;       // 0      Interrupt enable
+   Uint16 TALK:1;            // 1      Master/Slave transmit enable
+   Uint16 MASTER_SLAVE:1;    // 2      Network control mode
+   Uint16 CLK_PHASE:1;       // 3      Clock phase select
+   Uint16 OVERRUNINTENA:1;   // 4      Overrun interrupt enable
+   Uint16 rsvd:11;           // 15:5   reserved
+};
+
+union SPICTL_REG {
+   Uint16              all;
+   struct SPICTL_BITS  bit;
+};
+
+//--------------------------------------
+// SPI status register bit definitions:
+//
+//
+struct  SPISTS_BITS {        // bits   description
+   Uint16 rsvd1:5;           // 4:0    reserved
+   Uint16 BUFFULL_FLAG:1;    // 5      SPI transmit buffer full flag
+   Uint16 INT_FLAG:1;        // 6      SPI interrupt flag
+   Uint16 OVERRUN_FLAG:1;    // 7      SPI reciever overrun flag
+   Uint16 rsvd2:8;           // 15:8   reserved
+};
+
+union SPISTS_REG {
+   Uint16              all;
+   struct SPISTS_BITS  bit;
+};
+
+//------------------------------------------------
+// SPI priority control register bit definitions:
+//
+//
+struct  SPIPRI_BITS {        // bits   description
+   Uint16 rsvd1:4;           // 3:0    reserved
+   Uint16 FREE:1;            // 4      Free emulation mode control
+   Uint16 SOFT:1;            // 5      Soft emulation mode control
+   Uint16 rsvd2:1;           // 6      reserved
+   Uint16 rsvd3:9;           // 15:7   reserved
+};
+
+union SPIPRI_REG {
+   Uint16              all;
+   struct SPIPRI_BITS  bit;
+};
+
+//---------------------------------------------------------------------------
+// SPI Register File:
+//
+struct  SPI_REGS {
+   union SPICCR_REG     SPICCR;      // Configuration register
+   union SPICTL_REG     SPICTL;      // Operation control register
+   union SPISTS_REG     SPISTS;      // Status register
+   Uint16               rsvd1;       // reserved
+   Uint16               SPIBRR;      // Baud Rate
+   Uint16               rsvd2;       // reserved
+   Uint16               SPIRXEMU;    // Emulation buffer
+   Uint16               SPIRXBUF;    // Serial input buffer
+   Uint16               SPITXBUF;    // Serial output buffer
+   Uint16               SPIDAT;      // Serial data
+   union SPIFFTX_REG    SPIFFTX;     // FIFO transmit register
+   union SPIFFRX_REG    SPIFFRX;     // FIFO recieve register
+   union SPIFFCT_REG    SPIFFCT;     // FIFO control register
+   Uint16               rsvd3[2];    // reserved
+   union SPIPRI_REG     SPIPRI;      // FIFO Priority control
+};
+
+//---------------------------------------------------------------------------
+// SPI External References & Function Declarations:
+//
+extern struct SPI_REGS SpiaRegs;
+
+
+#endif  // end of DSP2833x_SPI_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_SysCtrl.h b/Inu/main_matlab/device_support/include/DSP2833x_SysCtrl.h
new file mode 100644
index 0000000..520a904
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_SysCtrl.h
@@ -0,0 +1,376 @@
+// TI File $Revision: /main/5 $
+// Checkin $Date: May 12, 2008   09:34:58 $
+//###########################################################################
+//
+// FILE:   DSP2833x_SysCtrl.h
+//
+// TITLE:  DSP2833x Device System Control Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_SYS_CTRL_H
+#define DSP2833x_SYS_CTRL_H
+
+
+
+//---------------------------------------------------------------------------
+// System Control Individual Register Bit Definitions:
+//
+
+
+// PLL Status Register
+struct PLLSTS_BITS   {    // bits  description
+   Uint16 PLLLOCKS:1;     // 0     PLL lock status
+   Uint16 rsvd1:1;        // 1     reserved
+   Uint16 PLLOFF:1;       // 2     PLL off bit
+   Uint16 MCLKSTS:1;      // 3     Missing clock status bit
+   Uint16 MCLKCLR:1;      // 4     Missing clock clear bit
+   Uint16 OSCOFF:1;       // 5     Oscillator clock off
+   Uint16 MCLKOFF:1;      // 6     Missing clock detect
+   Uint16 DIVSEL:2;       // 7     Divide Select
+   Uint16 rsvd2:7;        // 15:7  reserved
+};
+
+union PLLSTS_REG {
+   Uint16              all;
+   struct PLLSTS_BITS  bit;
+};
+
+// High speed peripheral clock register bit definitions:
+struct HISPCP_BITS  {   // bits  description
+   Uint16 HSPCLK:3;     // 2:0   Rate relative to SYSCLKOUT
+   Uint16 rsvd1:13;     // 15:3  reserved
+};
+
+union HISPCP_REG {
+   Uint16              all;
+   struct HISPCP_BITS  bit;
+};
+
+// Low speed peripheral clock register bit definitions:
+struct LOSPCP_BITS  {   // bits  description
+   Uint16 LSPCLK:3;     // 2:0   Rate relative to SYSCLKOUT
+   Uint16 rsvd1:13;     // 15:3  reserved
+};
+
+union LOSPCP_REG {
+   Uint16              all;
+   struct LOSPCP_BITS  bit;
+};
+
+// Peripheral clock control register 0 bit definitions:
+struct PCLKCR0_BITS  {   // bits  description
+   Uint16 rsvd1:2;       // 1:0   reserved
+   Uint16 TBCLKSYNC:1;   // 2     EWPM Module TBCLK enable/sync
+   Uint16 ADCENCLK:1;    // 3     Enable high speed clk to ADC
+   Uint16 I2CAENCLK:1;   // 4     Enable SYSCLKOUT to I2C-A
+   Uint16 SCICENCLK:1;   // 5     Enalbe low speed clk to SCI-C
+   Uint16 rsvd2:2;       // 7:6   reserved
+   Uint16 SPIAENCLK:1;   // 8     Enable low speed clk to SPI-A
+   Uint16 rsvd3:1;       // 9     reserved
+   Uint16 SCIAENCLK:1;   // 10    Enable low speed clk to SCI-A
+   Uint16 SCIBENCLK:1;   // 11    Enable low speed clk to SCI-B
+   Uint16 MCBSPAENCLK:1; // 12    Enable low speed clk to McBSP-A
+   Uint16 MCBSPBENCLK:1; // 13    Enable low speed clk to McBSP-B
+   Uint16 ECANAENCLK:1;  // 14    Enable system clk to eCAN-A
+   Uint16 ECANBENCLK:1;  // 15    Enable system clk to eCAN-B
+};
+
+union PCLKCR0_REG {
+   Uint16              all;
+   struct PCLKCR0_BITS bit;
+};
+
+// Peripheral clock control register 1 bit definitions:
+struct PCLKCR1_BITS  {    // bits  description
+   Uint16 EPWM1ENCLK:1;   // 0     Enable SYSCLKOUT to EPWM1
+   Uint16 EPWM2ENCLK:1;   // 1     Enable SYSCLKOUT to EPWM2
+   Uint16 EPWM3ENCLK:1;   // 2     Enable SYSCLKOUT to EPWM3
+   Uint16 EPWM4ENCLK:1;   // 3     Enable SYSCLKOUT to EPWM4
+   Uint16 EPWM5ENCLK:1;   // 4     Enable SYSCLKOUT to EPWM5
+   Uint16 EPWM6ENCLK:1;   // 5     Enable SYSCLKOUT to EPWM6
+   Uint16 rsvd1:2;        // 7:6   reserved
+   Uint16 ECAP1ENCLK:1;   // 8     Enable SYSCLKOUT to ECAP1
+   Uint16 ECAP2ENCLK:1;   // 9     Enable SYSCLKOUT to ECAP2
+   Uint16 ECAP3ENCLK:1;   // 10    Enable SYSCLKOUT to ECAP3
+   Uint16 ECAP4ENCLK:1;   // 11    Enable SYSCLKOUT to ECAP4
+   Uint16 ECAP5ENCLK:1;   // 12    Enable SYSCLKOUT to ECAP5
+   Uint16 ECAP6ENCLK:1;   // 13    Enable SYSCLKOUT to ECAP6
+   Uint16 EQEP1ENCLK:1;   // 14    Enable SYSCLKOUT to EQEP1
+   Uint16 EQEP2ENCLK:1;   // 15    Enable SYSCLKOUT to EQEP2
+};
+
+union PCLKCR1_REG {
+   Uint16              all;
+   struct PCLKCR1_BITS bit;
+};
+
+
+// Peripheral clock control register 2 bit definitions:
+struct PCLKCR3_BITS  {        // bits  description
+   Uint16 rsvd1:8;            // 7:0   reserved
+   Uint16 CPUTIMER0ENCLK:1;   // 8     Enable SYSCLKOUT to CPU-Timer 0
+   Uint16 CPUTIMER1ENCLK:1;   // 9     Enable SYSCLKOUT to CPU-Timer 1
+   Uint16 CPUTIMER2ENCLK:1;   // 10    Enable SYSCLKOUT to CPU-Timer 2
+   Uint16 DMAENCLK:1;         // 11    Enable the DMA clock
+   Uint16 XINTFENCLK:1;       // 12    Enable SYSCLKOUT to XINTF
+   Uint16 GPIOINENCLK:1;      //     Enable GPIO input clock
+   Uint16 rsvd2:2;            // 15:14 reserved
+};
+
+union PCLKCR3_REG {
+   Uint16              all;
+   struct PCLKCR3_BITS bit;
+};
+
+
+
+// PLL control register bit definitions:
+struct PLLCR_BITS {      // bits  description
+   Uint16 DIV:4;         // 3:0   Set clock ratio for the PLL
+   Uint16 rsvd1:12;      // 15:4  reserved
+};
+
+union PLLCR_REG {
+   Uint16             all;
+   struct PLLCR_BITS  bit;
+};
+
+// Low Power Mode 0 control register bit definitions:
+struct LPMCR0_BITS {     // bits  description
+   Uint16 LPM:2;         // 1:0   Set the low power mode
+   Uint16 QUALSTDBY:6;   // 7:2   Qualification
+   Uint16 rsvd1:7;       // 14:8  reserved
+   Uint16 WDINTE:1;      // 15    Enables WD to wake the device from STANDBY
+};
+
+union LPMCR0_REG {
+   Uint16              all;
+   struct LPMCR0_BITS  bit;
+};
+
+// Dual-mapping configuration register bit definitions:
+struct MAPCNF_BITS {     // bits  description
+    Uint16 MAPEPWM:1;    // 0     EPWM dual-map enable
+    Uint16 rsvd1:15;     // 15:1  reserved
+};
+
+union MAPCNF_REG {
+	Uint16             all;
+	struct MAPCNF_BITS bit;
+};
+
+//---------------------------------------------------------------------------
+// System Control Register File:
+//
+struct SYS_CTRL_REGS {
+   Uint16              rsvd1;     // 0
+   union   PLLSTS_REG  PLLSTS;    // 1
+   Uint16              rsvd2[8];  // 2-9
+   union   HISPCP_REG  HISPCP;    // 10: High-speed peripheral clock pre-scaler
+   union   LOSPCP_REG  LOSPCP;    // 11: Low-speed peripheral clock pre-scaler
+   union   PCLKCR0_REG PCLKCR0;   // 12: Peripheral clock control register
+   union   PCLKCR1_REG PCLKCR1;   // 13: Peripheral clock control register
+   union   LPMCR0_REG  LPMCR0;    // 14: Low-power mode control register 0
+   Uint16              rsvd3;     // 15: reserved
+   union   PCLKCR3_REG PCLKCR3;   // 16: Peripheral clock control register
+   union   PLLCR_REG   PLLCR;     // 17: PLL control register
+   // No bit definitions are defined for SCSR because
+   // a read-modify-write instruction can clear the WDOVERRIDE bit
+   Uint16              SCSR;      // 18: System control and status register
+   Uint16              WDCNTR;    // 19: WD counter register
+   Uint16              rsvd4;     // 20
+   Uint16              WDKEY;     // 21: WD reset key register
+   Uint16              rsvd5[3];  // 22-24
+   // No bit definitions are defined for WDCR because
+   // the proper value must be written to the WDCHK field
+   // whenever writing to this register.
+   Uint16              WDCR;      // 25: WD timer control register
+   Uint16              rsvd6[4];  // 26-29
+   union   MAPCNF_REG  MAPCNF;    // 30: Dual-mapping configuration register
+   Uint16              rsvd7[1];  // 31
+};
+
+
+/* --------------------------------------------------- */
+/* CSM Registers                                       */
+/*                                                     */
+/* ----------------------------------------------------*/
+
+/* CSM Status & Control register bit definitions */
+struct  CSMSCR_BITS {      // bit   description
+   Uint16     SECURE:1;    // 0     Secure flag
+   Uint16     rsvd1:14;    // 14-1  reserved
+   Uint16     FORCESEC:1;  // 15    Force Secure control bit
+
+};
+
+/* Allow access to the bit fields or entire register */
+union CSMSCR_REG {
+   Uint16             all;
+   struct CSMSCR_BITS bit;
+};
+
+/* CSM Register File */
+struct  CSM_REGS {
+   Uint16           KEY0;    // KEY reg bits 15-0
+   Uint16           KEY1;    // KEY reg bits 31-16
+   Uint16           KEY2;    // KEY reg bits 47-32
+   Uint16           KEY3;    // KEY reg bits 63-48
+   Uint16           KEY4;    // KEY reg bits 79-64
+   Uint16           KEY5;    // KEY reg bits 95-80
+   Uint16           KEY6;    // KEY reg bits 111-96
+   Uint16           KEY7;    // KEY reg bits 127-112
+   Uint16           rsvd1;   // reserved
+   Uint16           rsvd2;   // reserved
+   Uint16           rsvd3;   // reserved
+   Uint16           rsvd4;   // reserved
+   Uint16           rsvd5;   // reserved
+   Uint16           rsvd6;   // reserved
+   Uint16           rsvd7;   // reserved
+   union CSMSCR_REG CSMSCR;  // CSM Status & Control register
+};
+
+/* Password locations */
+struct  CSM_PWL {
+   Uint16   PSWD0;  // PSWD bits 15-0
+   Uint16   PSWD1;  // PSWD bits 31-16
+   Uint16   PSWD2;  // PSWD bits 47-32
+   Uint16   PSWD3;  // PSWD bits 63-48
+   Uint16   PSWD4;  // PSWD bits 79-64
+   Uint16   PSWD5;  // PSWD bits 95-80
+   Uint16   PSWD6;  // PSWD bits 111-96
+   Uint16   PSWD7;  // PSWD bits 127-112
+};
+
+
+
+/* Flash Registers */
+
+#define FLASH_SLEEP   0x0000;
+#define FLASH_STANDBY 0x0001;
+#define FLASH_ACTIVE  0x0003;
+
+
+/* Flash Option Register bit definitions */
+struct  FOPT_BITS {       // bit   description
+   Uint16     ENPIPE:1;   // 0     Enable Pipeline Mode
+   Uint16     rsvd:15;    // 1-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FOPT_REG {
+   Uint16           all;
+   struct FOPT_BITS bit;
+};
+
+/* Flash Power Modes Register bit definitions */
+struct  FPWR_BITS {       // bit   description
+   Uint16     PWR:2;      // 0-1   Power Mode bits
+   Uint16     rsvd:14;    // 2-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FPWR_REG {
+   Uint16           all;
+   struct FPWR_BITS bit;
+};
+
+
+/* Flash Status Register bit definitions */
+struct  FSTATUS_BITS {       // bit   description
+   Uint16     PWRS:2;        // 0-1   Power Mode Status bits
+   Uint16     STDBYWAITS:1;  // 2     Bank/Pump Sleep to Standby Wait Counter Status bits
+   Uint16     ACTIVEWAITS:1; // 3     Bank/Pump Standby to Active Wait Counter Status bits
+   Uint16     rsvd1:4;       // 4-7   reserved
+   Uint16     V3STAT:1;      // 8     VDD3V Status Latch bit
+   Uint16     rsvd2:7;       // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FSTATUS_REG {
+   Uint16              all;
+   struct FSTATUS_BITS bit;
+};
+
+/* Flash Sleep to Standby Wait Counter Register bit definitions */
+struct  FSTDBYWAIT_BITS {    // bit   description
+   Uint16     STDBYWAIT:9;   // 0-8   Bank/Pump Sleep to Standby Wait Count bits
+   Uint16     rsvd:7;        // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FSTDBYWAIT_REG {
+   Uint16                 all;
+   struct FSTDBYWAIT_BITS bit;
+};
+
+/* Flash Standby to Active Wait Counter Register bit definitions */
+struct  FACTIVEWAIT_BITS {   // bit   description
+   Uint16     ACTIVEWAIT:9;  // 0-8   Bank/Pump Standby to Active Wait Count bits
+   Uint16     rsvd:7;        // 9-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FACTIVEWAIT_REG {
+   Uint16                  all;
+   struct FACTIVEWAIT_BITS bit;
+};
+
+/* Bank Read Access Wait State Register bit definitions */
+struct  FBANKWAIT_BITS {     // bit   description
+   Uint16     RANDWAIT:4;    // 0-3   Flash Random Read Wait State bits
+   Uint16     rsvd1:4;       // 4-7   reserved
+   Uint16     PAGEWAIT:4;    // 8-11  Flash Paged Read Wait State bits
+   Uint16     rsvd2:4;       // 12-15 reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FBANKWAIT_REG {
+   Uint16                all;
+   struct FBANKWAIT_BITS bit;
+};
+
+/* OTP Read Access Wait State Register bit definitions */
+struct  FOTPWAIT_BITS {      // bit   description
+   Uint16     OTPWAIT:5;     // 0-4   OTP Read Wait State bits
+   Uint16     rsvd:11;       // 5-15  reserved
+};
+
+/* Allow access to the bit fields or entire register */
+union FOTPWAIT_REG {
+   Uint16               all;
+   struct FOTPWAIT_BITS bit;
+};
+
+
+struct FLASH_REGS {
+   union FOPT_REG        FOPT;        // Option Register
+   Uint16                rsvd1;       // reserved
+   union FPWR_REG        FPWR;        // Power Modes Register
+   union FSTATUS_REG     FSTATUS;     // Status Register
+   union FSTDBYWAIT_REG  FSTDBYWAIT;  // Pump/Bank Sleep to Standby Wait State Register
+   union FACTIVEWAIT_REG FACTIVEWAIT; // Pump/Bank Standby to Active Wait State Register
+   union FBANKWAIT_REG   FBANKWAIT;   // Bank Read Access Wait State Register
+   union FOTPWAIT_REG    FOTPWAIT;    // OTP Read Access Wait State Register
+};
+
+//---------------------------------------------------------------------------
+// System Control External References & Function Declarations:
+//
+extern struct SYS_CTRL_REGS SysCtrlRegs;
+extern struct CSM_REGS CsmRegs;
+extern struct CSM_PWL CsmPwl;
+extern struct FLASH_REGS FlashRegs;
+
+
+#endif  // end of DSP2833x_SYS_CTRL_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_XIntrupt.h b/Inu/main_matlab/device_support/include/DSP2833x_XIntrupt.h
new file mode 100644
index 0000000..2fe44a0
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_XIntrupt.h
@@ -0,0 +1,76 @@
+// TI File $Revision: /main/1 $
+// Checkin $Date: August 18, 2006   13:52:39 $
+//###########################################################################
+//
+// FILE:  DSP2833x_XIntrupt.h
+//
+// TITLE: DSP2833x Device External Interrupt Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_XINTRUPT_H
+#define DSP2833x_XINTRUPT_H
+
+
+//---------------------------------------------------------------------------
+
+struct XINTCR_BITS {
+    Uint16   ENABLE:1;    // 0      enable/disable
+    Uint16   rsvd1:1;     // 1      reserved
+    Uint16   POLARITY:2;  // 3:2    pos/neg, both triggered
+    Uint16   rsvd2:12;    //15:4    reserved
+};
+
+union XINTCR_REG {
+   Uint16               all;
+   struct XINTCR_BITS   bit;
+};  
+
+struct XNMICR_BITS {
+    Uint16   ENABLE:1;    // 0      enable/disable
+    Uint16   SELECT:1;    // 1      Timer 1 or XNMI connected to int13
+    Uint16   POLARITY:2;  // 3:2    pos/neg, or both triggered
+    Uint16   rsvd2:12;    // 15:4   reserved
+};
+
+union XNMICR_REG {
+   Uint16               all;
+   struct XNMICR_BITS   bit;
+};  
+
+
+
+
+//---------------------------------------------------------------------------
+// External Interrupt Register File:
+//
+struct XINTRUPT_REGS {
+   union XINTCR_REG XINT1CR;
+   union XINTCR_REG XINT2CR;
+   union XINTCR_REG XINT3CR;
+   union XINTCR_REG XINT4CR;
+   union XINTCR_REG XINT5CR;
+   union XINTCR_REG XINT6CR;
+   union XINTCR_REG XINT7CR;
+   union XNMICR_REG XNMICR;
+   Uint16           XINT1CTR;
+   Uint16           XINT2CTR;
+   Uint16           rsvd[5];
+   Uint16           XNMICTR;
+};
+
+//---------------------------------------------------------------------------
+// External Interrupt References & Function Declarations:
+//
+extern struct XINTRUPT_REGS XIntruptRegs;
+
+#endif  // end of DSP2833x_XINTF_H definition
+
+//===========================================================================
+// End of file.
+//===========================================================================
+
diff --git a/Inu/main_matlab/device_support/include/DSP2833x_Xintf.h b/Inu/main_matlab/device_support/include/DSP2833x_Xintf.h
new file mode 100644
index 0000000..271f92a
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/DSP2833x_Xintf.h
@@ -0,0 +1,114 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: July 27, 2009   13:57:25 $
+//###########################################################################
+//
+// FILE:   DSP2833x_Xintf.h
+//
+// TITLE:  DSP2833x Device External Interface Register Definitions.
+//
+//###########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//###########################################################################
+#include "SimSupport_GlobalPrototypes.h"
+
+#ifndef DSP2833x_XINTF_H
+#define DSP2833x_XINTF_H
+
+
+
+
+// XINTF timing register bit definitions:
+struct XTIMING_BITS {    // bits  description
+   Uint16 XWRTRAIL:2;    // 1:0   Write access trail timing
+   Uint16 XWRACTIVE:3;   // 4:2   Write access active timing
+   Uint16 XWRLEAD:2;     // 6:5   Write access lead timing
+   Uint16 XRDTRAIL:2;    // 8:7   Read access trail timing
+   Uint16 XRDACTIVE:3;   // 11:9  Read access active timing
+   Uint16 XRDLEAD:2;     // 13:12 Read access lead timing
+   Uint16 USEREADY:1;    // 14    Extend access using HW waitstates
+   Uint16 READYMODE:1;   // 15    Ready mode
+   Uint16 XSIZE:2;       // 17:16 XINTF bus width - must be written as 11b
+   Uint16 rsvd1:4;       // 21:18 reserved
+   Uint16 X2TIMING:1;    // 22    Double lead/active/trail timing
+   Uint16 rsvd3:9;       // 31:23 reserved
+};
+
+union XTIMING_REG {
+   Uint32               all;
+   struct XTIMING_BITS  bit;
+};
+
+// XINTF control register bit definitions:
+struct XINTCNF2_BITS {    // bits  description
+   Uint16 WRBUFF:2;       // 1:0   Write buffer depth
+   Uint16 CLKMODE:1;      // 2     Ratio for XCLKOUT with respect to XTIMCLK
+   Uint16 CLKOFF:1;       // 3     Disable XCLKOUT
+   Uint16 rsvd1:2;        // 5:4   reserved
+   Uint16 WLEVEL:2;       // 7:6   Current level of the write buffer
+   Uint16 rsvd2:1;        // 8     reserved
+   Uint16 HOLD:1;         // 9     Hold enable/disable
+   Uint16 HOLDS:1;        // 10    Current state of HOLDn input
+   Uint16 HOLDAS:1;       // 11    Current state of HOLDAn output
+   Uint16 rsvd3:4;        // 15:12 reserved
+   Uint16 XTIMCLK:3;      // 18:16 Ratio for XTIMCLK
+   Uint16 rsvd4:13;       // 31:19 reserved
+};
+
+union XINTCNF2_REG {
+   Uint32                all;
+   struct XINTCNF2_BITS  bit;
+};
+
+// XINTF bank switching register bit definitions:
+struct XBANK_BITS {      // bits  description
+   Uint16  BANK:3;       // 2:0   Zone for which banking is enabled
+   Uint16  BCYC:3;       // 5:3   XTIMCLK cycles to add
+   Uint16  rsvd:10;      // 15:6  reserved
+};
+
+union XBANK_REG {
+   Uint16             all;
+   struct XBANK_BITS  bit;
+};
+
+struct XRESET_BITS {
+    Uint16  XHARDRESET:1;
+    Uint16  rsvd1:15;
+};
+
+union XRESET_REG {
+    Uint16            all;
+    struct XRESET_BITS bit;
+};
+
+
+//---------------------------------------------------------------------------
+// XINTF Register File:
+//
+struct XINTF_REGS {
+   union XTIMING_REG XTIMING0;
+   Uint32  rsvd1[5];
+   union XTIMING_REG XTIMING6;
+   union XTIMING_REG XTIMING7;
+   Uint32  rsvd2[2];
+   union XINTCNF2_REG XINTCNF2;
+   Uint32  rsvd3;
+   union XBANK_REG    XBANK;
+   Uint16  rsvd4;
+   Uint16  XREVISION;
+   Uint16  rsvd5[2];
+   union XRESET_REG   XRESET;
+};
+
+//---------------------------------------------------------------------------
+// XINTF External References & Function Declarations:
+//
+extern struct XINTF_REGS XintfRegs;
+
+
+#endif  // end of DSP2833x_XINTF_H definition
+
+//===========================================================================
+// No more.
+//===========================================================================
diff --git a/Inu/main_matlab/device_support/include/IQmathLib.h b/Inu/main_matlab/device_support/include/IQmathLib.h
new file mode 100644
index 0000000..5e27d84
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/IQmathLib.h
@@ -0,0 +1,687 @@
+//#define __IQMATHLIB_H_INCLUDED__
+
+
+/**
+* ��������� ���������� IQmath ��� ������������ � MATLAB
+*
+*/
+#ifndef IQ_MATH_LIB
+#define IQ_MATH_LIB
+
+
+#ifndef   GLOBAL_Q
+#define   GLOBAL_Q       24
+#endif
+
+typedef   long    _iq;
+typedef   long    _iq30;
+typedef   long    _iq29;
+typedef   long    _iq28;
+typedef   long    _iq27;
+typedef   long    _iq26;
+typedef   long    _iq25;
+typedef   long    _iq24;
+typedef   long    _iq23;
+typedef   long    _iq22;
+typedef   long    _iq21;
+typedef   long    _iq20;
+typedef   long    _iq19;
+typedef   long    _iq18;
+typedef   long    _iq17;
+typedef   long    _iq16;
+typedef   long    _iq15;
+typedef   long    _iq14;
+typedef   long    _iq13;
+typedef   long    _iq12;
+typedef   long    _iq11;
+typedef   long    _iq10;
+typedef   long    _iq9;
+typedef   long    _iq8;
+typedef   long    _iq7;
+typedef   long    _iq6;
+typedef   long    _iq5;
+typedef   long    _iq4;
+typedef   long    _iq3;
+typedef   long    _iq2;
+typedef   long    _iq1;
+
+//---------------------------------------------------------------------------
+#define _IQmpy2(A)          ((A)<<1)
+#define _IQmpy4(A)          ((A)<<2)
+#define _IQmpy8(A)          ((A)<<3)
+#define _IQmpy16(A)         ((A)<<4)
+#define _IQmpy32(A)         ((A)<<5)
+#define _IQmpy64(A)         ((A)<<6)
+
+#define _IQdiv2(A)          ((A)>>1)
+#define _IQdiv4(A)          ((A)>>2)
+#define _IQdiv8(A)          ((A)>>3)
+#define _IQdiv16(A)         ((A)>>4)
+#define _IQdiv32(A)         ((A)>>5)
+#define _IQdiv64(A)         ((A)>>6)
+//---------------------------------------------------------------------------
+#define   _IQ30(A)      (long) ((A) * 1073741824.0L)
+#define   _IQ29(A)      (long) ((A) * 536870912.0L)
+#define   _IQ28(A)      (long) ((A) * 268435456.0L)
+#define   _IQ27(A)      (long) ((A) * 134217728.0L)
+#define   _IQ26(A)      (long) ((A) * 67108864.0L)
+#define   _IQ25(A)      (long) ((A) * 33554432.0L)
+#define   _IQ24(A)      (long) ((A) * 16777216.0L)
+#define   _IQ23(A)      (long) ((A) * 8388608.0L)
+#define   _IQ22(A)      (long) ((A) * 4194304.0L)
+#define   _IQ21(A)      (long) ((A) * 2097152.0L)
+#define   _IQ20(A)      (long) ((A) * 1048576.0L)
+#define   _IQ19(A)      (long) ((A) * 524288.0L)
+#define   _IQ18(A)      (long) ((A) * 262144.0L)
+#define   _IQ17(A)      (long) ((A) * 131072.0L)
+#define   _IQ16(A)      (long) ((A) * 65536.0L)
+#define   _IQ15(A)      (long) ((A) * 32768.0L)
+#define   _IQ14(A)      (long) ((A) * 16384.0L)
+#define   _IQ13(A)      (long) ((A) * 8192.0L)
+#define   _IQ12(A)      (long) ((A) * 4096.0L)
+#define   _IQ11(A)      (long) ((A) * 2048.0L)
+#define   _IQ10(A)      (long) ((A) * 1024.0L)
+#define   _IQ9(A)       (long) ((A) * 512.0L)
+#define   _IQ8(A)       (long) ((A) * 256.0L)
+#define   _IQ7(A)       (long) ((A) * 128.0L)
+#define   _IQ6(A)       (long) ((A) * 64.0L)
+#define   _IQ5(A)       (long) ((A) * 32.0L)
+#define   _IQ4(A)       (long) ((A) * 16.0L)
+#define   _IQ3(A)       (long) ((A) * 8.0L)
+#define   _IQ2(A)       (long) ((A) * 4.0L)
+#define   _IQ1(A)       (long) ((A) * 2.0L)
+
+#if GLOBAL_Q == 30
+#define   _IQ(A)  _IQ30(A)
+#endif
+#if GLOBAL_Q == 29
+#define   _IQ(A)  _IQ29(A)
+#endif
+#if GLOBAL_Q == 28
+#define   _IQ(A)  _IQ28(A)
+#endif
+#if GLOBAL_Q == 27
+#define   _IQ(A)  _IQ27(A)
+#endif
+#if GLOBAL_Q == 26
+#define   _IQ(A)  _IQ26(A)
+#endif
+#if GLOBAL_Q == 25
+#define   _IQ(A)  _IQ25(A)
+#endif
+#if GLOBAL_Q == 24
+#define   _IQ(A)  _IQ24(A)
+#endif
+#if GLOBAL_Q == 23
+#define   _IQ(A)  _IQ23(A)
+#endif
+#if GLOBAL_Q == 22
+#define   _IQ(A)  _IQ22(A)
+#endif
+#if GLOBAL_Q == 21
+#define   _IQ(A)  _IQ21(A)
+#endif
+#if GLOBAL_Q == 20
+#define   _IQ(A)  _IQ20(A)
+#endif
+#if GLOBAL_Q == 19
+#define   _IQ(A)  _IQ19(A)
+#endif
+#if GLOBAL_Q == 18
+#define   _IQ(A)  _IQ18(A)
+#endif
+#if GLOBAL_Q == 17
+#define   _IQ(A)  _IQ17(A)
+#endif
+#if GLOBAL_Q == 16
+#define   _IQ(A)  _IQ16(A)
+#endif
+#if GLOBAL_Q == 15
+#define   _IQ(A)  _IQ15(A)
+#endif
+#if GLOBAL_Q == 14
+#define   _IQ(A)  _IQ14(A)
+#endif
+#if GLOBAL_Q == 13
+#define   _IQ(A)  _IQ13(A)
+#endif
+#if GLOBAL_Q == 12
+#define   _IQ(A)  _IQ12(A)
+#endif
+#if GLOBAL_Q == 11
+#define   _IQ(A)  _IQ11(A)
+#endif
+#if GLOBAL_Q == 10
+#define   _IQ(A)  _IQ10(A)
+#endif
+#if GLOBAL_Q == 9
+#define   _IQ(A)  _IQ9(A)
+#endif
+#if GLOBAL_Q == 8
+#define   _IQ(A)  _IQ8(A)
+#endif
+#if GLOBAL_Q == 7
+#define   _IQ(A)  _IQ7(A)
+#endif
+#if GLOBAL_Q == 6
+#define   _IQ(A)  _IQ6(A)
+#endif
+#if GLOBAL_Q == 5
+#define   _IQ(A)  _IQ5(A)
+#endif
+#if GLOBAL_Q == 4
+#define   _IQ(A)  _IQ4(A)
+#endif
+#if GLOBAL_Q == 3
+#define   _IQ(A)  _IQ3(A)
+#endif
+#if GLOBAL_Q == 2
+#define   _IQ(A)  _IQ2(A)
+#endif
+#if GLOBAL_Q == 1
+#define   _IQ(A)  _IQ1(A)
+#endif
+
+//---------------------------------------------------------------------------
+
+#define   _IQ30toF(A)      ((float) ((A) / 1073741824.0L))
+#define   _IQ29toF(A)      ((float) ((A) / 536870912.0L))
+#define   _IQ28toF(A)      ((float) ((A) / 268435456.0L))
+#define   _IQ27toF(A)      ((float) ((A) / 134217728.0L))
+#define   _IQ26toF(A)      ((float) ((A) / 67108864.0L))
+#define   _IQ25toF(A)      ((float) ((A) / 33554432.0L))
+#define   _IQ24toF(A)      ((float) ((A) / 16777216.0L))
+#define   _IQ23toF(A)      ((float) ((A) / 8388608.0L))
+#define   _IQ22toF(A)      ((float) ((A) / 4194304.0L))
+#define   _IQ21toF(A)      ((float) ((A) / 2097152.0L))
+#define   _IQ20toF(A)      ((float) ((A) / 1048576.0L))
+#define   _IQ19toF(A)      ((float) ((A) / 524288.0L))
+#define   _IQ18toF(A)      ((float) ((A) / 262144.0L))
+#define   _IQ17toF(A)      ((float) ((A) / 131072.0L))
+#define   _IQ16toF(A)      ((float) ((A) / 65536.0L))
+#define   _IQ15toF(A)      ((float) ((A) / 32768.0L))
+#define   _IQ14toF(A)      ((float) ((A) / 16384.0L))
+#define   _IQ13toF(A)      ((float) ((A) / 8192.0L))
+#define   _IQ12toF(A)      ((float) ((A) / 4096.0L))
+#define   _IQ11toF(A)      ((float) ((A) / 2048.0L))
+#define   _IQ10toF(A)      ((float) ((A) / 1024.0L))
+#define   _IQ9toF(A)       ((float) ((A) / 512.0L))
+#define   _IQ8toF(A)       ((float) ((A) / 256.0L))
+#define   _IQ7toF(A)       ((float) ((A) / 128.0L))
+#define   _IQ6toF(A)       ((float) ((A) / 64.0L))
+#define   _IQ5toF(A)       ((float) ((A) / 32.0L))
+#define   _IQ4toF(A)       ((float) ((A) / 16.0L))
+#define   _IQ3toF(A)       ((float) ((A) / 8.0L))
+#define   _IQ2toF(A)       ((float) ((A) / 4.0L))
+#define   _IQ1toF(A)       ((float) ((A) / 2.0L))
+
+#if GLOBAL_Q == 30
+#define   _IQtoF(A)  _IQ30toF(A)
+#endif
+#if GLOBAL_Q == 29
+#define   _IQtoF(A)  _IQ29toF(A)
+#endif
+#if GLOBAL_Q == 28
+#define   _IQtoF(A)  _IQ28toF(A)
+#endif
+#if GLOBAL_Q == 27
+#define   _IQtoF(A)  _IQ27toF(A)
+#endif
+#if GLOBAL_Q == 26
+#define   _IQtoF(A)  _IQ26toF(A)
+#endif
+#if GLOBAL_Q == 25
+#define   _IQtoF(A)  _IQ25toF(A)
+#endif
+#if GLOBAL_Q == 24
+#define   _IQtoF(A)  _IQ24toF(A)
+#endif
+#if GLOBAL_Q == 23
+#define   _IQtoF(A)  _IQ23toF(A)
+#endif
+#if GLOBAL_Q == 22
+#define   _IQtoF(A)  _IQ22toF(A)
+#endif
+#if GLOBAL_Q == 21
+#define   _IQtoF(A)  _IQ21toF(A)
+#endif
+#if GLOBAL_Q == 20
+#define   _IQtoF(A)  _IQ20toF(A)
+#endif
+#if GLOBAL_Q == 19
+#define   _IQtoF(A)  _IQ19toF(A)
+#endif
+#if GLOBAL_Q == 18
+#define   _IQtoF(A)  _IQ18toF(A)
+#endif
+#if GLOBAL_Q == 17
+#define   _IQtoF(A)  _IQ17toF(A)
+#endif
+#if GLOBAL_Q == 16
+#define   _IQtoF(A)  _IQ16toF(A)
+#endif
+#if GLOBAL_Q == 15
+#define   _IQtoF(A)  _IQ15toF(A)
+#endif
+#if GLOBAL_Q == 14
+#define   _IQtoF(A)  _IQ14toF(A)
+#endif
+#if GLOBAL_Q == 13
+#define   _IQtoF(A)  _IQ13toF(A)
+#endif
+#if GLOBAL_Q == 12
+#define   _IQtoF(A)  _IQ12toF(A)
+#endif
+#if GLOBAL_Q == 11
+#define   _IQtoF(A)  _IQ11toF(A)
+#endif
+#if GLOBAL_Q == 10
+#define   _IQtoF(A)  _IQ10toF(A)
+#endif
+#if GLOBAL_Q == 9
+#define   _IQtoF(A)  _IQ9toF(A)
+#endif
+#if GLOBAL_Q == 8
+#define   _IQtoF(A)  _IQ8toF(A)
+#endif
+#if GLOBAL_Q == 7
+#define   _IQtoF(A)  _IQ7toF(A)
+#endif
+#if GLOBAL_Q == 6
+#define   _IQtoF(A)  _IQ6toF(A)
+#endif
+#if GLOBAL_Q == 5
+#define   _IQtoF(A)  _IQ5toF(A)
+#endif
+#if GLOBAL_Q == 4
+#define   _IQtoF(A)  _IQ4toF(A)
+#endif
+#if GLOBAL_Q == 3
+#define   _IQtoF(A)  _IQ3toF(A)
+#endif
+#if GLOBAL_Q == 2
+#define   _IQtoF(A)  _IQ2toF(A)
+#endif
+#if GLOBAL_Q == 1
+#define   _IQtoF(A)  _IQ1toF(A)
+#endif
+
+#define   _IQsat(A, Pos, Neg)  ((A > Pos) ? Pos : (A < Neg) ? Neg : A)
+//---------------------------------------------------------------------------
+#define   _IQtoIQ30(A)  ((long) (A) << (30 - GLOBAL_Q))
+#define   _IQ30toIQ(A)  ((long) (A) >> (30 - GLOBAL_Q))
+
+#if (GLOBAL_Q >= 29)
+#define   _IQtoIQ29(A) ((long) (A) >> (GLOBAL_Q - 29))
+#define   _IQ29toIQ(A) ((long) (A) << (GLOBAL_Q - 29))
+#else
+#define   _IQtoIQ29(A) ((long) (A) << (29 - GLOBAL_Q))
+#define   _IQ29toIQ(A) ((long) (A) >> (29 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 28)
+#define   _IQtoIQ28(A) ((long) (A) >> (GLOBAL_Q - 28))
+#define   _IQ28toIQ(A) ((long) (A) << (GLOBAL_Q - 28))
+#else
+#define   _IQtoIQ28(A) ((long) (A) << (28 - GLOBAL_Q))
+#define   _IQ28toIQ(A) ((long) (A) >> (28 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 27)
+#define   _IQtoIQ27(A) ((long) (A) >> (GLOBAL_Q - 27))
+#define   _IQ27toIQ(A) ((long) (A) << (GLOBAL_Q - 27))
+#else
+#define   _IQtoIQ27(A) ((long) (A) << (27 - GLOBAL_Q))
+#define   _IQ27toIQ(A) ((long) (A) >> (27 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 26)
+#define   _IQtoIQ26(A) ((long) (A) >> (GLOBAL_Q - 26))
+#define   _IQ26toIQ(A) ((long) (A) << (GLOBAL_Q - 26))
+#else
+#define   _IQtoIQ26(A) ((long) (A) << (26 - GLOBAL_Q))
+#define   _IQ26toIQ(A) ((long) (A) >> (26 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 25)
+#define   _IQtoIQ25(A) ((long) (A) >> (GLOBAL_Q - 25))
+#define   _IQ25toIQ(A) ((long) (A) << (GLOBAL_Q - 25))
+#else
+#define   _IQtoIQ25(A) ((long) (A) << (25 - GLOBAL_Q))
+#define   _IQ25toIQ(A) ((long) (A) >> (25 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 24)
+#define   _IQtoIQ24(A) ((long) (A) >> (GLOBAL_Q - 24))
+#define   _IQ24toIQ(A) ((long) (A) << (GLOBAL_Q - 24))
+#else
+#define   _IQtoIQ24(A) ((long) (A) << (24 - GLOBAL_Q))
+#define   _IQ24toIQ(A) ((long) (A) >> (24 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 23)
+#define   _IQtoIQ23(A) ((long) (A) >> (GLOBAL_Q - 23))
+#define   _IQ23toIQ(A) ((long) (A) << (GLOBAL_Q - 23))
+#else
+#define   _IQtoIQ23(A) ((long) (A) << (23 - GLOBAL_Q))
+#define   _IQ23toIQ(A) ((long) (A) >> (23 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 22)
+#define   _IQtoIQ22(A) ((long) (A) >> (GLOBAL_Q - 22))
+#define   _IQ22toIQ(A) ((long) (A) << (GLOBAL_Q - 22))
+#else
+#define   _IQtoIQ22(A) ((long) (A) << (22 - GLOBAL_Q))
+#define   _IQ22toIQ(A) ((long) (A) >> (22 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 21)
+#define   _IQtoIQ21(A) ((long) (A) >> (GLOBAL_Q - 21))
+#define   _IQ21toIQ(A) ((long) (A) << (GLOBAL_Q - 21))
+#else
+#define   _IQtoIQ21(A) ((long) (A) << (21 - GLOBAL_Q))
+#define   _IQ21toIQ(A) ((long) (A) >> (21 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 20)
+#define   _IQtoIQ20(A) ((long) (A) >> (GLOBAL_Q - 20))
+#define   _IQ20toIQ(A) ((long) (A) << (GLOBAL_Q - 20))
+#else
+#define   _IQtoIQ20(A) ((long) (A) << (20 - GLOBAL_Q))
+#define   _IQ20toIQ(A) ((long) (A) >> (20 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 19)
+#define   _IQtoIQ19(A) ((long) (A) >> (GLOBAL_Q - 19))
+#define   _IQ19toIQ(A) ((long) (A) << (GLOBAL_Q - 19))
+#else
+#define   _IQtoIQ19(A) ((long) (A) << (19 - GLOBAL_Q))
+#define   _IQ19toIQ(A) ((long) (A) >> (19 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 18)
+#define   _IQtoIQ18(A) ((long) (A) >> (GLOBAL_Q - 18))
+#define   _IQ18toIQ(A) ((long) (A) << (GLOBAL_Q - 18))
+#else
+#define   _IQtoIQ18(A) ((long) (A) << (18 - GLOBAL_Q))
+#define   _IQ18toIQ(A) ((long) (A) >> (18 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 17)
+#define   _IQtoIQ17(A) ((long) (A) >> (GLOBAL_Q - 17))
+#define   _IQ17toIQ(A) ((long) (A) << (GLOBAL_Q - 17))
+#else
+#define   _IQtoIQ17(A) ((long) (A) << (17 - GLOBAL_Q))
+#define   _IQ17toIQ(A) ((long) (A) >> (17 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 16)
+#define   _IQtoIQ16(A) ((long) (A) >> (GLOBAL_Q - 16))
+#define   _IQ16toIQ(A) ((long) (A) << (GLOBAL_Q - 16))
+#else
+#define   _IQtoIQ16(A) ((long) (A) << (16 - GLOBAL_Q))
+#define   _IQ16toIQ(A) ((long) (A) >> (16 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 15)
+#define   _IQtoIQ15(A) ((long) (A) >> (GLOBAL_Q - 15))
+#define   _IQ15toIQ(A) ((long) (A) << (GLOBAL_Q - 15))
+#define   _IQtoQ15(A)  ((long) (A) >> (GLOBAL_Q - 15))
+#define   _Q15toIQ(A)  ((long) (A) << (GLOBAL_Q - 15))
+#else
+#define   _IQtoIQ15(A) ((long) (A) << (15 - GLOBAL_Q))
+#define   _IQ15toIQ(A) ((long) (A) >> (15 - GLOBAL_Q))
+#define   _IQtoQ15(A)  ((long) (A) << (15 - GLOBAL_Q))
+#define   _Q15toIQ(A)  ((long) (A) >> (15 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 14)
+#define   _IQtoIQ14(A) ((long) (A) >> (GLOBAL_Q - 14))
+#define   _IQ14toIQ(A) ((long) (A) << (GLOBAL_Q - 14))
+#define   _IQtoQ14(A)  ((long) (A) >> (GLOBAL_Q - 14))
+#define   _Q14toIQ(A)  ((long) (A) << (GLOBAL_Q - 14))
+#else
+#define   _IQtoIQ14(A) ((long) (A) << (14 - GLOBAL_Q))
+#define   _IQ14toIQ(A) ((long) (A) >> (14 - GLOBAL_Q))
+#define   _IQtoQ14(A)  ((long) (A) << (14 - GLOBAL_Q))
+#define   _Q14toIQ(A)  ((long) (A) >> (14 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 13)
+#define   _IQtoIQ13(A) ((long) (A) >> (GLOBAL_Q - 13))
+#define   _IQ13toIQ(A) ((long) (A) << (GLOBAL_Q - 13))
+#define   _IQtoQ13(A)  ((long) (A) >> (GLOBAL_Q - 13))
+#define   _Q13toIQ(A)  ((long) (A) << (GLOBAL_Q - 13))
+#else
+#define   _IQtoIQ13(A) ((long) (A) << (13 - GLOBAL_Q))
+#define   _IQ13toIQ(A) ((long) (A) >> (13 - GLOBAL_Q))
+#define   _IQtoQ13(A)  ((long) (A) << (13 - GLOBAL_Q))
+#define   _Q13toIQ(A)  ((long) (A) >> (13 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 12)
+#define   _IQtoIQ12(A) ((long) (A) >> (GLOBAL_Q - 12))
+#define   _IQ12toIQ(A) ((long) (A) << (GLOBAL_Q - 12))
+#define   _IQtoQ12(A)  ((long) (A) >> (GLOBAL_Q - 12))
+#define   _Q12toIQ(A)  ((long) (A) << (GLOBAL_Q - 12))
+#else
+#define   _IQtoIQ12(A) ((long) (A) << (12 - GLOBAL_Q))
+#define   _IQ12toIQ(A) ((long) (A) >> (12 - GLOBAL_Q))
+#define   _IQtoQ12(A)  ((long) (A) << (12 - GLOBAL_Q))
+#define   _Q12toIQ(A)  ((long) (A) >> (12 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 11)
+#define   _IQtoIQ11(A) ((long) (A) >> (GLOBAL_Q - 11))
+#define   _IQ11toIQ(A) ((long) (A) << (GLOBAL_Q - 11))
+#define   _IQtoQ11(A)  ((long) (A) >> (GLOBAL_Q - 11))
+#define   _Q11toIQ(A)  ((long) (A) << (GLOBAL_Q - 11))
+#else
+#define   _IQtoIQ11(A) ((long) (A) << (11 - GLOBAL_Q))
+#define   _IQ11toIQ(A) ((long) (A) >> (11 - GLOBAL_Q))
+#define   _IQtoQ11(A)  ((long) (A) << (11 - GLOBAL_Q))
+#define   _Q11toIQ(A)  ((long) (A) >> (11 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 10)
+#define   _IQtoIQ10(A) ((long) (A) >> (GLOBAL_Q - 10))
+#define   _IQ10toIQ(A) ((long) (A) << (GLOBAL_Q - 10))
+#define   _IQtoQ10(A)  ((long) (A) >> (GLOBAL_Q - 10))
+#define   _Q10toIQ(A)  ((long) (A) << (GLOBAL_Q - 10))
+#else
+#define   _IQtoIQ10(A) ((long) (A) << (10 - GLOBAL_Q))
+#define   _IQ10toIQ(A) ((long) (A) >> (10 - GLOBAL_Q))
+#define   _IQtoQ10(A)  ((long) (A) << (10 - GLOBAL_Q))
+#define   _Q10toIQ(A)  ((long) (A) >> (10 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 9)
+#define   _IQtoIQ9(A) ((long) (A) >> (GLOBAL_Q - 9))
+#define   _IQ9toIQ(A) ((long) (A) << (GLOBAL_Q - 9))
+#define   _IQtoQ9(A)  ((long) (A) >> (GLOBAL_Q - 9))
+#define   _Q9toIQ(A)  ((long) (A) << (GLOBAL_Q - 9))
+#else
+#define   _IQtoIQ9(A) ((long) (A) << (9 - GLOBAL_Q))
+#define   _IQ9toIQ(A) ((long) (A) >> (9 - GLOBAL_Q))
+#define   _IQtoQ9(A)  ((long) (A) << (9 - GLOBAL_Q))
+#define   _Q9toIQ(A)  ((long) (A) >> (9 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 8)
+#define   _IQtoIQ8(A) ((long) (A) >> (GLOBAL_Q - 8))
+#define   _IQ8toIQ(A) ((long) (A) << (GLOBAL_Q - 8))
+#define   _IQtoQ8(A)  ((long) (A) >> (GLOBAL_Q - 8))
+#define   _Q8toIQ(A)  ((long) (A) << (GLOBAL_Q - 8))
+#else
+#define   _IQtoIQ8(A) ((long) (A) << (8 - GLOBAL_Q))
+#define   _IQ8toIQ(A) ((long) (A) >> (8 - GLOBAL_Q))
+#define   _IQtoQ8(A)  ((long) (A) << (8 - GLOBAL_Q))
+#define   _Q8toIQ(A)  ((long) (A) >> (8 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 7)
+#define   _IQtoIQ7(A) ((long) (A) >> (GLOBAL_Q - 7))
+#define   _IQ7toIQ(A) ((long) (A) << (GLOBAL_Q - 7))
+#define   _IQtoQ7(A)  ((long) (A) >> (GLOBAL_Q - 7))
+#define   _Q7toIQ(A)  ((long) (A) << (GLOBAL_Q - 7))
+#else
+#define   _IQtoIQ7(A) ((long) (A) << (7 - GLOBAL_Q))
+#define   _IQ7toIQ(A) ((long) (A) >> (7 - GLOBAL_Q))
+#define   _IQtoQ7(A)  ((long) (A) << (7 - GLOBAL_Q))
+#define   _Q7toIQ(A)  ((long) (A) >> (7 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 6)
+#define   _IQtoIQ6(A) ((long) (A) >> (GLOBAL_Q - 6))
+#define   _IQ6toIQ(A) ((long) (A) << (GLOBAL_Q - 6))
+#define   _IQtoQ6(A)  ((long) (A) >> (GLOBAL_Q - 6))
+#define   _Q6toIQ(A)  ((long) (A) << (GLOBAL_Q - 6))
+#else
+#define   _IQtoIQ6(A) ((long) (A) << (6 - GLOBAL_Q))
+#define   _IQ6toIQ(A) ((long) (A) >> (6 - GLOBAL_Q))
+#define   _IQtoQ6(A)  ((long) (A) << (6 - GLOBAL_Q))
+#define   _Q6toIQ(A)  ((long) (A) >> (6 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 5)
+#define   _IQtoIQ5(A) ((long) (A) >> (GLOBAL_Q - 5))
+#define   _IQ5toIQ(A) ((long) (A) << (GLOBAL_Q - 5))
+#define   _IQtoQ5(A)  ((long) (A) >> (GLOBAL_Q - 5))
+#define   _Q5toIQ(A)  ((long) (A) << (GLOBAL_Q - 5))
+#else
+#define   _IQtoIQ5(A) ((long) (A) << (5 - GLOBAL_Q))
+#define   _IQ5toIQ(A) ((long) (A) >> (5 - GLOBAL_Q))
+#define   _IQtoQ5(A)  ((long) (A) << (5 - GLOBAL_Q))
+#define   _Q5toIQ(A)  ((long) (A) >> (5 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 4)
+#define   _IQtoIQ4(A) ((long) (A) >> (GLOBAL_Q - 4))
+#define   _IQ4toIQ(A) ((long) (A) << (GLOBAL_Q - 4))
+#define   _IQtoQ4(A)  ((long) (A) >> (GLOBAL_Q - 4))
+#define   _Q4toIQ(A)  ((long) (A) << (GLOBAL_Q - 4))
+#else
+#define   _IQtoIQ4(A) ((long) (A) << (4 - GLOBAL_Q))
+#define   _IQ4toIQ(A) ((long) (A) >> (4 - GLOBAL_Q))
+#define   _IQtoQ4(A)  ((long) (A) << (4 - GLOBAL_Q))
+#define   _Q4toIQ(A)  ((long) (A) >> (4 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 3)
+#define   _IQtoIQ3(A) ((long) (A) >> (GLOBAL_Q - 3))
+#define   _IQ3toIQ(A) ((long) (A) << (GLOBAL_Q - 3))
+#define   _IQtoQ3(A)  ((long) (A) >> (GLOBAL_Q - 3))
+#define   _Q3toIQ(A)  ((long) (A) << (GLOBAL_Q - 3))
+#else
+#define   _IQtoIQ3(A) ((long) (A) << (3 - GLOBAL_Q))
+#define   _IQ3toIQ(A) ((long) (A) >> (3 - GLOBAL_Q))
+#define   _IQtoQ3(A)  ((long) (A) << (3 - GLOBAL_Q))
+#define   _Q3toIQ(A)  ((long) (A) >> (3 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 2)
+#define   _IQtoIQ2(A) ((long) (A) >> (GLOBAL_Q - 2))
+#define   _IQ2toIQ(A) ((long) (A) << (GLOBAL_Q - 2))
+#define   _IQtoQ2(A)  ((long) (A) >> (GLOBAL_Q - 2))
+#define   _Q2toIQ(A)  ((long) (A) << (GLOBAL_Q - 2))
+#else
+#define   _IQtoIQ2(A) ((long) (A) << (2 - GLOBAL_Q))
+#define   _IQ2toIQ(A) ((long) (A) >> (2 - GLOBAL_Q))
+#define   _IQtoQ2(A)  ((long) (A) << (2 - GLOBAL_Q))
+#define   _Q2toIQ(A)  ((long) (A) >> (2 - GLOBAL_Q))
+#endif
+
+#if (GLOBAL_Q >= 1)
+#define   _IQtoQ1(A)  ((long) (A) >> (GLOBAL_Q - 1))
+#define   _Q1toIQ(A)  ((long) (A) << (GLOBAL_Q - 1))
+#else
+#define   _IQtoQ1(A)  ((long) (A) << (1 - GLOBAL_Q))
+#define   _Q1toIQ(A)  ((long) (A) >> (1 - GLOBAL_Q))
+#endif
+
+#define   _IQtoIQ1(A)   ((long) (A) >> (GLOBAL_Q - 1))
+#define   _IQ1toIQ(A)   ((long) (A) << (GLOBAL_Q - 1))
+
+/////////////////////////////////////////////////////////////
+long multiply(long x, long y);
+long long multiply_fixed_base_select(long long x, long long y, int base);
+long divide(long num, long den);
+long divide19(long num, long den);
+long divideN(long num, long den, unsigned int d);
+long sin_fixed(long x);
+long cos_fixed(long x);
+long sqrt_fixed(long x);
+long exp_fixed(long x);
+long exp_fixedN(long x, unsigned int n);
+
+#define   _IQabs(A)     ((A) > 0 ? (A): -(A))
+#define   _IQmpy(A,B)   multiply(A,B)
+#define   _IQ19mpy(A,B) multiply_fixed_base_select(A,B,19)
+#define   _IQ18mpy(A,B) multiply_fixed_base_select(A,B,18)
+
+#define   _IQdiv(A,B)  	divide(A,B)
+#define   _IQ19div(A,B)  	divide19(A,B)
+#define   _IQ18div(A,B)  	divideN(A,B,18)
+#define   _IQ22div(A,B)  	divideN(A,B,22)
+#define   _IQsin(A)  	sin_fixed(A)
+#define   _IQcos(A)  	cos_fixed(A)
+#define   _IQsinPU(A)  	sin_fixed(A)
+#define   _IQcosPU(A)  	cos_fixed(A)
+#define   _IQsqrt(A)    sqrt_fixed(A)
+#define   _IQexp(A)    exp_fixed(A)
+#define   _IQ18exp(A)    exp_fixedN(A,18)
+
+
+#define   _IQmpyI32(A,B)    ((A)*(B))
+
+
+#define PI 3.1415926535897932384626433832795
+#define PI_2 1.5707963267948966192313216916398
+#define TWO_PI 6.283185307179586476925286766559
+
+#ifndef ONE_24
+#define ONE_24 16777216
+#endif
+#ifndef ONE_27
+#define ONE_27 134217728
+#endif
+#ifndef ONE_28
+#define ONE_28 268435456
+#endif
+
+// #ifndef FIXED_PI
+// #define FIXED_PI 52707179
+// #endif
+
+// #ifndef FIXED_2PI
+// #define FIXED_2PI 105414357
+// #endif
+
+#ifndef FIXED_PI_30
+#define FIXED_PI_30 3373259426
+#endif
+
+#ifndef FIXED_2PI_30
+#define FIXED_2PI_30 6746518852
+#endif
+
+#ifndef FIXED_3PIna2
+#define FIXED_3PIna2 79060768
+#endif
+
+#ifndef FIXED_PIna3
+#define FIXED_PIna3 17569059
+#endif
+
+#ifndef FIXED_PIna6
+#define FIXED_PIna6 8784529
+#endif
+
+//###########################################################################
+// If FLOAT_MATH is used, the IQmath library function are replaced by
+// equivalent floating point operations:
+//===========================================================================
+
+#define   _IQ15sqrt(A)        sqrt(A)
+
+#endif //IQ_MATH_LIB
diff --git a/Inu/main_matlab/device_support/include/SimSupport_GlobalPrototypes.h b/Inu/main_matlab/device_support/include/SimSupport_GlobalPrototypes.h
new file mode 100644
index 0000000..ce32fdd
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/SimSupport_GlobalPrototypes.h
@@ -0,0 +1,5 @@
+#define cregister
+
+#define interrupt
+
+#define asm(...)
\ No newline at end of file
diff --git a/Inu/main_matlab/device_support/include/dmctype.h b/Inu/main_matlab/device_support/include/dmctype.h
new file mode 100644
index 0000000..31b11d8
--- /dev/null
+++ b/Inu/main_matlab/device_support/include/dmctype.h
@@ -0,0 +1,32 @@
+/* =================================================================================
+File name:        DMCTYPE.H                    
+                    
+Originator:	Digital Control Systems Group
+			Texas Instruments
+
+Description: DMC data type definition file.
+=====================================================================================
+ History:
+-------------------------------------------------------------------------------------
+ 04-15-2005	Version 3.20                                                  
+------------------------------------------------------------------------------*/
+ 
+#ifndef DMCTYPE
+#define DMCTYPE
+
+//---------------------------------------------------------------------------
+// For Portability, User Is Recommended To Use Following Data Type Size
+// Definitions For 16-bit and 32-Bit Signed/Unsigned Integers:
+//
+#ifndef DSP28_DATA_TYPES
+#define DSP28_DATA_TYPES
+typedef int             int16;
+typedef long            int32;
+typedef unsigned int    Uint16;
+typedef unsigned long   Uint32;
+typedef float           float32;
+typedef long double     float64;
+#endif
+
+#endif  // DMCTYPE
+
diff --git a/Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.c b/Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.c
new file mode 100644
index 0000000..38895d0
--- /dev/null
+++ b/Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.c
@@ -0,0 +1,52 @@
+#include "math.h"
+/*
+// Reciprocal (32-bit Precision)
+signed long int qinv1(signed short int x)
+{
+	return (signed long int)(2147483647.999/(double)x); //2147483648 ��� 2 � 31-�� �������
+}
+
+
+// Reciprocal (16-bit Precision)
+signed short int qinv2(signed short int x)
+{
+	return (signed short int)(32767.999/(double)x); //32768 ��� 2 � 15-�� �������
+}
+
+
+// SIN (Table look-up and Linear Interpolation)
+signed short int qsinlt(signed short int x)
+{
+	return (signed short int)(32767.999*sin((double)x*3.1415926535897932384626433832795/32768.));
+}
+
+
+// COS (Table look-up and Linear Interpolation)
+signed short int qcoslt(signed short int x)
+{
+	return (signed short int)(32767.999*cos((double)x*3.1415926535897932384626433832795/32768.));
+}
+
+
+// Fixed point Square-root (Taylor series implementation)
+unsigned short int qsqrt(unsigned long int x)
+{
+	return (unsigned short int)sqrt((double)x);
+}
+*/
+
+// Single-Precision Floating-Point 1.0/Square Root
+float isqrt(float x)
+{
+	return 1.0/sqrt(x);
+}
+
+
+// Single-Precision Floating-Point SIN and COS (radians)
+void sincos(float radian, float *ptrSin, float *ptrCos)
+{
+	*ptrSin = sin(radian);
+	*ptrCos = cos(radian);
+}
+
+
diff --git a/Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.obj b/Inu/main_matlab/device_support/source/C28x_FPU_FastRTS.obj
new file mode 100644
index 0000000000000000000000000000000000000000..51a7a69ad6f54480acee828e3926be67b8f762f5
GIT binary patch
literal 1685
zcma)6PiPZq6o1nhV~x6#>OsWA4%s<G7RT6%*jg}6wWgTXlB5P|a7;6kIyV2Dnbe|}
zE`q2<kY!nR6~(`M*gY%?9u_Yyb=Qg_is+%D;6*)nsI7|PLEoF1B$IgY!Q{Q~_kQoa
zFW>jxryTLZ^e@}ecUXWQz!pi-)r>i&I!joK#wDh*a<tb6lA;cmN5pu=^BWou8+ak`
zg(XuRH^qFR!t<js+5~U{KN3=cZ(vU&FNXMebj~;O#+9_0rbt_wQ7y#%yCvichNMzG
zZwV53<gIeJq%2-TJ|E)k-<Yo#d4rAl^!mEAKjW)>p^%i>J8EoLk6v2_P#tREffvt4
z5Y}$l+S4@{O+<Uc9sa)f&hA*kUk~nxZt3sp+Zy)^9Hx1L-!c5Q1Ji;Ex;s*RU5RK{
zSdO&@Ti2yi2a5V=N>RtOj4B)DQmLq$az2;R3YlD4QB&Qm8^`6IfkC+^ZJ4n{Tq+Ll
zgAV9yfnk9AupE4FS%a$X(=vL|C}vF|5L+$mD4AMbJE#>#gzjR#q~%nd_7FMzIxx=<
z-FQWdIo`L_*1M;({LsIV!#4v{ixBw^KMrWq-&<DXSW0Y8Vr-CKZHhwg<Oe?aJ~BCj
znP&OG|5h?Sd3%l@n#Sck-?G?(B9kdGgg76-AabII$09*_O2E8Sn}as|rKaG3;TYh;
zXrlOSW&QH_%c36}$Fk@ums=LYdw}2D1m5+{;Ej1o2m&>1MW~7FNZX>wl@?|*W;c($
z|LfDv$g^9``jz7?9WVbpwd>5e{pV+r7u$ZHcoDw0Y0c4**}(kScc<AKPcQxYkw3Gj
zf73~6`sXJ<y?%Z(ss5eoY%e^%HkG&YVJm0wuq92otZ~fe&s05>Rnw*v44!0Q!baSq
zO_RzpG~D&#9_uD_u?!7%y|_n}I+kVV)QJ7)Eq4fja=STnf-FPlL!4)SOkK4(nz3Iu
z5g}ngK(B!<STt;evykf20v(P`s3Em9h!IDO_E#s1cIc@?Xg?m1T!X&=5tgA_B6-mM
zAHEcXkr122;(+^E@gT}F)I(I`M>T%E7PSl!5{pw;Yaya6Lw!L~oLlz~SFJ@|PhxTE
zYSG?mwXVNqSJa{;D+a*gfaH3BXr^laYvS(A1^W&tpwo#WP7}!4oLM$h#Q_m<KT!A%
tVV;4Cv#JwliRHopt)PhZZHm^jTUj_R=UN?~vyx?9P3J;w*=*1)@CCIn7;^vs

literal 0
HcmV?d00001

diff --git a/Inu/main_matlab/device_support/source/DSP281x_GlobalVariableDefs.c b/Inu/main_matlab/device_support/source/DSP281x_GlobalVariableDefs.c
new file mode 100644
index 0000000..1841493
--- /dev/null
+++ b/Inu/main_matlab/device_support/source/DSP281x_GlobalVariableDefs.c
@@ -0,0 +1,265 @@
+// TI File $Revision: /main/3 $
+// Checkin $Date: July 9, 2009   17:28:45 $
+//###########################################################################
+//
+// FILE:    DSP281x_GlobalVariableDefs.c
+//
+// TITLE:   DSP281x Global Variables and Data Section Pragmas.
+//
+//###########################################################################
+// $TI Release: DSP281x C/C++ Header Files V1.20 $
+// $Release Date: July 27, 2009 $
+//###########################################################################
+
+#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
+
+//---------------------------------------------------------------------------
+// Define Global Peripheral Variables:
+//
+
+#ifdef __cplusplus
+#pragma DATA_SECTION("AdcRegsFile")
+#else
+#pragma DATA_SECTION(AdcRegs,"AdcRegsFile");
+#endif
+struct ADC_REGS AdcRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("CpuTimer0RegsFile")
+#else
+#pragma DATA_SECTION(CpuTimer0Regs,"CpuTimer0RegsFile");
+#endif
+struct CPUTIMER_REGS CpuTimer0Regs;
+//----------------------------------------
+
+#ifdef __cplusplus
+#pragma DATA_SECTION("CpuTimer1RegsFile")
+#else
+#pragma DATA_SECTION(CpuTimer1Regs,"CpuTimer1RegsFile");
+#endif
+struct CPUTIMER_REGS CpuTimer1Regs;
+//----------------------------------------
+
+#ifdef __cplusplus
+#pragma DATA_SECTION("CpuTimer2RegsFile")
+#else
+#pragma DATA_SECTION(CpuTimer2Regs,"CpuTimer2RegsFile");
+#endif
+struct CPUTIMER_REGS CpuTimer2Regs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ECanaRegsFile")
+#else
+#pragma DATA_SECTION(ECanaRegs,"ECanaRegsFile");
+#endif
+struct ECAN_REGS ECanaRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ECanaMboxesFile")
+#else
+#pragma DATA_SECTION(ECanaMboxes,"ECanaMboxesFile");
+#endif
+struct ECAN_MBOXES ECanaMboxes;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ECanaLAMRegsFile")
+#else
+#pragma DATA_SECTION(ECanaLAMRegs,"ECanaLAMRegsFile");
+#endif
+struct LAM_REGS ECanaLAMRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ECanaMOTSRegsFile")
+#else
+#pragma DATA_SECTION(ECanaMOTSRegs,"ECanaMOTSRegsFile");
+#endif
+struct MOTS_REGS ECanaMOTSRegs;
+
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ECanaMOTORegsFile")
+#else
+#pragma DATA_SECTION(ECanaMOTORegs,"ECanaMOTORegsFile");
+#endif
+struct MOTO_REGS ECanaMOTORegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("EvaRegsFile")
+#else
+#pragma DATA_SECTION(EvaRegs,"EvaRegsFile");
+#endif
+struct EVA_REGS EvaRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("EvbRegsFile")
+#else
+#pragma DATA_SECTION(EvbRegs,"EvbRegsFile");
+#endif
+struct EVB_REGS EvbRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("GpioDataRegsFile")
+#else
+#pragma DATA_SECTION(GpioDataRegs,"GpioDataRegsFile");
+#endif
+struct GPIO_DATA_REGS GpioDataRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("GpioMuxRegsFile")
+#else
+#pragma DATA_SECTION(GpioMuxRegs,"GpioMuxRegsFile");
+#endif
+struct GPIO_MUX_REGS GpioMuxRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("McbspaRegsFile")
+#else
+#pragma DATA_SECTION(McbspaRegs,"McbspaRegsFile");
+#endif
+struct MCBSP_REGS McbspaRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("PieCtrlRegsFile")
+#else
+#pragma DATA_SECTION(PieCtrlRegs,"PieCtrlRegsFile");
+#endif
+struct PIE_CTRL_REGS PieCtrlRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("PieVectTableFile")
+#else
+#pragma DATA_SECTION(PieVectTable,"PieVectTableFile");
+#endif
+struct PIE_VECT_TABLE PieVectTable;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("SciaRegsFile")
+#else
+#pragma DATA_SECTION(SciaRegs,"SciaRegsFile");
+#endif
+struct SCI_REGS SciaRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("ScibRegsFile")
+#else
+#pragma DATA_SECTION(ScibRegs,"ScibRegsFile");
+#endif
+struct SCI_REGS ScibRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("SpiaRegsFile")
+#else
+#pragma DATA_SECTION(SpiaRegs,"SpiaRegsFile");
+#endif
+struct SPI_REGS SpiaRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("SysCtrlRegsFile")
+#else
+#pragma DATA_SECTION(SysCtrlRegs,"SysCtrlRegsFile");
+#endif
+struct SYS_CTRL_REGS SysCtrlRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("DevEmuRegsFile")
+#else
+#pragma DATA_SECTION(DevEmuRegs,"DevEmuRegsFile");
+#endif
+struct DEV_EMU_REGS DevEmuRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("CsmRegsFile")
+#else
+#pragma DATA_SECTION(CsmRegs,"CsmRegsFile");
+#endif
+struct CSM_REGS CsmRegs;
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("CsmPwlFile")
+#else
+#pragma DATA_SECTION(CsmPwl,"CsmPwlFile");
+#endif
+struct CSM_PWL CsmPwl;
+
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("FlashRegsFile")
+#else
+#pragma DATA_SECTION(FlashRegs,"FlashRegsFile");
+#endif
+struct FLASH_REGS FlashRegs;
+
+#if DSP28_F2812
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("XintfRegsFile")
+#else
+#pragma DATA_SECTION(XintfRegs,"XintfRegsFile");
+#endif
+struct XINTF_REGS XintfRegs;
+#endif
+
+//----------------------------------------
+#ifdef __cplusplus
+#pragma DATA_SECTION("XIntruptRegsFile")
+#else
+#pragma DATA_SECTION(XIntruptRegs,"XIntruptRegsFile");
+#endif
+struct XINTRUPT_REGS XIntruptRegs;
+
+
+
+// The following are provided to support alternate notation
+// that was used in an early version of the header files
+
+#define ADCRegs       AdcRegs
+#define CPUTimer0Regs CpuTimer0Regs
+#define CPUTimer1Regs CpuTimer1Regs
+#define CPUTimer2Regs CpuTimer2Regs
+#define ECANARegs     ECanaRegs
+#define ECANAMboxes   ECanaMboxes
+#define EVARegs       EvaRegs
+#define GPIODataRegs  GpioDataRegs
+#define GPIOMuxRegs   GpioMuxRegs
+#define MCBSPARegs    McbspaRegs
+#define PIECtrlRegs   PieCtrlRegs
+#define PIEVectTable  PieVectTable
+#define SCIARegs      SciaRegs
+#define SCIBRegs      ScibRegs
+#define SYSCtrlRegs   SysCtrlRegs
+#define DEVEmuRegs    DevEmuRegs
+#define CSMRegs       CsmRegs
+#define CSMPwl        CsmPwl
+#define FLASHRegs     FlashRegs
+#define XINTFRegs     XintfRegs
+#define XINTRUPTRegs  XIntruptRegs
+
+
+
+
+
+
+
+
+
diff --git a/Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.c b/Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.c
new file mode 100644
index 0000000..57a84d5
--- /dev/null
+++ b/Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.c
@@ -0,0 +1,198 @@
+// TI File $Revision: /main/4 $
+// Checkin $Date: June 2, 2008   11:12:33 $
+//#########################################################################
+//
+// FILE:	DSP2833x_GlobalVariableDefs.c
+//
+// TITLE:	DSP2833x Global Variables and Data Section Pragmas.
+//
+//#########################################################################
+// $TI Release: 2833x/2823x Header Files V1.32 $
+// $Release Date: June 28, 2010 $
+//#########################################################################
+
+#include "DSP2833x_Device.h"     // DSP2833x Headerfile Include File
+
+//-------------------------------------------------------------------------
+// Define Global Peripheral Variables:
+//
+//----------------------------------------
+struct ADC_REGS AdcRegs;
+
+//----------------------------------------
+struct ADC_RESULT_MIRROR_REGS AdcMirror;
+
+//----------------------------------------
+struct CPUTIMER_REGS CpuTimer0Regs;
+
+//----------------------------------------
+struct CPUTIMER_REGS CpuTimer1Regs;
+
+//----------------------------------------
+struct CPUTIMER_REGS CpuTimer2Regs;
+
+//----------------------------------------
+struct CSM_PWL CsmPwl;
+
+//----------------------------------------
+struct CSM_REGS CsmRegs;
+
+//----------------------------------------
+struct DEV_EMU_REGS DevEmuRegs;
+
+//----------------------------------------
+struct DMA_REGS DmaRegs;
+
+//----------------------------------------
+struct ECAN_REGS ECanaRegs;
+
+//----------------------------------------
+struct ECAN_MBOXES ECanaMboxes;
+
+//----------------------------------------
+struct LAM_REGS ECanaLAMRegs;
+
+//----------------------------------------
+struct MOTS_REGS ECanaMOTSRegs;
+
+//----------------------------------------
+struct MOTO_REGS ECanaMOTORegs;
+
+//----------------------------------------
+struct ECAN_REGS ECanbRegs;
+
+//----------------------------------------
+struct ECAN_MBOXES ECanbMboxes;
+
+//----------------------------------------
+struct LAM_REGS ECanbLAMRegs;
+
+//----------------------------------------
+struct MOTS_REGS ECanbMOTSRegs;
+
+//----------------------------------------
+struct MOTO_REGS ECanbMOTORegs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm1Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm2Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm3Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm4Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm5Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm6Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm7Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm8Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm9Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm10Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm11Regs;
+
+//----------------------------------------
+struct EPWM_REGS EPwm12Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap1Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap2Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap3Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap4Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap5Regs;
+
+//----------------------------------------
+struct ECAP_REGS ECap6Regs;
+
+//----------------------------------------
+struct EQEP_REGS EQep1Regs;
+
+//----------------------------------------
+struct EQEP_REGS EQep2Regs;
+
+//----------------------------------------
+struct GPIO_CTRL_REGS GpioCtrlRegs;
+
+//----------------------------------------
+struct GPIO_DATA_REGS GpioDataRegs;
+
+//----------------------------------------
+struct GPIO_INT_REGS GpioIntRegs;
+
+//----------------------------------------
+struct I2C_REGS I2caRegs;
+
+//----------------------------------------
+struct MCBSP_REGS McbspaRegs;
+
+//----------------------------------------
+struct MCBSP_REGS McbspbRegs;
+
+//----------------------------------------
+struct PARTID_REGS PartIdRegs;
+
+//----------------------------------------
+struct PIE_CTRL_REGS PieCtrlRegs;
+
+//----------------------------------------
+struct PIE_VECT_TABLE PieVectTable;
+
+//----------------------------------------
+struct SCI_REGS SciaRegs;
+
+//----------------------------------------
+struct SCI_REGS ScibRegs;
+
+//----------------------------------------
+struct SCI_REGS ScicRegs;
+
+//----------------------------------------
+struct SPI_REGS SpiaRegs;
+
+//----------------------------------------
+struct SYS_CTRL_REGS SysCtrlRegs;
+
+//----------------------------------------
+struct FLASH_REGS FlashRegs;
+
+//----------------------------------------
+struct XINTRUPT_REGS XIntruptRegs;
+
+//----------------------------------------
+struct XINTF_REGS XintfRegs;
+
+//=========================================================================
+// End of file.
+//=========================================================================
+
+
+
+
+
+
+
+
+
diff --git a/Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.obj b/Inu/main_matlab/device_support/source/DSP2833x_GlobalVariableDefs.obj
new file mode 100644
index 0000000000000000000000000000000000000000..bd56dbedc65396e828c02146d05a62544886338c
GIT binary patch
literal 2096
zcmZvdO=uHA6vrn?57L9S^<u%pQi|v$P10Ix>0#3(Z3EdhCNUHYl>JIO?QVA6-L%z<
z1w}kq@KETrpgnofvsAp<g9kwnK~T@)MGz4L>zkR)Cgb>Eng9FEdv88>*SMcR$9wat
zA46ysF-sbrsRx^8=%O(Y4?9k$?H@o%!_?ZVqty;N0P&*ZgsqGQW|R8bhCewG^_&BB
z1IFX5A0bJS#`1-^?DbNuRGgh2QL6P^r8dIDrBZ$|s}!muQXk}hhi4C-I*JXFa=Gb-
zlC71pvn!QMDw9?lTaLHUFw9M?n=5|XbsaBQv8@Jf=~mk?8~JKEGc`WGy)th(nrhWm
z538DG=FO&`bhLFejb;XshR|Dd77d_7jG|V-y65;#GmtJ;E=fynfNgvmw^pT`W4qWg
zJ+%4r>F@f&r`JRCACJ-c(F~a%F<FO*BsLClU+m-rp#+kfrWzzusYfxi!$|KDkey1z
z$RY67yZv$KO2iKM0Pu=)70Sq75sRZ@;a`$9^oqIaqiq%fF~mrQOavGsr$NmmC<w_g
zINi#mXA~ZZ2r!nF0VNR^j1d`>1P?Jr7D261zeAS0onedtWQU8nDUdq?*#*K^-X}HK
zuwnC9$a*G_mjZbMgs=QwAYTOXRUkhE@`odNTcxM-iktH(xD@vwju`7063BUhTo6b~
zAkzZL3uI9s%L35^VhdzjAa{X$V9N^EwJVT)AQl(%1W1`9&w-G;NDS_LMyH$jfPt{`
z5yX&h2QjvX#{zi=gg@oaKsuK`j;b!Em1R-{42b?8qLCw%X+#)9U%4(JUEiSc4iR8+
zl=E$R?lSd5Qr?1vOA#UB7i94y4vUdV7Z_XD8E6(50Mh$8Ca-fMMn1^A4MPTe7ZmJy
zj)(H*X2EXL>6BG3C>m7e+;$DyrkCQpH0NcgSIDU?c8jS}G-uoN5!I!v(hX6TYD=6~
zjXb)8G)3!4*Lu@6E}eK$y31w-Bf8Oy-0@CvcOp`kBQ?oXdCLxSL4~=X!dy^cE~qdU
zR5$lZRAnksS0j~XTUUUTba#|=ILtM(Gi^|e&AZsi1)fDK5GSt&Y-5R2Yz4GK(KX*?
sm`b*HWo$;NpzH99uaSQps^0RWjyX&9*JzPtsOGg@R&g1(f+od(0kM-|MF0Q*

literal 0
HcmV?d00001

diff --git a/Inu/main_matlab/device_support/source/IQmathLib_matlab.c b/Inu/main_matlab/device_support/source/IQmathLib_matlab.c
new file mode 100644
index 0000000..aac0c57
--- /dev/null
+++ b/Inu/main_matlab/device_support/source/IQmathLib_matlab.c
@@ -0,0 +1,237 @@
+#include "IQmathLib.h"
+#include <math.h>
+
+
+// Преобразование числа с плавающей точкой в число с фиксированной точкой
+#define float_to_fixed(A)   (long)((A)*(1 << (GLOBAL_Q)) + (A > 0 ? 0.5: -0.5))
+// Преобразование числа с плавающей точкой в число с фиксированной точкой с выбором числа бит, отдаваемых под дробную часть
+#define float_to_fixed_base_select(A, F_BITS) (long)((A)*(1 << (F_BITS)) + (A > 0 ? 0.5: -0.5))
+// Преобразование целого числа в число с фиксированной точкой
+#define int_to_fixed(A) (long)((A) << (GLOBAL_Q))
+// Преобразование целого числа в число с фиксированной точкой  с выбором числа бит, отдаваемых под дробную часть
+#define int_to_fixed_base_select(A, F_BITS) (long)((A) << (F_BITS))
+//Преобразование числа с фиксированной точкой в число с плавающей точкой
+#define fixed_to_float(A) ((double)A / (1 << GLOBAL_Q))
+//Перобразование числа с фиксированной точкой в целое число
+#define fixed_to_int(A) ((int)(A >> GLOBAL_Q) )
+
+long _IQmag(long a, long b)
+{
+    return _IQsqrt(_IQmpy(a, a) + _IQmpy(b, b));
+}
+
+long multiply(long x, long y)
+{
+	long long z = (long long)x * (long long)y;
+	return (long)(z >> GLOBAL_Q);
+}
+//служебная функция. Умножает числа с 27 битами, отданными под дробную часть
+static inline long multiply_27(long x, long y)
+{
+    long long z = (long long)x * (long long)y;
+    return z & 0x4000000 ? (long)(z >> 27) + 1 : (long)(z >> 27);
+}
+
+long long multiply_fixed_base_select(long long x, long long y, int base)
+{
+    long long z = (long long)x * (long long)y;
+    return z & (1 << base) ? (z >> base) + 1 : (z >> base);
+}
+
+long divide(long num, long den)
+{
+    if (den == 0)
+        return 0;
+	long long numLong = (long long)num;
+    long long quotient = (numLong << GLOBAL_Q) / den;
+	return (long)quotient;
+}
+
+long divide19(long num, long den)
+{
+    if (den == 0)
+        return 0;
+	long long numLong = (long long)num;
+    long long quotient = (numLong << 19) / den;
+	return (long)quotient;
+}
+
+long divideN(long num, long den, unsigned int d)
+{
+    if (den == 0)
+        return 0;
+	long long numLong = (long long)num;
+    long long quotient = (numLong << d) / den;
+	return (long)quotient;
+}
+//
+static inline long long divide_fixed_base_select(long long num, long long den, int base)
+{
+    if (den == 0)
+        return 0;
+    long long quotient = ((long long)num << base) / den;
+    return quotient;
+}
+
+#define div_def(A,B) (long)(((long long)(A) << 24)/(B))
+#define div_mod(A,B) (A)%(B)
+#define mult_def(A,B) (long)((((long long)(A))*((long long)(B))) >> 24)
+#define abs_def(A) ((A) > 0 ? (A): -(A))
+
+long sin_fixed(long x)
+{
+    //Константы сделал ститическими, что бы они вычислялись во время запуска программы, а не исполнения
+    static long FIXED_2PI = float_to_fixed(TWO_PI);
+    static long FIXED_PI = float_to_fixed(PI);
+    static long FIXED_PIna2 = float_to_fixed(PI_2);
+    //Здесть так же что бы не производить операции деления посчитал констаны ряда Тейлора
+    static long one_110 = float_to_fixed_base_select(1./110, 27);
+    static long one_72 = float_to_fixed_base_select(1./72, 27);
+    static long one_42 = float_to_fixed_base_select(1./42, 27);
+    static long one_20= float_to_fixed_base_select(1./20, 27);
+    static long one_6 = float_to_fixed_base_select(1./6, 27);
+
+    long long xx, tmp ;
+    while(x >= FIXED_2PI) { x -= FIXED_2PI;}    //Помещаю аргумент в диапазон 2 ПИ
+    while(x <= -FIXED_2PI) { x += FIXED_2PI;}
+    //Так как ряды быстрее сходнятся при малых значениях, помещаю значение аргумента
+    //в ближайшие к нулю области
+    if(x > FIXED_PI)
+    {
+        x -= FIXED_2PI;
+    }
+    else if(x < -FIXED_PI)
+    {
+        x += FIXED_2PI;
+    }
+    if(x < -FIXED_PIna2)
+    {
+        x = -FIXED_PI - x;
+    }
+    else if(x > FIXED_PIna2)
+    {
+        x =  FIXED_PI - x;
+    }
+    //проверяю угол на значения, при которых синус раве 0 или 1
+    if(x == 0) return 0;
+    if(x == FIXED_PIna2) return int_to_fixed(1);
+    if(x == -FIXED_PIna2) return int_to_fixed(-1);
+    //Перевожу в формат с максимальной точностью для возможного дипазано значений
+    x <<= (27 - GLOBAL_Q);
+    //Считаю ряд фурье
+    xx = multiply_27(x, x);
+    tmp = ONE_27 - multiply_27(one_110, xx);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_72);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_42);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_20);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_6);
+    tmp = multiply_27(x, tmp);
+    return tmp >> (27 - GLOBAL_Q); //Перед возвращением из функции преобразую в первоначальный формат
+}
+
+long cos_fixed(long x)
+{
+    //Константы сделал ститическими, что бы они вычислялись во время запуска программы, а не исполнения
+    static long FIXED_2PI = float_to_fixed(TWO_PI);
+    static long FIXED_PI = float_to_fixed(PI);
+    static long FIXED_PIna2 = float_to_fixed(PI_2);
+    //Здесть так же что бы не производить операции деления посчитал констаны ряда Тейлора
+    static long one_132 = float_to_fixed_base_select(1./132, 27);
+    static long one_90 = float_to_fixed_base_select(1./90, 27);
+    static long one_56 = float_to_fixed_base_select(1./56, 27);
+    static long one_30 = float_to_fixed_base_select(1./30, 27);
+    static long one_12 = float_to_fixed_base_select(1./12, 27);
+
+    long xx, tmp, counter = 0;
+    while(x >= FIXED_2PI) { x -= FIXED_2PI;}    //Помещаю аргумент в диапазон 2 ПИ
+    while(x < 0) { x += FIXED_2PI;}
+    x = _IQabs(x);   //Так как косинус симметричен относительно нуля, нахожу его модуль
+    //проверяю угол на значения, при которых синус раве 0 или 1
+    if(x == 0) return 1 << GLOBAL_Q;
+    if(x == FIXED_PI) return -(1 << GLOBAL_Q);
+    if(x == (FIXED_PIna2) || (x == FIXED_3PIna2))return 0;
+    //Так как ряды быстрее сходнятся при малых значениях, помещаю значение аргумента
+    //в ближайшие к нулю области
+    while(x > FIXED_PIna2)
+    {
+        x -= FIXED_PIna2;
+        counter++;
+    }
+
+    if(counter == 1 || counter == 3) { x = FIXED_PIna2 - x;}
+    //Перевожу в формат с максимальной точностью для возможного дипазона значений
+    x <<= (27 - GLOBAL_Q);
+    //Считаю ряд фурье
+    xx = multiply_27(x, x);
+    tmp = ONE_27 - multiply_27(xx, one_132);
+    tmp= multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(xx, one_90);
+    tmp= multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_56);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_30);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - multiply_27(tmp, one_12);
+    tmp = multiply_27(xx, tmp);
+    tmp = ONE_27 - (tmp >> 1);
+    tmp >>= (27 - GLOBAL_Q);
+    return (counter == 0) || (counter == 3) ? tmp : -tmp;
+}
+
+long sqrt_fixed(long x)
+{
+    int variable_size_bits = sizeof(x) << 3;
+    long average_val, prev_avg_val;
+    if(x <= 0) return 0;
+    while(!(x & (1 << --variable_size_bits))); //Нахожу старший значащий бит
+    //Нахожу приближение корня сдвгом на половину числа бит между старшим значащим битом
+    //и положением точки
+    if(variable_size_bits > GLOBAL_Q)
+    {
+        average_val = x >> ((variable_size_bits - GLOBAL_Q) >> 1);
+    }
+    else
+    {
+        average_val = x << ((GLOBAL_Q - variable_size_bits) >> 1);
+    }
+    prev_avg_val = divide(x, average_val); //Нахожу 1/А
+    //В цикле нахожу среднее арифметическое между А и 1/А, пока число не перестанет меняться
+    while(_IQabs(prev_avg_val - average_val) > 1)
+    {
+        prev_avg_val = average_val;
+        average_val = (average_val + divide(x, average_val)) >> 1;
+    }
+    return average_val;
+}
+
+
+long exp_fixed(long x)
+{
+ //   static long FIXED_2PI = float_to_fixed(TWO_PI); 
+    float f = _IQtoF(x);
+    float r1 = exp(f);
+    if (r1>127) r1=127;
+    if (r1<-127) r1=-127;
+    long r2 = _IQ(r1);
+
+    return r2;
+}
+
+
+long exp_fixedN(long x, unsigned int n)
+{
+    if (n==18)
+    {
+        float f = _IQ18toF(x);
+        float r1 = exp(f);
+        if (r1>8100) r1=8100;
+        if (r1<-8100) r1=-8100;
+        long r2 = _IQ(r1);
+
+        return r2;
+    }
+}
\ No newline at end of file
diff --git a/inu_23550.slx b/inu_23550.slx
index d1fee4bbeb352089f0fbb5517ac10f0cca595e0a..0be3b616cc2f5c21b1078f250a87e624fd7a8d2a 100644
GIT binary patch
delta 60548
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

delta 60035
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

diff --git a/run_mex.bat b/run_mex.bat
index 5518865..1f29452 100644
--- a/run_mex.bat
+++ b/run_mex.bat
@@ -4,7 +4,7 @@ set defines=-D"ML" -D"__IQMATHLIB_H_INCLUDED__" -D"_MATLAB_SIMULATOR"^
  -D"_MATLAB_FAST_SIMULATOR" -D"PROJECT_SHIP=1"
  
 :: -------------------------USERS PATHS AND CODE---------------------------
-set includes_USER=-I"..\device_support_ml\include"^
+set includes_USER=-I".\Inu\main_matlab\device_support\include"^
  -I".\"^
  -I".\Inu"^
  -I".\Inu\tms_matlab\"^
@@ -15,7 +15,8 @@ set includes_USER=-I"..\device_support_ml\include"^
  -I".\Inu\Src\N12_Xilinx"
 
 :: исходный код
-set params_main_c=.\Inu\Src\main\adc_tools.c^
+set params_main_c=^
+ .\Inu\Src\main\adc_tools.c^
  .\Inu\Src\main\v_pwm24_v2.c^
  .\Inu\Src\main\calc_rms_vals.c^
  .\Inu\Src\main\alg_simple_scalar.c^
@@ -44,9 +45,9 @@ set params_libs_c=.\Inu\Src\N12_Libs\mathlib.c^
  .\Inu\Src\N12_Xilinx\xp_write_xpwm_time.c
  
  
-set params_device_support=..\device_support_ml\source\C28x_FPU_FastRTS.obj^
- ..\device_support_ml\source\DSP2833x_GlobalVariableDefs.obj^
- ..\device_support_ml\source\IQmathLib_matlab.c
+set params_device_support=.\Inu\main_matlab\device_support\source\C28x_FPU_FastRTS.obj^
+ .\Inu\main_matlab\device_support\source\DSP281x_GlobalVariableDefs.c^
+ .\Inu\main_matlab\device_support\source\IQmathLib_matlab.c
 
  
 set code_USER=%params_main_c% %params_vectorcontorl_c% %params_libs_c% %params_device_support%