C2804x C/C++ Header Files and Peripheral Examples Quick Start
C2804x C/C++ Header Files and Peripheral Examples Quick Start
Version 1.30
July 27, 2009
1
DSP2804x V1.30 Quick Start Readme
1 Introduction:
The DSP2804x C/C++ peripheral header files and example projects facilitate writing in C/C++
Code for the Texas Instruments TMS320x2804x DSPs. The code can be used as a learning tool
or as the basis for a development platform depending on the current needs of the user.
• Learning Tool:
This download includes several example Code Composer Studio™† projects for a ‘2804x
development platform.
These examples demonstrate the steps required to initialize the device and utilize the on-
chip peripherals. The provided examples can be copied and modified giving the user a
platform to quickly experiment with different peripheral configurations.
These projects can also be migrated to any future ‘2804x devices by simply changing the
memory allocation in the linker command file.
• Development Platform:
The peripheral header files can easily be incorporated into a new or existing project to
provide a platform for accessing the on-chip peripherals using C or C++ code. In addition,
the user can pick and choose functions from the provided code samples as needed and
discard the rest.
To get started this document provides the following information:
• Overview of the bit-field structure approach used in the DSP2804x C/C++ peripheral header
files.
• Steps for integrating the peripheral header files into a new or existing project.
†
Code Composer Studio is a trademark of Texas Instruments (www.ti.com).
2
DSP2804x V1.30 Quick Start Readme
3
DSP2804x V1.30 Quick Start Readme
Under the DSP2804x_headers and DSP2804x_common directories the source files are further
broken down into sub-directories each indicating the type of file. Table 2 lists the sub-directories
and describes the types of files found within each:
4
DSP2804x V1.30 Quick Start Readme
DSP2804x_headers\include Header files for each of the 2804x on-chip peripherals.
DSP2804x_common\cmd Example memory command files that allocate memory on the ‘2804x devices.
DSP2804x_common\include Common .h files that are used by the peripheral examples.
DSP2804x_common\source Common .c files that are used by the peripheral examples.
DSP2804x_common\lib Common library (.lib) files that are used by the peripheral examples.
DSP2804x_common\gel Code Composer Studio v3.x GEL files for each device. These are optional.
DSP2804x_common\gel\ccsv4 Code Composer Studio v4.x GEL files for each device. These are optional.
5
DSP2804x V1.30 Quick Start Readme
The DSP2804x C/C++ Header Files and Peripheral Examples in C use a bit-field structure
approach for mapping and accessing peripheral registers on the TI ‘2804x based DSPs. For
more information on using this technique, refer to the application note Programming
TMS32028xx and 28xxx Peripherals in C/C++ (SPRAA85).
This application note explores the hardware abstraction layer implementation to make C/C++
coding easier on 28x DSPs. This method is compared to traditional #define macros and topics of
code efficiency and special case registers are also addressed.
6
DSP2804x V1.30 Quick Start Readme
A brief description of the example and any assumptions that are made and any external
hardware requirements are listed in the comments at the top of the main source file of each
example. In some cases you may be required to make external connections for the example
to work properly.
4. Perform any hardware setup required by the example.
Perform any hardware setup indicated by the comments in the main source. The DSP2804x
CPU-Timer example only requires that the hardware be setup for “Boot to SARAM” mode.
Other examples may require additional hardware configuration such as connecting pins
together or pulling a pin high or low.
Table 3 shows a listing of the boot mode pin settings for your reference. Refer to the
documentation for your hardware platform for information on configuring the boot mode pins.
The ‘2804x boot modes are identical to those on the 280x. Refer to the TMS320x280x Boot
ROM Reference Guide (SPRU722) for more information.
7
DSP2804x V1.30 Quick Start Readme
8. When done, remove the example’s GEL file and project from Code Composer
Studio.
To remove the GEL file, right click on its name and select remove.
The examples use the header files in the DSP2804x_headers directory and shared source in the
DSP2804x_common directory. Only example files specific to a particular example are located
within in the example directory.
Note: Most of the example code included uses the .bit field structures to access registers.
This is done to help the user learn how to use the peripheral and device. Using the bit
fields has the advantage of yielding code that is easier to read and modify. This method
will result in a slight code overhead when compared to using the .all method. In addition,
the example projects have the compiler optimizer turned off. The user can change the
compiler settings to turn on the optimizer if desired.
NOTE: As supplied, the ‘280x example projects are built for the ‘2808 device. If you are
using another 280x device, the memory definition in the linker command file (.cmd) will need
to be changed and the project rebuilt.
2. Open the example project.
Each example has its own project directory which is “imported”/opened in Code Composer
Studio v4.
To open the ‘280x CPU-Timer example project directory, follow the following steps:
e. In Code Composer Studio v 4.x: Project->Import Existing CCS/CCE Eclipse Project.
f. Next to “Select Root Directory”, browse to the CPU Timer example directory:
DSP280x_examples_ccsv4\cpu_timer. Select the Finish button.
This will import/open the project in the CCStudio v4 C/C++ Perspective project.
9. Review the comments at the top of the main source file: Example_2804xCpuTimer.c.
A brief description of the example and any assumptions that are made and any external
hardware requirements are listed in the comments at the top of the main source file of each
example. In some cases you may be required to make external connections for the example
to work properly.
10. Perform any hardware setup required by the example.
Perform any hardware setup indicated by the comments in the main source. The DSP2804x
CPU-Timer example only requires that the hardware be setup for “Boot to SARAM” mode.
8
DSP2804x V1.30 Quick Start Readme
Other examples may require additional hardware configuration such as connecting pins
together or pulling a pin high or low.
Table 3 shows a listing of the boot mode pin settings for your reference. Refer to the
documentation for your hardware platform for information on configuring the boot mode pins.
The ‘2804x boot modes are identical to those on the 280x. Refer to the TMS320x280x Boot
ROM Reference Guide (SPRU722) for more information.
9
DSP2804x V1.30 Quick Start Readme
The examples use the header files in the DSP2802x_headers directory and shared source in
the DSP2802x_common directory. Only example files specific to a particular example are
located within in the example directory.
Note: Most of the example code included uses the .bit field structures to access
registers. This is done to help the user learn how to use the peripheral and device.
Using the bit fields has the advantage of yielding code that is easier to read and
modify. This method will result in a slight code overhead when compared to using the
.all method. In addition, the example projects have the compiler optimizer turned off.
The user can change the compiler settings to turn on the optimizer if desired.
10
DSP2804x V1.30 Quick Start Readme
DSP2804x_GlobalVariableDefs.c
This source file is required to use the DSP2804x
peripheral header files.
DSP2804x_Headers_nonBIOS.cmd
Linker file required by the peripheral specific header files.
Each of the example programs has a very similar structure. This structure includes unique
source code, shared source code, header files and linker command files.
/********************************************************************
* DSP2804x_examples\cpu_timer\Example_2804xCpuTimer.c
********************************************************************/
• DSP2804x_Device.h
This header file is required to use the DSP2804x peripheral header files. This file includes
all of the required peripheral specific header files and includes device specific macros and
typedef statements. This file is found in the <base>\DSP2804x_headers\include directory.
11
DSP2804x V1.30 Quick Start Readme
• DSP2804x_Examples.h
This header file defines parameters that are used by the example code. This file is not
required to use just the DSP2804x peripheral header files but is required by some of the
common source files. This file is found in the <base>\DSP2804x_common\include
directory.
• DSP2804x_GlobalVariableDefs.c
Any project that uses the DSP2804x peripheral header files must include this source file. In
this file are the declarations for the peripheral register structure variables and data section
assignments. This file is found in the <base>\DSP2804x_headers\source directory.
12
DSP2804x V1.30 Quick Start Readme
13
DSP2804x V1.30 Quick Start Readme
Reset
Boot ROM
DSP2804x_CodeStartBranch.asm
Used to re-direct code execution from the boot
Boot Sequence
entry point to the C Init routine.
Code can be configured to disable the
WatchDog if the WD is timing out before main()
is reached.
DSP2804x_CodeStartBranch.asm
Assigned to the BEGIN section by the linker.
Disable WD (Optional)
Located at 0x000000 for Boot to M0
Branch to C Init Routine Located at 0x3F7FF6 for Boot to Flash
C Init Routine
The Compiler's boot.asm which is
C Init automatically included with the runtime
library. This will set OBJMODE to 28x.
Init PLL, Turn on Peripheral Clocks and set the
main()
clock pre-scalers
{ Initialize System Control Disable the WatchDog
14
DSP2804x V1.30 Quick Start Readme
15
DSP2804x V1.30 Quick Start Readme
Included Examples Continued…
spi_loopback_interrupts SPI-A example that uses the peripherals loop-back test mode to send data. Both
interrupts and FIFOs are used in this example.
sw_prioritized_interrupts The standard hardware prioritization of interrupts can be used for most applications.
This example shows a method for software to re-prioritize interrupts if required.
watchdog Illustrates feeding the dog and re-directing the watchdog to an interrupt.
16
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* DSP2804x_common\source\DSP2804x_SysCtrl.c
********************************************************************/
The ramfuncs section is then assigned to a load address in flash and a run address in
SARAM by the memory linker command file as shown below:
/********************************************************************
* DSP2804x_common\include\F28044.cmd
********************************************************************/
SECTIONS
{
ramfuncs : LOAD = FLASHD,
RUN = RAML0,
LOAD_START(_RamfuncsLoadStart),
LOAD_END(_RamfuncsLoadEnd),
RUN_START(_RamfuncsRunStart),
PAGE = 0
}
17
DSP2804x V1.30 Quick Start Readme
The linker will assign symbols as specified above to specific addresses as follows:
Address Symbol
Load start address RamfuncsLoadStart
Load end address RamfuncsLoadEnd
Run start address RamfuncsRunStart
These symbols can then be used to copy the functions from the Flash to SARAM using the
included example MemCopy routine or the C library standard memcopy() function.
To perform this copy from flash to SARAM using the included example MemCopy function:
a. Add the file DSP2804x_common\source\DSP2804x_MemCopy.c to the project.
b. Add the following function prototype to the example source code. This is done for you in
the DSP2804x_Examples.h file.
/********************************************************************
* DSP2804x_common\include\DSP2804x_Examples.h
********************************************************************/
c. Add the following variable declaration to your source code to tell the compiler that these
variables exist. The linker command file will assign the address of each of these
variables as specified in the linker command file as shown in step 3. For the DSP2804x
example code this has is already done in DSP2804x_Examples.h.
/********************************************************************
* DSP2804x_common\include\DSP2804x_GlobalPrototypes.h
********************************************************************/
d. Modify the code to call the example MemCopy function for each section that needs to be
copied from flash to SARAM.
/********************************************************************
* DSP2804x_examples\Flash source file
********************************************************************/
18
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* DSP2804x peripheral example .c file
********************************************************************/
InitFlash();
Refer to the documentation for your hardware platform for information on configuring the
boot mode selection pins.
The 2804x boot modes are identical to the 280x. For more information refer to the
TMS320x280x, 2801x, 2804x DSP Boot ROM Reference Guide (SPRU722).
6. Program the device with the built code.
In Code Composer Studio v4.0, when code is loaded into the device during debug, it
automatically programs to flash memory.
This can be done using SDFlash available from Spectrum Digital’s website
(www.spectrumdigital.com). In addition the C2000 on-chip Flash programmer plug-in for
Code Composer Studio v3.0 can be used.
These tools will be updated to support new devices as they become available. Please
check for updates.
7. In Code Composer Studio v3, to debug, load the project in CCS, select File->Load
Symbols->Load Symbols Only.
It is useful to load only symbol information when working in a debugging environment where
the debugger cannot or need not load the object code, such as when the code is in ROM or
flash. This operation loads the symbol information from the specified file.
19
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* User’s source file
********************************************************************/
#include “DSP2804x_Device.h”
2. Edit DSP2804x_Device.h and select the target you are building for:
In the below example, the file is configured to build for the ‘28044 device.
/********************************************************************
* DSP2804x_headers\include\DSP2804x_Device.h
********************************************************************/
#define TARGET 1
#define DSP28_28044 TARGET
20
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* User’s linker .cmd file
********************************************************************/
†
DSP/BIOS is a trademark of Texas Instruments
21
DSP2804x V1.30 Quick Start Readme
2) Add the directory path to the DSP2804x peripheral linker .cmd file to your
project.
Code Composer Studio 3.x
a. Open the menu: Project->Build Options
b. Select the Linker tab and then Select Basic.
c. In the Library Search Path, add the directory path to the location of the
DSP2804x_headers\cmd directory on your system.
Code Composer Studio 4.x:
Method #1:
a. Right-click on the project in the project window of the C/C++ Projects perspective.
a. Right-click on the project in the project window of the C/C++ Projects perspective.
b. Select New->File.
e. Select the Variables… button. From the list, pick the linked variable (macro defined in
your macros.ini file) associated with your installation directory. (For the 2804x header
files, this is INSTALLROOT_2804X_V<version #>). For more information on linked
variables and the macros.ini file, see:
http://tiexpressdsp.com/index.php/Portable_Projects_in_CCSv4_for_C2000#Method_.2
32_for_Linking_Files_to_Project:
f. Click on the Extend…” button. Navigate to the desired .cmd file and select OK.
22
DSP2804x V1.30 Quick Start Readme
5. Add the directory path to the DSP2804x header files to your project.
Code Composer Studio 3.x:
To specify the directory where the header files are located:
a. Open the menu: Project->Build Options
b. Select the Compiler tab
c. Select pre-processor.
d. In the Include Search Path, add the directory path to the location of
DSP2804x_headers\include on your system.
Code Composer Studio 4.x:
To specify the directory where the header files are located:
a. Open the menu: Project->Properties.
b. In the menu on the left, select “C/C++ Build”.
c. In the “Tool Settings” tab, Select “C2000 Compiler -> Include Options:”
d. In the “Add dir to #include search path (--include_path, -I” window, select the “Add” icon
in the top right corner.
e. Select the “File system…” button and navigate to the directory path of
DSP2804x_headers\include on your system.
6. Additional suggested build options:
The following are additional compiler and linker options. The options can all be set via the
Project->Build Options menu.
– Compiler Tab:
-ml Select Advanced and check –ml
Build for large memory model. This setting allows data sections to reside anywhere
within the 4M-memory reach of the 28x devices.
-pdr Select Diagnostics and check –pdr
Issue non-serious warnings. The compiler uses a warning to indicate code that is
valid but questionable. In many cases, these warnings issued by enabling -pdr can
alert you to code that may cause problems later on.
– Linker Tab:
-w Select Advanced and check –w
Warn about output sections. This option will alert you if any unassigned memory
sections exist in your code. By default the linker will attempt to place any
unassigned code or data section to an available memory location without alerting the
user. This can cause problems, however, when the section is placed in an
unexpected location.
-e Select Basic and enter Code Entry Point –e
23
DSP2804x V1.30 Quick Start Readme
Defines a global symbol that specifies the primary entry point for the output module.
For the DSP2804x examples, this is the symbol “code_start”. This symbol is defined
in the DSP2804x_common\source\DSP2804x_CodeStartBranch.asm file. When
you load the code in Code Composer Studio, the debugger will set the PC to the
address of this symbol. If you do not define a entry point using the –e option, then
the linker will use _c_int00 by default.
/********************************************************************
* User’s source file
********************************************************************/
#include “DSP2804x_Examples.h”
2. Add the directory path to the example include files to your project.
Code Composer Studio 3.x
To specify the directory where the header files are located:
a. Open the menu: Project->Build Options
b. Select the Compiler tab
c. Select pre-processor.
d. In the Include Search Path, add the directory path to the location of
DSP2804x_common/include on your system.
Use a semicolon between directories.
For example the directory path for the included projects is:
..\..\DSP2804x_headers\include;..\..\DSP2804x_common\include
Code Composer Studio 4.x:
To specify the directory where the header files are located:
a. Open the menu: Project->Properties.
b. In the menu on the left, select “C/C++ Build”.
c. In the “Tool Settings” tab, Select “C2000 Compiler -> Include Options:”
d. In the “Add dir to #include search path (--include_path, -I” window, select the “Add” icon
in the top right corner.
e. Select the “File system…” button and navigate to the directory path of
DSP2804x_headers\include on your system.
24
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* DSP2804x_common\include\DSP2804x_Examples.h
********************************************************************/
25
DSP2804x V1.30 Quick Start Readme
• Peripheral registers cannot be modified or unless the clock to the specific peripheral is
enabled. The function InitPeripheralClocks() in the DSP2804x_common\source
directory shows an example of enabling the peripheral clocks.
• Some peripherals are not present on all 2804x family derivatives. Refer to the device
datasheet for information on which peripherals are available.
• The EALLOW bit protects some registers from spurious writes by the CPU. If your
program seems unable to write to a register, then check to see if it is EALLOW
protected. If it is, then enable access using the EALLOW assembly instruction.
TMS320x280x Control and Interrupts Reference Guide (SPRU712) for a preliminary list
of EALLOW protected registers.
26
DSP2804x V1.30 Quick Start Readme
• I re-built one of the projects to run from Flash and now it doesn’t work. What could be
wrong?
Make sure all initialized sections have been moved to flash such as .econst and .switch.
If you are using SDFlash, make sure that all initialized sections, including .econst, are
allocated to page 0 in the linker command file (.cmd). SDFlash will only program sections
in the .out file that are allocated to page 0.
• Why do the examples populate the PIE vector table and then re-assign some of the
function pointers to other ISRs?
The examples share a common default ISR file. This file is used to populate the PIE vector
table with pointers to default interrupt service routines. Any ISR used within the example is
then remapped to a function within the same source file. This is done for the following
reasons:
– The entire PIE vector table is enabled, even if the ISR is not used within the example.
This can be very useful for debug purposes.
– The default ISR file is left un-modified for use with other examples or your own project
as you see fit.
– It illustrates how the PIE table can be updated at a later time.
• When I build the examples, the linker outputs the following: warning: entry point
other than _c_int00 specified. What does this mean?
This warning is given when a symbol other then _c_int00 is defined as the code entry point
of the project. For these examples, the symbol code_start is the first code that is executed
after exiting the boot ROM code and thus is defined as the entry point via the –e linker
option. This symbol is defined in the DSP2804x_CodeStartBranch.asm file. The entry point
symbol is used by the debugger and by the hex utility. When you load the code, CCS will
set the PC to the entry point symbol. By default, this is the _c_int00 symbol which marks
the start of the C initialization routine. For the DSP2804x examples, the code_start symbol
is used instead. Refer to the source code for more information.
• When I build many of the examples, the compiler outputs the following: remark:
controlling expression is constant. What does this mean?
Some of the examples run forever until the user stops execution by using a while(1) {} loop
The remark refers to the while loop using a constant and thus the loop will never be exited.
• When I build some of the examples, the compiler outputs the following: warning:
statement is unreachable. What does this mean?
27
DSP2804x V1.30 Quick Start Readme
Some of the examples run forever until the user stops execution by using a while(1) {} loop.
If there is code after this while(1) loop then it will never be reached.
• I changed the build configuration of one of the projects from “Debug” to “Release”
and now the project will not build. What could be wrong?
When you switch to a new build configuration (Project->Configurations) the compiler and
linker options changed for the project. The user must enter other options such as include
search path and the library search path. Open the build options menu (Project->Build
Options) and enter the following information:
– Compiler Tab, Preprocessor: Include search path
– Linker Tab, Basic: Library search path
– Linker Tab, Basic: Include libraries (ie rts2800_ml.lib)
Refer to section 4 for more details.
• In the flash example I loaded the symbols and ran to main. I then set a breakpoint but
the breakpoint is never hit. What could be wrong?
In the Flash example, the InitFlash function and several of the ISR functions are copied out
of flash into SARAM. When you set a breakpoint in one of these functions, Code Composer
will insert an ESTOP0 instruction into the SARAM location. When the ESTOP0 instruction
is hit, program execution is halted. CCS will then remove the ESTOP0 and replace it with
the original opcode. In the case of the flash program, when one of these functions is
copied from Flash into SARAM, the ESTOP0 instruction is overwritten code. This is why the
breakpoint is never hit. To avoid this, set the breakpoint after the SARAM functions have
been copied to SARAM.
5.1.1 Registers with multiple flag bits in which writing a 1 clears that flag.
For example, consider the PIEACK register. Bits within this register are cleared when writing a 1
to that bit. If more then one bit is set, performing a read-modify-write on the register may clear
more bits then intended.
The below solution is incorrect. It will write a 1 to any bit set and thus clear all of them:
28
DSP2804x V1.30 Quick Start Readme
/********************************************************************
* User’s source file
********************************************************************/
The correct solution is to write a mask value to the register in which only the intended bit will
have a 1 written to it:
/********************************************************************
* User’s source file
********************************************************************/
29
DSP2804x V1.30 Quick Start Readme
6 Packet Contents:
This section lists all of the files included in the release.
30
DSP2804x V1.30 Quick Start Readme
6.1.2 DSP2804x Header Files – Peripheral Bit-Field and Register Structure Definition
Files
The following files define the bit-fields and register structures for each of the peripherals on the
2804x devices. These files are automatically included in the project by including
DSP2804x_Device.h. Refer to section 4.2 for more information on incorporating the header files
into a new or existing project.
Table 11. DSP2804x Header File Bit-Field & Register Structure Definition Files
File Location Description
DSP2804x_Adc.h DSP2804x_headers\include ADC register structure and bit-field definitions.
DSP2804x_CpuTimers.h DSP2804x_headers\include CPU-Timer register structure and bit-field definitions.
DSP2804x_DevEmu.h DSP2804x_headers\include Emulation register definitions
DSP2804x_EPwm.h DSP2804x_headers\include ePWM register structures and bit-field definitions.
DSP2804x_Gpio.h DSP2804x_headers\include General Purpose I/O (GPIO) register structures and
bit-field definitions.
DSP2804x_I2c.h DSP2804x_headers\include I2C register structure and bit-field definitions.
DSP2804x_PieCtrl.h DSP2804x_headers\include PIE control register structure and bit-field definitions.
DSP2804x_PieVect.h DSP2804x_headers\include Structure definition for the entire PIE vector table.
DSP2804x_Sci.h DSP2804x_headers\include SCI register structure and bit-field definitions.
DSP2804x_Spi.h DSP2804x_headers\include SPI register structure and bit-field definitions.
DSP2804x_SysCtrl.h DSP2804x_headers\include System register definitions. Includes Watchdog,
PLL, CSM, Flash/OTP, Clock registers.
DSP2804x_XIntrupt.h DSP2804x_headers\include External interrupt register structure and bit-field
definitions.
31
DSP2804x V1.30 Quick Start Readme
32
DSP2804x V1.30 Quick Start Readme
In addition, the following files are included for software prioritization of interrupts. These files are
used in place of those above when additional software prioritization of the interrupts is required.
Refer to the example and documentation in DSP2804x_examples\sw_prioritized_interrupts for
more information.
Table 15. Software Prioritized Interrupt PIE Block Specific Support Files
33
DSP2804x V1.30 Quick Start Readme
Note: The specific routines are under development and may not all be available as of this release. They will be
added and distributed as more examples are developed.
34
DSP2804x V1.30 Quick Start Readme
6.2.4 Example Linker .cmd files
Example memory linker command files are located in the DSP2804x_common\cmd directory.
For getting started using the 2804x devices, the basic 28044_RAM_lnk.cmd file is suggested
and used by many of the included examples.
On 2804x devices, the SARAM blocks L0 and L1 are mirrored. For simplicity these memory
maps only include one instance of these memory blocks.
35
DSP2804x V1.30 Quick Start Readme
b) DSP2804x_Device.h – Added int64 and Uint64 typedef definitions.
c) DSP2804x_Spi.h- Changed SPIPRI register bit 6 to reserved bit.
d) DSP2804x_Gpio.h- In GPIO_DATA_REGS struct changed GPBPUD_REG for GPBDAT
register to GPBDAT_REG.
Changes to Common Files:
e) DSP2804x_CpuTimers.c – Updated comments to indicate only CpuTimer2 is reserved
for DSP/BIOS use. User must comment out CpuTimer2 code when using DSP/BIOS.
f) DSP2804x_I2c_defines.h- Fixed typo for DSP280x_I2CDEINFES_H and replaced with
DSP280x_I2CDEFINES_H.
g) CCSv4 gel files – Added ccsv4 directory in /gel directory for CCSv4-specific device gel
files (GEL_WatchAdd() functions removed).
Changes to Example Files:
h) All PJT Files- Removed the line: Tool="DspBiosBuilder" from all example PJT files for
easy migration path to CCSv4 Microcontroller-only (code-size limited) version users.
i) Example_2804xHRPWM.c and Example_2804xHRPWM_slider.c – Changed
initialization code to set TBPRD register to period-1 instead of period to achieve correct
period and duty cycle.
j) Example_2804xHaltWake.c- Update WAKE_ISR to toggle GPIO1 instead of set GPIO1
in ISR. Additionally, updated description comments for wakeup.
k) Example_2804xHRPWM_SFO_V5.c- Added line of code before calling MepDis()
function to enable HRPWM logic for the channel first.
l) Added DSP2804x_examples_ccsv4 directories - Added directories for CCSv4.x
projects. The example projects in these directories are identical to those found in the
normal CCSv3.x DSP2804x_examples directory with the exception that the examples
now support the Code Composer Studio v4.x project folder format instead of the Code
Composer Studio v3.x PJT files. The example gel files have also been removed for the
CCSv4 example projects because the gel file functions used in the example gels are no
longer supported.
Changes from V1.10 to V1.20
Changes to Header Files:
m) DSP2804x_DevEmu.h – Removed MONPRIV, EMU0SEL, and EMU1SEL bits in the
DEVICECNF register.
Changes to Common Files:
n) DSP2804x_SWPrioritizedDefaultIsr.c – Fixed some PIEIER number typos.
36
DSP2804x V1.30 Quick Start Readme
o) SFO_TI_Build_V5B.lib and SFO_TI_Build_V5Bfpu.lib – Because the SFO_MepEn()
function in the original version of the SFO library was restricted to MEP control on falling
edge only with HRLOAD on CTR=ZRO, a new version of the V5 library, V5B, was added,
which includes a SFO_MepEn() function that supports all available HRPWM
configurations – falling and rising edge as well as HRLOAD on CTR=ZRO and
CTR=PRD.
p) DSP2804x_SysCtrl.h – Added EALLOW access to code which sets CLKINDIV bit to 0.
Also removed “!” from code which sets CLKINDIV to divider value.
37
DSP2804x V1.30 Quick Start Readme
g) SFO library V5 (SFO_TI_Build_V5.lib + SFO_V5.h) added to support up to maximum
number of HRPWM channels. Note – V5 runs faster and takes less memory than the
original version did, but when using SFO_MepEn_V5(n), Mep_En must be called
repetitively until it is finished on the current channel before it is called on a different
channel. Therefore, it now returns a “1” when it has finished running on a channel and a
“0” otherwise. Due to this change, SFO_TI_Build.lib is still included in the event that it is
necessary to run MepEn concurrently on up to 4 HRPWM channels. Also updated
readme in /lib folder.
h) Example_280xHRPWM_SFO_V5.c (hrpwm_sfo_v5) example added to demonstrate
SFO library V5’s optimizations and limitations.
i) The root of the default path in all example project files was changed from
C:\tidcs\c28\DSP2804x\v100\ to C:\tidcs\c28\DSP2804x\v110\ to reflect the version
change.
8 Errata
This section lists known typos or errors in the header files which have not been updated to
prevent incompatibilities with code developed using earlier versions of the header files.
a) DSP2804x_I2C.h:
Details— When the C-header files are included in an assembly project, the assembler
views the AL (Arbitration Lost) bit in both the I2CIER and the I2CSTR structures as
reserved words and issues an error.
Workaround— When including the C-header files in an assembly project, rename the
AL bits to ARBL in DSP2804x_I2C.h as follows to prevent conflicts with the assembler:
//----------------------------------------------------
// 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
};
//----------------------------------------------------
// 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
38
DSP2804x V1.30 Quick Start Readme
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
};
39