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	_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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[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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%