Started to create RX64M GCC project - building but not yet converted to new core.

pull/4/head
Richard Barry 11 years ago
parent 6fe7e7ef67
commit d59bf60ff9

@ -0,0 +1,124 @@
<?xml version="1.0" encoding="ASCII"?>
<com.renesas.linkersection.model:SectionContainer xmi:version="2.0" xmlns:xmi="http://www.omg.org/XMI" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:com.renesas.linkersection.model="http:///LinkerSection.ecore" targets="GNU_RX">
<definedRegionsList name="RAM">
<startAddress xsi:type="com.renesas.linkersection.model:FixedAddress"/>
<endAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="524287"/>
</definedRegionsList>
<definedRegionsList name="ROM">
<startAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="4290772992"/>
<endAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="4294967295"/>
</definedRegionsList>
<sections name=".fvectors" isKeep="true">
<sectionAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="4294967168"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".fvectors"/>
</sections>
<sections name=".text">
<sectionAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="4290772992"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".text"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".text.*"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="P"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="etext"/>
</sections>
<sections name=".rvectors">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.1"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_rvectors_start"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".rvectors"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_rvectors_end"/>
</sections>
<sections name=".init">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.2"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".init"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__preinit_array_start"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".preinit_array"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__preinit_array_end"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__init_array_start = (. + 3) &amp; ~ 3"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".init_array"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="SORT(.init_array.*)"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__init_array_end"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__fini_array_start"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".fini_array"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="SORT(.fini_array.*)"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__fini_array_end"/>
</sections>
<sections name=".fini">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.3"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".fini"/>
</sections>
<sections name=".got">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.4"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".got"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".got.plt"/>
</sections>
<sections name=".rodata">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.5"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".rodata"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".rodata.*"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="C_1"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="C_2"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="C"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_erodata"/>
</sections>
<sections name=".eh_frame_hdr">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.6"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".eh_frame_hdr"/>
</sections>
<sections name=".eh_frame">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.7"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".eh_frame"/>
</sections>
<sections name=".jcr">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.8"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".jcr"/>
</sections>
<sections name=".tors">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.9"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__CTOR_LIST__"/>
<contents xsi:type="com.renesas.linkersection.model:Keyword" text=". = ALIGN(2)"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="___ctors"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".ctors"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="___ctors_end"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__CTOR_END__"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__DTOR_LIST__"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="___dtors"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".dtors"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="___dtors_end"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="__DTOR_END__"/>
<contents xsi:type="com.renesas.linkersection.model:Keyword" text=". = ALIGN(2)"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_mdata"/>
</sections>
<sections name=".ustack">
<sectionAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="512"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_ustack"/>
</sections>
<sections name=".istack">
<sectionAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="256"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_istack"/>
</sections>
<sections name=".data">
<sectionAddress xsi:type="com.renesas.linkersection.model:FixedAddress" fixedAddress="516"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_data"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".data"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".data.*"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="D"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="D_1"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="D_2"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_edata"/>
<reservedMemAddress xsi:type="com.renesas.linkersection.model:ReferencedLabelAddress" label="//@sections.10/@contents.12"/>
</sections>
<sections name=".gcc_exc">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.13"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".gcc_exc"/>
</sections>
<sections name=".bss">
<sectionAddress xsi:type="com.renesas.linkersection.model:ReferencedSectionAddress" referencedSection="//@sections.14"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_bss"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".bss"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name=".bss.**"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="COMMON"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="B"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="B_1"/>
<contents xsi:type="com.renesas.linkersection.model:WildCardExpression" specificSection="true" name="B_2"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_ebss"/>
<contents xsi:type="com.renesas.linkersection.model:Label" rhs="= .;" lhs="_end"/>
</sections>
</com.renesas.linkersection.model:SectionContainer>

@ -0,0 +1,115 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<?fileVersion 4.0.0?>
<cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage">
<storageModule moduleId="org.eclipse.cdt.core.settings">
<cconfiguration id="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687">
<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687" moduleId="org.eclipse.cdt.core.settings" name="HardwareDebug">
<externalSettings/>
<extensions>
<extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/>
<extension id="org.eclipse.cdt.core.PE" point="org.eclipse.cdt.core.BinaryParser"/>
<extension id="org.eclipse.cdt.core.VCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
<extension id="org.eclipse.cdt.core.MakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
</extensions>
</storageModule>
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
<configuration artifactName="RTOSDemo" buildArtefactType="com.renesas.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.debug,org.eclipse.cdt.build.core.buildArtefactType=com.renesas.cdt.build.core.buildArtefactType.exe" cleanCommand="rm -rf *.lst *.lis *.lpp *.map" description="" errorParsers="org.eclipse.cdt.core.MakeErrorParser;org.eclipse.cdt.core.GCCErrorParser;org.eclipse.cdt.core.GLDErrorParser;org.eclipse.cdt.core.GASErrorParser;org.eclipse.cdt.core.VCErrorParser" id="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687" name="HardwareDebug" parent="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id">
<folderInfo id="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687." name="/" resourcePath="">
<toolChain id="%com.renesas.cdt.rx.hardwaredebug.win32.toolChain.Id.804086182" name="KPIT GNURX-ELF Toolchain" superClass="%com.renesas.cdt.rx.hardwaredebug.win32.toolChain.Id">
<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.ELF;org.eclipse.cdt.core.PE" id="com.renesas.cdt.rx.hardwaredebug.win32.targetPlatform.Id.1441458979" osList="win32" superClass="com.renesas.cdt.rx.hardwaredebug.win32.targetPlatform.Id"/>
<builder buildPath="${workspace_loc:/RTOSDemo}/HardwareDebug" id="com.renesas.cdt.rx.hardwaredebug.win32.builder.Id.476907861" keepEnvironmentInBuildfile="false" managedBuildOn="true" name="GNU Make Builder" parallelBuildOn="true" parallelizationNumber="optimal" superClass="com.renesas.cdt.rx.hardwaredebug.win32.builder.Id"/>
<tool command="rx-elf-libgen" id="com.renesas.cdt.rx.hardwaredebug.win32.tool.libgen.Id.2057566942" name="Library Generator" superClass="com.renesas.cdt.rx.hardwaredebug.win32.tool.libgen.Id">
<option id="com.renesas.cdt.core.LibraryGenerator.option.math.2039618467" name="math.h : Performs numeric calculations such as trigonometric functions" superClass="com.renesas.cdt.core.LibraryGenerator.option.math" value="true" valueType="boolean"/>
<option id="com.renesas.cdt.core.LibraryGenerator.option.stdio.2055452080" name="stdio.h : Performs input/output handling" superClass="com.renesas.cdt.core.LibraryGenerator.option.stdio" value="true" valueType="boolean"/>
<option id="com.renesas.cdt.core.LibraryGenerator.option.stdlib.321901636" name="stdlib.h : Performs C program standard processing such as storage area management" superClass="com.renesas.cdt.core.LibraryGenerator.option.stdlib" value="true" valueType="boolean"/>
<option id="com.renesas.cdt.core.LibraryGenerator.option.string.1771884942" name="string.h : Performs string comparison, copying " superClass="com.renesas.cdt.core.LibraryGenerator.option.string" value="true" valueType="boolean"/>
<option id="com.renesas.cdt.core.LibraryGenerator.option.selectLibrary.236583299" name="Select library" superClass="com.renesas.cdt.core.LibraryGenerator.option.selectLibrary" value="Optimized" valueType="enumerated"/>
<option id="com.renesas.cdt.core.LibraryGenerator.option.libraryType.1090078057" name="Library type" superClass="com.renesas.cdt.core.LibraryGenerator.option.libraryType" value="Project-Built" valueType="enumerated"/>
</tool>
<tool id="com.renesas.cdt.rx.hardwaredebug.win32.tool.compiler.Id.315385351" name="Compiler" superClass="com.renesas.cdt.rx.hardwaredebug.win32.tool.compiler.Id">
<option defaultValue="true" id="com.renesas.cdt.core.Compiler.option.misc2.945596144" name="Don't search standard system directories for header files(-nostdinc)" superClass="com.renesas.cdt.core.Compiler.option.misc2" value="false" valueType="boolean"/>
<option id="com.renesas.cdt.rx.HardwareDebug.Compiler.option.macroDefines.1508551089" name="Macro Defines" superClass="com.renesas.cdt.rx.HardwareDebug.Compiler.option.macroDefines" valueType="definedSymbols">
<listOptionValue builtIn="false" value="__RX_LITTLE_ENDIAN__=1"/>
</option>
<option id="com.renesas.cdt.rx.HardwareDebug.Compiler.option.dataEndian.1753220522" name="Data Endian" superClass="com.renesas.cdt.rx.HardwareDebug.Compiler.option.dataEndian" value="Little-endian data" valueType="enumerated"/>
<option id="com.renesas.cdt.rx.HardwareDebug.Compiler.option.cpuType.681354731" name="CPU type" superClass="com.renesas.cdt.rx.HardwareDebug.Compiler.option.cpuType" value="RX600" valueType="enumerated"/>
<option id="com.renesas.cdt.core.Compiler.option.device.679293684" name="Device" superClass="com.renesas.cdt.core.Compiler.option.device" value="R5F564ML" valueType="string"/>
<option id="com.renesas.cdt.core.Compiler.option.deviceShortName.1803462626" name="DeviceShortName" superClass="com.renesas.cdt.core.Compiler.option.deviceShortName" value="R5F564MLDxFC" valueType="string"/>
<option id="com.renesas.cdt.core.Compiler.option.includeFileDir.1782217841" name="Include file directories" superClass="com.renesas.cdt.core.Compiler.option.includeFileDir" valueType="includePath">
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}/src/FreeRTOS/Source/include}&quot;"/>
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}/src/Common_Demo_Tasks/include}&quot;"/>
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}/src/FreeRTOS/Source/portable/GCC/RX600v2}&quot;"/>
<listOptionValue builtIn="false" value="&quot;${TCINSTALL}\rx-elf\optlibinc&quot;"/>
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}/src}&quot;"/>
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}/src/RenesasCode}&quot;"/>
</option>
<option id="com.renesas.cdt.core.Compiler.option.CPUSeries.1945733388" name="Cpu Series" superClass="com.renesas.cdt.core.Compiler.option.CPUSeries" value="RX64M" valueType="string"/>
<option id="com.renesas.cdt.core.Compiler.option.warning14.1219627871" name="Print extra warning messages(-Wextra)" superClass="com.renesas.cdt.core.Compiler.option.warning14" value="true" valueType="boolean"/>
<inputType id="%Base.Compiler.C.InputType.Id.1746322545" name="C Input" superClass="%Base.Compiler.C.InputType.Id"/>
<inputType id="Base.Compiler.CPP.InputType.Id.1052891014" name="C++ Input" superClass="Base.Compiler.CPP.InputType.Id"/>
</tool>
<tool id="com.renesas.cdt.rx.hardwaredebug.win32.tool.assembler.Id.508016564" name="Assembler" superClass="com.renesas.cdt.rx.hardwaredebug.win32.tool.assembler.Id">
<option id="com.renesas.cdt.rx.HardwareDebug.Assembler.option.dataEndian.735581335" name="Data Endian" superClass="com.renesas.cdt.rx.HardwareDebug.Assembler.option.dataEndian" value="Little-endian data" valueType="enumerated"/>
<option id="com.renesas.cdt.core.Assembler.option.includeFileDirectories.286633038" name="Include file directories" superClass="com.renesas.cdt.core.Assembler.option.includeFileDirectories" valueType="includePath">
<listOptionValue builtIn="false" value="&quot;${workspace_loc:/${ProjName}}\src&quot;"/>
</option>
<inputType id="%Base.Assembler.inputType.Id.1966626285" name="Assembler InputType" superClass="%Base.Assembler.inputType.Id"/>
</tool>
<tool command="rx-elf-ld" commandLinePattern="${COMMAND} ${OUTPUT_FLAG}${OUTPUT_PREFIX} ${OUTPUT}${INPUTS} ${FLAGS}" id="com.renesas.cdt.rx.hardwaredebug.win32.tool.linker.Id.1075007051" name="Linker" superClass="com.renesas.cdt.rx.hardwaredebug.win32.tool.linker.Id">
<option id="com.renesas.cdt.rx.HardwareDebug.Linker.option.dataEndian.233227307" name="Data Endian" superClass="com.renesas.cdt.rx.HardwareDebug.Linker.option.dataEndian" value="Little-endian data" valueType="enumerated"/>
<option id="com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveSearchDirectories.1899007176" name="Archive search directories" superClass="com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveSearchDirectories" valueType="stringList">
<listOptionValue builtIn="false" value="&quot;${CONFIGDIR}&quot;"/>
<listOptionValue builtIn="false" value="&quot;${TCINSTALL}\lib\gcc\rx-elf\\${GCC_VERSION}&quot;"/>
</option>
<option id="com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveLibraryFiles.821809154" name="Archive (library) files" superClass="com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveLibraryFiles" valueType="stringList">
<listOptionValue builtIn="false" value="${ProjName}"/>
<listOptionValue builtIn="false" value="gcc"/>
</option>
<option id="com.renesas.cdt.core.Linker.option.userDefinedOptions.1112264479" name="User defined options" superClass="com.renesas.cdt.core.Linker.option.userDefinedOptions" valueType="stringList">
<listOptionValue builtIn="false" value="-e_PowerON_Reset"/>
</option>
<option id="com.renesas.cdt.core.Linker.option.linkOrderList.1135295440" name="" superClass="com.renesas.cdt.core.Linker.option.linkOrderList" valueType="stringList">
<listOptionValue builtIn="false" value="&quot;.\src/RenesasCode\hardware_setup.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/RenesasCode\interrupt_handlers.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/RenesasCode\reset_program.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/RenesasCode\vector_table.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source/portable/MemMang\heap_4.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source/portable/GCC/RX600v2\port.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\croutine.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\event_groups.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\list.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\queue.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\tasks.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src/FreeRTOS/Source\timers.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\src\main.o&quot;"/>
<listOptionValue builtIn="false" value="&quot;.\libRTOSDemo.a&quot;"/>
</option>
</tool>
<tool id="com.renesas.cdt.rx.hardwaredebug.win32.tool.objcopy.Id.2054059721" name="Objcopy" superClass="com.renesas.cdt.rx.hardwaredebug.win32.tool.objcopy.Id"/>
</toolChain>
</folderInfo>
<sourceEntries>
<entry flags="VALUE_WORKSPACE_PATH" kind="sourcePath" name=""/>
</sourceEntries>
</configuration>
</storageModule>
<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/>
</cconfiguration>
</storageModule>
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
<project id="RTOSDemo.com.renesas.cdt.rx.projectType.Id.1663355096" name="Executable (Renesas)" projectType="com.renesas.cdt.rx.projectType.Id"/>
</storageModule>
<storageModule moduleId="scannerConfiguration">
<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/>
</storageModule>
<storageModule moduleId="org.eclipse.cdt.core.LanguageSettingsProviders"/>
<storageModule moduleId="refreshScope" versionNumber="2">
<configuration configurationName="HardwareDebug">
<resource resourceType="PROJECT" workspacePath="/RTOSDemo"/>
</configuration>
</storageModule>
</cproject>

@ -0,0 +1,7 @@
TOOL_CHAIN=KPIT GNURX-ELF Toolchain
VERSION=v14.01
TC_INSTALL=C:\Program Files\KPIT\GNURXv14.01-ELF\rx-ELF\rx-ELF\
GCC_STRING=4.7-GNURX_v14.01
VERSION_IDE=3.06.02.004
E2STUDIO_VERSION=2.1.0.21
ACTIVE_CONFIGURATION=HardwareDebug

@ -0,0 +1,143 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>RTOSDemo</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>com.renesas.cdt.core.genmakebuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder</name>
<triggers>full,incremental,</triggers>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.cdt.core.cnature</nature>
<nature>com.renesas.cdt.core.kpitcnature</nature>
<nature>com.renesas.cdt.core.kpitccnature</nature>
<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature>
<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature>
</natures>
<linkedResources>
<link>
<name>src/Common_Demo_Tasks</name>
<type>2</type>
<locationURI>virtual:/virtual</locationURI>
</link>
<link>
<name>src/FreeRTOS</name>
<type>2</type>
<locationURI>virtual:/virtual</locationURI>
</link>
<link>
<name>src/Common_Demo_Tasks/Minimal</name>
<type>2</type>
<locationURI>FREERTOS_ROOT/Demo/Common/Minimal</locationURI>
</link>
<link>
<name>src/Common_Demo_Tasks/include</name>
<type>2</type>
<locationURI>FREERTOS_ROOT/Demo/Common/include</locationURI>
</link>
<link>
<name>src/FreeRTOS/Source</name>
<type>2</type>
<locationURI>FREERTOS_ROOT/Source</locationURI>
</link>
</linkedResources>
<filteredResources>
<filter>
<id>1395316906017</id>
<name>src/Common_Demo_Tasks</name>
<type>22</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-alt*.*</arguments>
</matcher>
</filter>
<filter>
<id>1395316906049</id>
<name>src/Common_Demo_Tasks</name>
<type>22</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-cr*.*</arguments>
</matcher>
</filter>
<filter>
<id>1395316906064</id>
<name>src/Common_Demo_Tasks</name>
<type>22</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-Int*.*</arguments>
</matcher>
</filter>
<filter>
<id>1395316906080</id>
<name>src/Common_Demo_Tasks</name>
<type>22</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-sp*.*</arguments>
</matcher>
</filter>
<filter>
<id>1395316906096</id>
<name>src/Common_Demo_Tasks</name>
<type>22</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-comtest*.*</arguments>
</matcher>
</filter>
<filter>
<id>1395316464355</id>
<name>src/FreeRTOS/Source/portable</name>
<type>9</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-MemMang</arguments>
</matcher>
</filter>
<filter>
<id>1395316464402</id>
<name>src/FreeRTOS/Source/portable</name>
<type>9</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-GCC</arguments>
</matcher>
</filter>
<filter>
<id>1395316445089</id>
<name>src/FreeRTOS/Source/portable/GCC</name>
<type>9</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-RX600v2</arguments>
</matcher>
</filter>
<filter>
<id>1395316477637</id>
<name>src/FreeRTOS/Source/portable/MemMang</name>
<type>5</type>
<matcher>
<id>org.eclipse.ui.ide.multiFilter</id>
<arguments>1.0-name-matches-false-false-heap_4.c</arguments>
</matcher>
</filter>
</filteredResources>
<variableList>
<variable>
<name>FREERTOS_ROOT</name>
<value>$%7BPARENT-2-PROJECT_LOC%7D</value>
</variable>
</variableList>
</projectDescription>

@ -0,0 +1,22 @@
Library\ Generator\ Command=rx-elf-libgen
com.renesas.cdt.core.Assembler.option.includeFileDirectories="${workspace_loc\:/${ProjName}}\\src";
com.renesas.cdt.core.Compiler.option.includeFileDir.1782217841="${TCINSTALL}\\rx-elf\\optlibinc";
com.renesas.cdt.core.LibraryGenerator.option.ctype=false
com.renesas.cdt.core.LibraryGenerator.option.libraryType=Project-Built
com.renesas.cdt.core.LibraryGenerator.option.math=true
com.renesas.cdt.core.LibraryGenerator.option.selectLibrary=Optimized
com.renesas.cdt.core.LibraryGenerator.option.stdio=true
com.renesas.cdt.core.LibraryGenerator.option.stdlib=true
com.renesas.cdt.core.LibraryGenerator.option.string=true
com.renesas.cdt.core.Linker.option.userDefinedOptions=-e_PowerON_Reset;
com.renesas.cdt.rx.HardwareDebug.Compiler.option.cpuType=RX600
com.renesas.cdt.rx.HardwareDebug.Compiler.option.cpuType.681354731=RX600
com.renesas.cdt.rx.HardwareDebug.Compiler.option.dataEndian=Little-endian data
com.renesas.cdt.rx.HardwareDebug.Compiler.option.disableFPUInstructions=false
com.renesas.cdt.rx.HardwareDebug.Compiler.option.genCodeForRX610=false
com.renesas.cdt.rx.HardwareDebug.Compiler.option.generateRXas100output=false
com.renesas.cdt.rx.HardwareDebug.Compiler.option.macroDefines=__RX_LITTLE_ENDIAN__\=1;
com.renesas.cdt.rx.HardwareDebug.Compiler.option.make64bitDouble=false
com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveLibraryFiles=${ProjName};gcc;
com.renesas.cdt.rx.HardwareDebug.Linker.option.archiveSearchDirectories.1899007176="${CONFIGDIR}";"${TCINSTALL}\\lib\\gcc\\rx-elf\\\\${GCC_VERSION}";
eclipse.preferences.version=1

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<project>
<configuration id="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687" name="HardwareDebug">
<extension point="org.eclipse.cdt.core.LanguageSettingsProvider">
<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/>
<provider-reference id="org.eclipse.cdt.managedbuilder.core.MBSLanguageSettingsProvider" ref="shared-provider"/>
<provider class="com.renesas.cdt.common.build.spec.RXGCCBuiltinSpecsDetector" console="false" id="RXGCCBuiltinSpecsDetector" keep-relative-paths="false" name="Renesas GCCBuildinCompilerSettings" parameter="rx-elf-gcc -E -P -v -dD ${INPUTS} -mcpu=rx600 -mlittle-endian-data" prefer-non-shared="true">
<language-scope id="org.eclipse.cdt.core.gcc"/>
<language-scope id="org.eclipse.cdt.core.g++"/>
</provider>
</extension>
</configuration>
</project>

@ -0,0 +1,92 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<launchConfiguration type="com.renesas.cdt.launch.dsf.gdbremote.launchConfigurationType">
<intAttribute key="com.renesas.cdt.core.admPortNumber" value="61236"/>
<stringAttribute key="com.renesas.cdt.core.initCommands" value=""/>
<stringAttribute key="com.renesas.cdt.core.ipAddress" value="localhost"/>
<stringAttribute key="com.renesas.cdt.core.jtagDevice" value="E1"/>
<stringAttribute key="com.renesas.cdt.core.jtagDeviceId" value="com.renesas.hardwaredebug.rx.e1"/>
<booleanAttribute key="com.renesas.cdt.core.loadImage" value="true"/>
<stringAttribute key="com.renesas.cdt.core.optionInitCommands" value=""/>
<intAttribute key="com.renesas.cdt.core.portNumber" value="61234"/>
<stringAttribute key="com.renesas.cdt.core.runCommands" value=""/>
<stringAttribute key="com.renesas.cdt.core.serverParam" value="-g E1 -l 0 -t R5F564ML -p 61234 -d 61236 -uClockSrcHoco= 0 -uInputClock= 12.0000 -uAllowClockSourceInternal= 1 -uUseFine= 0 -uJTagClockFreq= 16.5 -w 0 -z 0 -uRegisterSetting= 0 -uModePin= 0 -uDebugMode= 0 -uExecuteProgram= 0 -uIdCode= FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF -b -n 0 -uWorkRamAddress= 1000 -uProgReWriteIRom= 0 -uProgReWriteDFlash= 0"/>
<booleanAttribute key="com.renesas.cdt.core.setResume" value="true"/>
<booleanAttribute key="com.renesas.cdt.core.setStopAt" value="true"/>
<booleanAttribute key="com.renesas.cdt.core.startServer" value="true"/>
<stringAttribute key="com.renesas.cdt.core.stopAt" value="main"/>
<stringAttribute key="com.renesas.cdt.core.targetDevice" value="R5F564ML"/>
<booleanAttribute key="com.renesas.cdt.core.useRemoteTarget" value="true"/>
<booleanAttribute key="com.renesas.cdt.core.verboseMode" value="false"/>
<stringAttribute key="com.renesas.cdt.debug.realtimemanager.memory.mruRanges" value=""/>
<stringAttribute key="com.renesas.cdt.launch.dsf.IO_MAP" value="${eclipse_home}..\internal\IoFiles\RX\RX64M.sfrx"/>
<booleanAttribute key="com.renesas.cdt.launch.dsf.USE_DEFAULT_IO_MAP" value="true"/>
<stringAttribute key="com.renesas.cdt.launch.dsf.launchSeqType" value="com.renesas.cdt.launch.dsf.launchSequence.e2GdbServer"/>
<stringAttribute key="com.renesas.cdt.launch.dsf.serverPath" value="${eclipse_home}../DebugComp/e2-server-gdb.exe"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.allow.clock.source.internal" value="true"/>
<intAttribute key="com.renesas.hardwaredebug.e1.clock_source" value="0"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.connection.mode" value="0"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.e1_pwr" value="false"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.enable_external_flash" value="false"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.execute.program" value="false"/>
<listAttribute key="com.renesas.hardwaredebug.e1.ext_flash_definitions"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.ext_flash_registers" value="2.1,0,"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.external_memory" value=""/>
<stringAttribute key="com.renesas.hardwaredebug.e1.fine.baud.rate" value="2.00"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.flash_overwrite_blocks" value=""/>
<stringAttribute key="com.renesas.hardwaredebug.e1.hook_Stop_func" value="0x0"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.hook_enable_Stop" value="false"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.hook_enable_start" value="false"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.hook_start_func" value="0x0"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.hw_break" value="true"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.id_code" value="FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.inputclock" value="12.0000"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.jtag.clock.freq" value="16.5"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.jtag.or.fine" value="0"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.le" value="true"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.mode" value="0"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.mode_pin" value="0"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.prog_rewrite_dflash" value="false"/>
<booleanAttribute key="com.renesas.hardwaredebug.e1.prog_rewrite_irom" value="false"/>
<stringAttribute key="com.renesas.hardwaredebug.e1.serial_number" value=""/>
<stringAttribute key="com.renesas.hardwaredebug.e1.supply.voltage" value="3.3V"/>
<intAttribute key="com.renesas.hardwaredebug.e1.work_ram_start" value="4096"/>
<booleanAttribute key="com.renesas.hardwaredebug.e20.le" value="true"/>
<intAttribute key="org.eclipse.cdt.debug.gdbjtag.core.delay" value="3"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.doHalt" value="false"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.doReset" value="false"/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.imageFileName" value=""/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.imageOffset" value=""/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.initCommands" value=""/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.loadImage" value="true"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.loadSymbols" value="true"/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.pcRegister" value=""/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.runCommands" value=""/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setPcRegister" value="false"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setResume" value="false"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setStopAt" value="true"/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.stopAt" value="main"/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.symbolsFileName" value=""/>
<stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.symbolsOffset" value=""/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useFileForImage" value="false"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useFileForSymbols" value="false"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useProjBinaryForImage" value="true"/>
<booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useProjBinaryForSymbols" value="true"/>
<stringAttribute key="org.eclipse.cdt.dsf.gdb.DEBUG_NAME" value="${eclipse_home}../DebugComp/rx-elf-gdb --rx-force-64bit-double -rx-force-v2"/>
<booleanAttribute key="org.eclipse.cdt.dsf.gdb.NON_STOP" value="true"/>
<intAttribute key="org.eclipse.cdt.launch.ATTR_BUILD_BEFORE_LAUNCH_ATTR" value="2"/>
<booleanAttribute key="org.eclipse.cdt.launch.DEBUGGER_STOP_AT_MAIN" value="true"/>
<stringAttribute key="org.eclipse.cdt.launch.DEBUGGER_STOP_AT_MAIN_SYMBOL" value="main"/>
<stringAttribute key="org.eclipse.cdt.launch.PROGRAM_NAME" value="HardwareDebug\RTOSDemo.x"/>
<stringAttribute key="org.eclipse.cdt.launch.PROJECT_ATTR" value="RTOSDemo"/>
<booleanAttribute key="org.eclipse.cdt.launch.PROJECT_BUILD_CONFIG_AUTO_ATTR" value="true"/>
<stringAttribute key="org.eclipse.cdt.launch.PROJECT_BUILD_CONFIG_ID_ATTR" value="%com.renesas.cdt.rx.hardwaredebug.win32.configuration.Id.606469687"/>
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_PATHS">
<listEntry value="/RTOSDemo"/>
</listAttribute>
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_TYPES">
<listEntry value="4"/>
</listAttribute>
<booleanAttribute key="org.eclipse.debug.ui.ATTR_LAUNCH_IN_BACKGROUND" value="false"/>
<stringAttribute key="org.eclipse.dsf.launch.MEMORY_BLOCKS" value="&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;no&quot;?&gt;&#13;&#10;&lt;memoryBlockExpressionList context=&quot;reserved-for-future-use&quot;/&gt;&#13;&#10;"/>
<stringAttribute key="process_factory_id" value="org.eclipse.cdt.dsf.gdb.GdbProcessFactory"/>
</launchConfiguration>

@ -0,0 +1,5 @@
################################################################################
# Automatically-generated file. Do not edit!
################################################################################
PATH := $(PATH):C:\PROGRA~1\KPIT\GNURXV~1.01-\rx-ELF\rx-ELF\bin;C:\PROGRA~1\KPIT\GNURXV~1.01-\rx-ELF\rx-ELF\libexec\gcc\rx-elf\4.7-GNURX_v14.01

@ -0,0 +1,178 @@
/*
FreeRTOS V8.0.0 - Copyright (C) 2014 Real Time Engineers Ltd.
All rights reserved
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
***************************************************************************
* *
* FreeRTOS provides completely free yet professionally developed, *
* robust, strictly quality controlled, supported, and cross *
* platform software that has become a de facto standard. *
* *
* Help yourself get started quickly and support the FreeRTOS *
* project by purchasing a FreeRTOS tutorial book, reference *
* manual, or both from: http://www.FreeRTOS.org/Documentation *
* *
* Thank you! *
* *
***************************************************************************
This file is part of the FreeRTOS distribution.
FreeRTOS is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License (version 2) as published by the
Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
>>! NOTE: The modification to the GPL is included to allow you to distribute
>>! a combined work that includes FreeRTOS without being obliged to provide
>>! the source code for proprietary components outside of the FreeRTOS
>>! kernel.
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. Full license text is available from the following
link: http://www.freertos.org/a00114.html
1 tab == 4 spaces!
***************************************************************************
* *
* Having a problem? Start by reading the FAQ "My application does *
* not run, what could be wrong?" *
* *
* http://www.FreeRTOS.org/FAQHelp.html *
* *
***************************************************************************
http://www.FreeRTOS.org - Documentation, books, training, latest versions,
license and Real Time Engineers Ltd. contact details.
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
compatible FAT file system, and our tiny thread aware UDP/IP stack.
http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High
Integrity Systems to sell under the OpenRTOS brand. Low cost OpenRTOS
licenses offer ticketed support, indemnification and middleware.
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
engineered and independently SIL3 certified version for use in safety and
mission critical applications that require provable dependability.
1 tab == 4 spaces!
*/
#ifndef FREERTOS_CONFIG_H
#define FREERTOS_CONFIG_H
/* Prevent Renesas headers redefining some stdint.h types. */
#define __TYPEDEF__ 1
/*-----------------------------------------------------------
* Application specific definitions.
*
* These definitions should be adjusted for your particular hardware and
* application requirements.
*
* THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE
* FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE.
*
* See http://www.freertos.org/a00110.html.
*----------------------------------------------------------*/
#define configUSE_PREEMPTION 1
#define configUSE_IDLE_HOOK 1
#define configUSE_TICK_HOOK 1
#define configCPU_CLOCK_HZ ( 120000000UL ) /*_RB_ guess*/
#define configPERIPHERAL_CLOCK_HZ ( 60000000UL ) /*_RB_ guess*/
#define configTICK_RATE_HZ ( ( TickType_t ) 1000 )
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 140 )
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 45 * 1024 ) )
#define configMAX_TASK_NAME_LEN ( 12 )
#define configUSE_TRACE_FACILITY 1
#define configUSE_16_BIT_TICKS 0
#define configIDLE_SHOULD_YIELD 1
#define configUSE_CO_ROUTINES 0
#define configUSE_MUTEXES 1
#define configGENERATE_RUN_TIME_STATS 0
#define configCHECK_FOR_STACK_OVERFLOW 2
#define configUSE_RECURSIVE_MUTEXES 1
#define configQUEUE_REGISTRY_SIZE 0
#define configUSE_MALLOC_FAILED_HOOK 1
#define configUSE_APPLICATION_TASK_TAG 0
#define configUSE_QUEUE_SETS 1
#define configUSE_COUNTING_SEMAPHORES 1
#define configMAX_PRIORITIES ( 7 )
#define configMAX_CO_ROUTINE_PRIORITIES ( 2 )
/* Software timer definitions. */
#define configUSE_TIMERS 1
#define configTIMER_TASK_PRIORITY ( configMAX_PRIORITIES - 1 )
#define configTIMER_QUEUE_LENGTH 5
#define configTIMER_TASK_STACK_DEPTH ( configMINIMAL_STACK_SIZE )
/* The interrupt priority used by the kernel itself for the tick interrupt and
the pended interrupt. This would normally be the lowest priority. */
#define configKERNEL_INTERRUPT_PRIORITY 1
/* The maximum interrupt priority from which FreeRTOS API calls can be made.
Interrupts that use a priority above this will not be effected by anything the
kernel is doing. */
#define configMAX_SYSCALL_INTERRUPT_PRIORITY 4
/* The peripheral used to generate the tick interrupt is configured as part of
the application code. This constant should be set to the vector number of the
peripheral chosen. As supplied this is CMT0. */
#define configTICK_VECTOR _CMT0_CMI0
/* Set the following definitions to 1 to include the API function, or zero
to exclude the API function. */
#define INCLUDE_vTaskPrioritySet 1
#define INCLUDE_uxTaskPriorityGet 1
#define INCLUDE_vTaskDelete 1
#define INCLUDE_vTaskCleanUpResources 0
#define INCLUDE_vTaskSuspend 1
#define INCLUDE_vTaskDelayUntil 1
#define INCLUDE_vTaskDelay 1
#define INCLUDE_uxTaskGetStackHighWaterMark 1
#define INCLUDE_xTaskGetSchedulerState 1
#define INCLUDE_eTaskGetState 1
#define INCLUDE_xTimerPendFunctionCall 1
void vAssertCalled( void );
#define configASSERT( x ) if( ( x ) == 0 ) vAssertCalled()
/* Override some of the priorities set in the common demo tasks. This is
required to ensure flase positive timing errors are not reported. */
#define bktPRIMARY_PRIORITY ( configMAX_PRIORITIES - 3 )
#define bktSECONDARY_PRIORITY ( configMAX_PRIORITIES - 4 )
#define intqHIGHER_PRIORITY ( configMAX_PRIORITIES - 3 )
/*-----------------------------------------------------------
* Ethernet configuration.
*-----------------------------------------------------------*/
/* MAC address configuration. */
#define configMAC_ADDR0 0x00
#define configMAC_ADDR1 0x12
#define configMAC_ADDR2 0x13
#define configMAC_ADDR3 0x10
#define configMAC_ADDR4 0x15
#define configMAC_ADDR5 0x11
/* IP address configuration. */
#define configIP_ADDR0 192
#define configIP_ADDR1 168
#define configIP_ADDR2 0
#define configIP_ADDR3 200
/* Netmask configuration. */
#define configNET_MASK0 255
#define configNET_MASK1 255
#define configNET_MASK2 255
#define configNET_MASK3 0
#endif /* FREERTOS_CONFIG_H */

@ -0,0 +1,198 @@
/*
FreeRTOS V8.0.0 - Copyright (C) 2014 Real Time Engineers Ltd.
All rights reserved
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
***************************************************************************
* *
* FreeRTOS provides completely free yet professionally developed, *
* robust, strictly quality controlled, supported, and cross *
* platform software that has become a de facto standard. *
* *
* Help yourself get started quickly and support the FreeRTOS *
* project by purchasing a FreeRTOS tutorial book, reference *
* manual, or both from: http://www.FreeRTOS.org/Documentation *
* *
* Thank you! *
* *
***************************************************************************
This file is part of the FreeRTOS distribution.
FreeRTOS is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License (version 2) as published by the
Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
>>! NOTE: The modification to the GPL is included to allow you to distribute
>>! a combined work that includes FreeRTOS without being obliged to provide
>>! the source code for proprietary components outside of the FreeRTOS
>>! kernel.
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. Full license text is available from the following
link: http://www.freertos.org/a00114.html
1 tab == 4 spaces!
***************************************************************************
* *
* Having a problem? Start by reading the FAQ "My application does *
* not run, what could be wrong?" *
* *
* http://www.FreeRTOS.org/FAQHelp.html *
* *
***************************************************************************
http://www.FreeRTOS.org - Documentation, books, training, latest versions,
license and Real Time Engineers Ltd. contact details.
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
compatible FAT file system, and our tiny thread aware UDP/IP stack.
http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High
Integrity Systems to sell under the OpenRTOS brand. Low cost OpenRTOS
licenses offer ticketed support, indemnification and middleware.
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
engineered and independently SIL3 certified version for use in safety and
mission critical applications that require provable dependability.
1 tab == 4 spaces!
*/
/*-----------------------------------------------------------
* Simple IO routines to control the LEDs.
*-----------------------------------------------------------*/
/* Scheduler includes. */
#include "FreeRTOS.h"
#include "task.h"
/* Demo includes. */
#include "partest.h"
/* Hardware specifics. */
//#include "iodefine.h"
#define partestNUM_LEDS ( 4 )
long lParTestGetLEDState( unsigned long ulLED );
/*-----------------------------------------------------------*/
void vParTestInitialise( void )
{
/* Port pin configuration is done by the low level set up prior to this
function being called. */
}
/*-----------------------------------------------------------*/
void vParTestSetLED( unsigned long ulLED, signed long xValue )
{
#if 0
if( ulLED < partestNUM_LEDS )
{
if( xValue != 0 )
{
/* Turn the LED on. */
taskENTER_CRITICAL();
{
switch( ulLED )
{
case 0: LED0 = LED_ON;
break;
case 1: LED1 = LED_ON;
break;
case 2: LED2 = LED_ON;
break;
case 3: LED3 = LED_ON;
break;
}
}
taskEXIT_CRITICAL();
}
else
{
/* Turn the LED off. */
taskENTER_CRITICAL();
{
switch( ulLED )
{
case 0: LED0 = LED_OFF;
break;
case 1: LED1 = LED_OFF;
break;
case 2: LED2 = LED_OFF;
break;
case 3: LED3 = LED_OFF;
break;
}
}
taskEXIT_CRITICAL();
}
}
#endif
}
/*-----------------------------------------------------------*/
void vParTestToggleLED( unsigned long ulLED )
{
#if 0
if( ulLED < partestNUM_LEDS )
{
taskENTER_CRITICAL();
{
if( lParTestGetLEDState( ulLED ) != 0x00 )
{
vParTestSetLED( ulLED, 0 );
}
else
{
vParTestSetLED( ulLED, 1 );
}
}
taskEXIT_CRITICAL();
}
#endif
}
/*-----------------------------------------------------------*/
long lParTestGetLEDState( unsigned long ulLED )
{
long lReturn = pdTRUE;
#if 0
if( ulLED < partestNUM_LEDS )
{
switch( ulLED )
{
case 0 : if( LED0 != 0 )
{
lReturn = pdFALSE;
}
break;
case 1 : if( LED1 != 0 )
{
lReturn = pdFALSE;
}
break;
case 2 : if( LED2 != 0 )
{
lReturn = pdFALSE;
}
break;
case 3 : if( LED3 != 0 )
{
lReturn = pdFALSE;
}
break;
}
}
#endif
return lReturn;
}
/*-----------------------------------------------------------*/

@ -0,0 +1,46 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : hardware_setup.c */
/* DESCRIPTION : Hardware Initialization */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 08/07/2013 */
/************************************************************************/
#include "iodefine.h"
#ifdef __cplusplus
extern "C" {
#endif
extern void HardwareSetup(void);
#ifdef __cplusplus
}
#endif
void HardwareSetup(void)
{
/*
BSC.CS0MOD.WORD = 0x1234;
BSC.CS7CNT.WORD = 0x5678;
SCI0.SCR.BIT.TE = 0;
SCI0.SCR.BIT.RE = 0;
SCI0.SCR.BIT.TE = 1;
SCI2.SSR.BIT.PER = 0;
TMR0.TCR.BYTE = 0x12;
TMR1.TCR.BYTE = 0x12;
TMR2.TCR.BYTE = 0x12;
P0.DDR.BYTE = 0x12;
P1.DDR.BYTE = 0x12;
*/
}

@ -0,0 +1,761 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : interrupt_handlers.c */
/* DESCRIPTION : Interrupt Handler */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 03/10/2013 */
/************************************************************************/
#include "interrupt_handlers.h"
// Exception(Supervisor Instruction)
void INT_Excep_SuperVisorInst(void){/* brk(); */}
// Exception(Access Instruction)
void INT_Excep_AccessInst(void){/* brk(); */}
// Exception(Undefined Instruction)
void INT_Excep_UndefinedInst(void){/* brk(); */}
// Exception(Floating Point)
void INT_Excep_FloatingPoint(void){/* brk(); */}
// NMI
void INT_NonMaskableInterrupt(void){/* brk(); */}
// Dummy
void Dummy(void){/* brk(); */}
// BRK
void INT_Excep_BRK(void){ /*wait();*/ }
//;0x0000 Reserved
//;0x0004 Reserved
//;0x0008 Reserved
//;0x000C Reserved
//;0x0010 Reserved
//;0x0014 Reserved
//;0x0018 Reserved
//;0x001C Reserved
//;0x0020 Reserved
//;0x0024 Reserved
//;0x0028 Reserved
//;0x002C Reserved
//;0x0030 Reserved
//;0x0034 Reserved
//;0x0038 Reserved
//;0x003C Reserved
//;0x0040 BUSERR
void INT_Excep_BSC_BUSERR(void){ }
//;0x0044 Reserved
//;0x0048 RAMERR
void INT_Excep_RAM_RAMERR(void){ };
//;0x004C Reserved
//;0x0050 Reserved
//;0x0054 FIFERR
void INT_Excep_FCU_FIFERR(void){ };
//;0x0058 Reserved
//;0x005C FRDYI
void INT_Excep_FCU_FRDYI(void){ };
//;0x0060 Reserved
//;0x0064 Reserved
//;0x0068 SWINT2
void INT_Excep_ICU_SWINT2(void){ };
//;0x006C SWINT
void INT_Excep_ICU_SWINT(void){ };
//;0x0070 CMI0
void INT_Excep_CMT0_CMI0(void){ };
//;0x0074 CMI1
void INT_Excep_CMT1_CMI1(void){ };
//;0x0078 CMWI0
void INT_Excep_CMTW0_CMWI0(void){ };
//;0x007C CMWI1
void INT_Excep_CMTW1_CMWI1(void){ };
//;0x0080 D0FIFO2
void INT_Excep_USBHS_D0FIFO2(void){ };
//;0x0084 D1FIFO2
void INT_Excep_USBHS_D1FIFO2(void){ };
//;0x0088 D0FIFO0
void INT_Excep_USB0_D0FIFO0(void){ };
//;0x008C D1FIFO0
void INT_Excep_USB0_D1FIFO0(void){ };
//;0x0090 Reserved
//;0x0094 Reserved
//;0x0098 SPRI0
void INT_Excep_RSPI0_SPRI0(void){ };
//;0x009C SPTI0
void INT_Excep_RSPI0_SPTI0(void){ };
//;0x00A0 Reserved
//;0x00A4 Reserved
//;0x00A8 SPRI
void INT_Excep_QSPI_SPRI(void){ };
//;0x00AC SPTI
void INT_Excep_QSPI_SPTI(void){ };
//;0x00B0 SBFAI
void INT_Excep_SHDI_SBFAI(void){ };
//;0x00B4 MBFAI
void INT_Excep_MMC_MBFAI(void){ };
//;0x00B8 SSITX0
void INT_Excep_SSI0_SSITXI0(void){ };
//;0x00BC SSIRX0
void INT_Excep_SSI0_SSIRXI0(void){ };
//;0x00C0 SSIRTI1
void INT_Excep_SSI1_SSIRTI1(void){ };
//;0x00C4 Reserved
//;0x00C8 IDEI
void INT_Excep_SRC_IDEI(void){ };
//;0x00CC ODFI
void INT_Excep_SRC_ODFI(void){ };
//;0x00D0 RXI0
void INT_Excep_RIIC0_RXI0(void){ };
//;0x00D4C TXI0
void INT_Excep_RIIC0_TXI0(void){ };
//;0x00D8 RXI2
void INT_Excep_RIIC2_RXI2(void){ };
//;0x00DC TXI2
void INT_Excep_RIIC2_TXI2(void){ };
//;0x00E0 Reserved
//;0x00E4 Reserved
//;0x00E8 RXI0
void INT_Excep_SCI0_RXI0(void){ };
//;0x00EC TXI0
void INT_Excep_SCI0_TXI0(void){ };
//;0x00F0 RXI1
void INT_Excep_SCI1_RXI1(void){ };
//;0x00F4 TXI1
void INT_Excep_SCI1_TXI1(void){ };
//;0x00F8 RXI2
void INT_Excep_SCI2_RXI2(void){ };
//;0x00FC TXI2
void INT_Excep_SCI2_TXI2(void){ };
//;0x0100 IRQ0
void INT_Excep_ICU_IRQ0(void){ };
//;0x0104 IRQ1
void INT_Excep_ICU_IRQ1(void){ };
//;0x0108 IRQ2
void INT_Excep_ICU_IRQ2(void){ };
//;0x010C IRQ3
void INT_Excep_ICU_IRQ3(void){ };
//;0x0110 IRQ4
void INT_Excep_ICU_IRQ4(void){ };
//;0x0114 IRQ5
void INT_Excep_ICU_IRQ5(void){ };
//;0x0118 IRQ6
void INT_Excep_ICU_IRQ6(void){ };
//;0x011C IRQ7
void INT_Excep_ICU_IRQ7(void){ };
//;0x0120 IRQ8
void INT_Excep_ICU_IRQ8(void){ };
//;0x0124 IRQ9
void INT_Excep_ICU_IRQ9(void){ };
//;0x0128 IRQ10
void INT_Excep_ICU_IRQ10(void){ };
//;0x012C IRQ11
void INT_Excep_ICU_IRQ11(void){ };
//;0x0130 IRQ12
void INT_Excep_ICU_IRQ12(void){ };
//;0x0134 IRQ13
void INT_Excep_ICU_IRQ13(void){ };
//;0x0138 IRQ14
void INT_Excep_ICU_IRQ14(void){ };
//;0x013C IRQ15
void INT_Excep_ICU_IRQ15(void){ };
//;0x0140 RXI3
void INT_Excep_SCI3_RXI3(void){ };
//;0x0144 TXI3
void INT_Excep_SCI3_TXI3(void){ };
//;0x0148 RXI4
void INT_Excep_SCI4_RXI4(void){ };
//;0x014C TXI4
void INT_Excep_SCI4_TXI4(void){ };
//;0x0150 RXI5
void INT_Excep_SCI5_RXI5(void){ };
//;0x0154 TXI5
void INT_Excep_SCI5_TXI5(void){ };
//;0x0158 RXI6
void INT_Excep_SCI6_RXI6(void){ };
//;0x015C TXI6
void INT_Excep_SCI6_TXI6(void){ };
//;0x0160 COMPA1
void INT_Excep_LVD1_COMPA1(void){ };
//;0x0164 COMPA2
void INT_Excep_LVD2_COMPA2(void){ };
//;0x0168 USBR0
void INT_Excep_USB_USBR0(void){ };
//;0x016C Reserved
//;0x0170 ALM
void INT_Excep_RTC_ALM(void){ };
//;0x0174 PRD
void INT_Excep_RTC_PRD(void){ };
//;0x0178 HSUSBR
void INT_Excep_USBHS_USBHSR(void){ };
//;0x017C IWUNI
void INT_Excep_IWDT_IWUNI(void){ };
//;0x0180 WUNI
void INT_Excep_WDT_WUNI(void){ };
//;0x0184 PCDFI
void INT_Excep_PDC_PCDFI(void){ };
//;0x0188 RXI7
void INT_Excep_SCI7_RXI7(void){ };
//;0x018C TXI7
void INT_Excep_SCI7_TXI7(void){ };
//;0x0190 RXIF8
void INT_Excep_SCIF8_RXIF8(void){ };
//;0x0194 TXIF8
void INT_Excep_SCIF8_TXIF8(void){ };
//;0x0198 RXIF9
void INT_Excep_SCIF9_RXIF9(void){ };
//;0x019C TXIF9
void INT_Excep_SCIF9_TXIF9(void){ };
//;0x01A0 RXIF10
void INT_Excep_SCIF10_RXIF10(void){ };
//;0x01A4 TXIF10
void INT_Excep_SCIF10_TXIF10(void){ };
//;0x01A8 GROUPBE0
void INT_Excep_ICU_GROUPBE0(void){ };
//;0x01AC Reserved
//;0x01B0 Reserved
//;0x01B4 Reserved
//;0x01B8 GROUPBL0
void INT_Excep_ICU_GROUPBL0(void){ };
//;0x01BC GROUPBL1
void INT_Excep_ICU_GROUPBL1(void){ };
//;0x01C0 GROUPAL0
void INT_Excep_ICU_GROUPAL0(void){ };
//;0x01C4 GROUPAL1
void INT_Excep_ICU_GROUPAL1(void){ };
//;0x01C8 RXIF11
void INT_Excep_SCIF11_RXIF11(void){ };
//;0x01CC TXIF11
void INT_Excep_SCIF11_TXIF11(void){ };
//;0x01D0 RXIF12
void INT_Excep_SCIF12_RXIF12(void){ };
//;0x01D4 TXIF12
void INT_Excep_SCIF12_TXIF12(void){ };
//;0x01D8 Reserved
//;0x01DC Reserved
//;0x01E0 DMAC0I
void INT_Excep_DMAC_DMAC0I(void){ };
//;0x01E4 DMAC1I
void INT_Excep_DMAC_DMAC1I(void){ };
//;0x01E8 DMAC2I
void INT_Excep_DMAC_DMAC2I(void){ };
//;0x01EC DMAC3I
void INT_Excep_DMAC_DMAC3I(void){ };
//;0x01F0 DMAC74I
void INT_Excep_DMAC_DMAC74I(void){ };
//;0x01F4 OST
void INT_Excep_ICU_OST(void){ };
//;0x01F8 EXDMAC0I
void INT_Excep_EXDMAC_EXDMAC0I(void){ };
//;0x01FC EXDMAC1I
void INT_Excep_EXDMAC_EXDMAC1I(void){ };
//;0x0200 INTB128
void INT_Excep_PERIB_INTB128(void){ };
//;0x0204 INTB129
void INT_Excep_PERIB_INTB129(void){ };
//;0x0208 INTB130
void INT_Excep_PERIB_INTB130(void){ };
//;0x020C INTB131
void INT_Excep_PERIB_INTB131(void){ };
//;0x0210 INTB132
void INT_Excep_PERIB_INTB132(void){ };
//;0x0214 INTB133
void INT_Excep_PERIB_INTB133(void){ };
//;0x0218 INTB134
void INT_Excep_PERIB_INTB134(void){ };
//;0x021C INTB135
void INT_Excep_PERIB_INTB135(void){ };
//;0x0220 INTB136
void INT_Excep_PERIB_INTB136(void){ };
//;0x0224 INTB137
void INT_Excep_PERIB_INTB137(void){ };
//;0x0228 INTB138
void INT_Excep_PERIB_INTB138(void){ };
//;0x022C INTB139
void INT_Excep_PERIB_INTB139(void){ };
//;0x0230 INTB140
void INT_Excep_PERIB_INTB140(void){ };
//;0x0234 INTB141
void INT_Excep_PERIB_INTB141(void){ };
//;0x0238 INTB142
void INT_Excep_PERIB_INTB142(void){ };
//;0x023C INTB143
void INT_Excep_PERIB_INTB143(void){ };
//;0x0240 INTB144
void INT_Excep_PERIB_INTB144(void){ };
//;0x0244 INTB145
void INT_Excep_PERIB_INTB145(void){ };
//;0x0248 INTB146
void INT_Excep_PERIB_INTB146(void){ };
//;0x024C INTB147
void INT_Excep_PERIB_INTB147(void){ };
//;0x0250 INTB148
void INT_Excep_PERIB_INTB148(void){ };
//;0x02540 INTB149
void INT_Excep_PERIB_INTB149(void){ };
//;0x0258 INTB150
void INT_Excep_PERIB_INTB150(void){ };
//;0x025C INTB151
void INT_Excep_PERIB_INTB151(void){ };
//;0x0260 INTB152
void INT_Excep_PERIB_INTB152(void){ };
//;0x0264 INTB153
void INT_Excep_PERIB_INTB153(void){ };
//;0x0268 INTB154
void INT_Excep_PERIB_INTB154(void){ };
//;0x026C INTB155
void INT_Excep_PERIB_INTB155(void){ };
//;0x0270 INTB156
void INT_Excep_PERIB_INTB156(void){ };
//;0x0274 INTB157
void INT_Excep_PERIB_INTB157(void){ };
//;0x0278 INTB158
void INT_Excep_PERIB_INTB158(void){ };
//;0x027C INTB159
void INT_Excep_PERIB_INTB159(void){ };
//;0x0280 INTB160
void INT_Excep_PERIB_INTB160(void){ };
//;0x0284 INTB161
void INT_Excep_PERIB_INTB161(void){ };
//;0x0288 INTB162
void INT_Excep_PERIB_INTB162(void){ };
//;0x028C INTB163
void INT_Excep_PERIB_INTB163(void){ };
//;0x0290 INTB164
void INT_Excep_PERIB_INTB164(void){ };
//;0x0294 PERIB INTB165
void INT_Excep_PERIB_INTB165(void){ };
//;0x0298 PERIB INTB166
void INT_Excep_PERIB_INTB166(void){ };
//;0x029C PERIB INTB167
void INT_Excep_PERIB_INTB167(void){ };
//;0x02A0 PERIB INTB168
void INT_Excep_PERIB_INTB168(void){ };
//;0x02A4 PERIB INTB169
void INT_Excep_PERIB_INTB169(void){ };
//;0x02A8 PERIB INTB170
void INT_Excep_PERIB_INTB170(void){ };
//;0x02AC PERIB INTB171
void INT_Excep_PERIB_INTB171(void){ };
//;0x02B0 PERIB INTB172
void INT_Excep_PERIB_INTB172(void){ };
//;0x02B4 PERIB INTB173
void INT_Excep_PERIB_INTB173(void){ };
//;0x02B8 PERIB INTB174
void INT_Excep_PERIB_INTB174(void){ };
//;0x02BC PERIB INTB175
void INT_Excep_PERIB_INTB175(void){ };
//;0x02C0 PERIB INTB176
void INT_Excep_PERIB_INTB176(void){ };
//;0x02C4 PERIB INTB177
void INT_Excep_PERIB_INTB177(void){ };
//;0x02C8 PERIB INTB178
void INT_Excep_PERIB_INTB178(void){ };
//;0x02CC PERIB INTB179
void INT_Excep_PERIB_INTB179(void){ };
//;0x02D0 PERIB INTB180
void INT_Excep_PERIB_INTB180(void){ };
//;0x02D4 PERIB INTB181
void INT_Excep_PERIB_INTB181(void){ };
//;0x02D8 PERIB INTB182
void INT_Excep_PERIB_INTB182(void){ };
//;0x02DC PERIB INTB183
void INT_Excep_PERIB_INTB183(void){ };
//;0x02E0 PERIB INTB184
void INT_Excep_PERIB_INTB184(void){ };
//;0x02E4 PERIB INTB185
void INT_Excep_PERIB_INTB185(void){ };
//;0x02E8 PERIB INTB186
void INT_Excep_PERIB_INTB186(void){ };
//;0x02EC PERIB INTB187
void INT_Excep_PERIB_INTB187(void){ };
//;0x02F0 PERIB INTB188
void INT_Excep_PERIB_INTB188(void){ };
//;0x02F4 PERIB INTB189
void INT_Excep_PERIB_INTB189(void){ };
//;0x02F8 PERIB INTB190
void INT_Excep_PERIB_INTB190(void){ };
//;0x02FC PERIB INTB191
void INT_Excep_PERIB_INTB191(void){ };
//;0x0300 PERIB INTB192
void INT_Excep_PERIB_INTB192(void){ };
//;0x0304 PERIB INTB193
void INT_Excep_PERIB_INTB193(void){ };
//;0x0308 PERIB INTB194
void INT_Excep_PERIB_INTB194(void){ };
//;0x030C PERIB INTB195
void INT_Excep_PERIB_INTB195(void){ };
//;0x0310 PERIB INTB196
void INT_Excep_PERIB_INTB196(void){ };
//;0x0314 PERIB INTB197
void INT_Excep_PERIB_INTB197(void){ };
//;0x0318 PERIB INTB198
void INT_Excep_PERIB_INTB198(void){ };
//;0x031C PERIB INTB199
void INT_Excep_PERIB_INTB199(void){ };
//;0x0320 PERIB INTB200
void INT_Excep_PERIB_INTB200(void){ };
//;0x0324 PERIB INTB201
void INT_Excep_PERIB_INTB201(void){ };
//;0x0328 PERIB INTB202
void INT_Excep_PERIB_INTB202(void){ };
//;0x032C PERIB INTB203
void INT_Excep_PERIB_INTB203(void){ };
//;0x0320 PERIB INTB204
void INT_Excep_PERIB_INTB204(void){ };
//;0x0334 PERIB INTB205
void INT_Excep_PERIB_INTB205(void){ };
//;0x0338 PERIB INTB206
void INT_Excep_PERIB_INTB206(void){ };
//;0x033C PERIB INTB207
void INT_Excep_PERIB_INTB207(void){ };
//;0x0340 PERIA INTA208
void INT_Excep_PERIA_INTA208(void){ };
//;0x0344 PERIA INTA209
void INT_Excep_PERIA_INTA209(void){ };
//;0x0348 PERIA INTA210
void INT_Excep_PERIA_INTA210(void){ };
//;0x034C PERIA INTA211
void INT_Excep_PERIA_INTA211(void){ };
//;0x0350 PERIA INTA212
void INT_Excep_PERIA_INTA212(void){ };
//;0x0354 PERIA INTA213
void INT_Excep_PERIA_INTA213(void){ };
//;0x0358 PERIA INTA214
void INT_Excep_PERIA_INTA214(void){ };
//;0x035C PERIA INTA215
void INT_Excep_PERIA_INTA215(void){ };
//;0x0360 PERIA INTA216
void INT_Excep_PERIA_INTA216(void){ };
//;0x0364 PERIA INTA217
void INT_Excep_PERIA_INTA217(void){ };
//;0x0368 PERIA INTA218
void INT_Excep_PERIA_INTA218(void){ };
//;0x036C PERIA INTA219
void INT_Excep_PERIA_INTA219(void){ };
//;0x0370 PERIA INTA220
void INT_Excep_PERIA_INTA220(void){ };
//;0x0374 PERIA INTA221
void INT_Excep_PERIA_INTA221(void){ };
//;0x0378 PERIA INTA222
void INT_Excep_PERIA_INTA222(void){ };
//;0x037C PERIA INTA223
void INT_Excep_PERIA_INTA223(void){ };
//;0x0380 PERIA INTA224
void INT_Excep_PERIA_INTA224(void){ };
//;0x0384 PERIA INTA225
void INT_Excep_PERIA_INTA225(void){ };
//;0x0388 PERIA INTA226
void INT_Excep_PERIA_INTA226(void){ };
//;0x038C PERIA INTA227
void INT_Excep_PERIA_INTA227(void){ };
//;0x0390 PERIA INTA228
void INT_Excep_PERIA_INTA228(void){ };
//;0x0394 PERIA INTA229
void INT_Excep_PERIA_INTA229(void){ };
//;0x0398 PERIA INTA230
void INT_Excep_PERIA_INTA230(void){ };
//;0x039C PERIA INTA231
void INT_Excep_PERIA_INTA231(void){ };
//;0x03A0 PERIA INTA232
void INT_Excep_PERIA_INTA232(void){ };
//;0x03A4 PERIA INTA233
void INT_Excep_PERIA_INTA233(void){ };
//;0x03A8 PERIA INTA234
void INT_Excep_PERIA_INTA234(void){ };
//;0x03AC PERIA INTA235
void INT_Excep_PERIA_INTA235(void){ };
//;0x03B0 PERIA INTA236
void INT_Excep_PERIA_INTA236(void){ };
//;0x04B4 PERIA INTA237
void INT_Excep_PERIA_INTA237(void){ };
//;0x03B8 PERIA INTA238
void INT_Excep_PERIA_INTA238(void){ };
//;0x03BC PERIA INTA239
void INT_Excep_PERIA_INTA239(void){ };
//;0x03C0 PERIA INTA240
void INT_Excep_PERIA_INTA240(void){ };
//;0x03C4 PERIA INTA241
void INT_Excep_PERIA_INTA241(void){ };
//;0x03C8 PERIA INTA242
void INT_Excep_PERIA_INTA242(void){ };
//;0x03CC PERIA INTA243
void INT_Excep_PERIA_INTA243(void){ };
//;0x03D0 PERIA INTA244
void INT_Excep_PERIA_INTA244(void){ };
//;0x03D4 PERIA INTA245
void INT_Excep_PERIA_INTA245(void){ };
//;0x03D8 PERIA INTA246
void INT_Excep_PERIA_INTA246(void){ };
//;0x03DC PERIA INTA247
void INT_Excep_PERIA_INTA247(void){ };
//;0x03E0 PERIA INTA248
void INT_Excep_PERIA_INTA248(void){ };
//;0x03E4 PERIA INTA249
void INT_Excep_PERIA_INTA249(void){ };
//;0x03E8 PERIA INTA250
void INT_Excep_PERIA_INTA250(void){ };
//;0x03EC PERIA INTA251
void INT_Excep_PERIA_INTA251(void){ };
//;0x03F0 PERIA INTA252
void INT_Excep_PERIA_INTA252(void){ };
//;0x03F4 PERIA INTA253
void INT_Excep_PERIA_INTA253(void){ };
//;0x03F8 PERIA INTA254
void INT_Excep_PERIA_INTA254(void){ };
//;0x03FC PERIA INTA255
void INT_Excep_PERIA_INTA255(void){ };

@ -0,0 +1,770 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : interrupt_handlers.h */
/* DESCRIPTION : Interrupt Handler Declarations */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 03/10/2013 */
/************************************************************************/
#ifndef INTERRUPT_HANDLERS_H
#define INTERRUPT_HANDLERS_H
// Exception(Supervisor Instruction)
void INT_Excep_SuperVisorInst(void) __attribute__ ((interrupt));
// Exception(Access Instruction)
void INT_Excep_AccessInst(void) __attribute__ ((interrupt));
// Exception(Undefined Instruction)
void INT_Excep_UndefinedInst(void) __attribute__ ((interrupt));
// Exception(Floating Point)
void INT_Excep_FloatingPoint(void) __attribute__ ((interrupt));
// NMI
void INT_NonMaskableInterrupt(void) __attribute__ ((interrupt));
// Dummy
void Dummy(void) __attribute__ ((interrupt));
// BRK
void INT_Excep_BRK(void) __attribute__ ((interrupt));
//;0x0000 Reserved
//;0x0004 Reserved
//;0x0008 Reserved
//;0x000C Reserved
//;0x0010 Reserved
//;0x0014 Reserved
//;0x0018 Reserved
//;0x001C Reserved
//;0x0020 Reserved
//;0x0024 Reserved
//;0x0028 Reserved
//;0x002C Reserved
//;0x0030 Reserved
//;0x0034 Reserved
//;0x0038 Reserved
//;0x003C Reserved
//;0x0040 BUSERR
void INT_Excep_BSC_BUSERR(void) __attribute__ ((interrupt));
//;0x0044 Reserved
//;0x0048 RAMERR
void INT_Excep_RAM_RAMERR(void) __attribute__ ((interrupt));
//;0x004C Reserved
//;0x0050 Reserved
//;0x0054 FIFERR
void INT_Excep_FCU_FIFERR(void) __attribute__ ((interrupt));
//;0x0058 Reserved
//;0x005C FRDYI
void INT_Excep_FCU_FRDYI(void) __attribute__ ((interrupt));
//;0x0060 Reserved
//;0x0064 Reserved
//;0x0068 SWINT2
void INT_Excep_ICU_SWINT2(void) __attribute__ ((interrupt));
//;0x006C SWINT
void INT_Excep_ICU_SWINT(void) __attribute__ ((interrupt));
//;0x0070 CMI0
void INT_Excep_CMT0_CMI0(void) __attribute__ ((interrupt));
//;0x0074 CMI1
void INT_Excep_CMT1_CMI1(void) __attribute__ ((interrupt));
//;0x0078 CMWI0
void INT_Excep_CMTW0_CMWI0(void) __attribute__ ((interrupt));
//;0x007C CMWI1
void INT_Excep_CMTW1_CMWI1(void) __attribute__ ((interrupt));
//;0x0080 D0FIFO2
void INT_Excep_USBHS_D0FIFO2(void) __attribute__ ((interrupt));
//;0x0084 D1FIFO2
void INT_Excep_USBHS_D1FIFO2(void) __attribute__ ((interrupt));
//;0x0088 D0FIFO0
void INT_Excep_USB0_D0FIFO0(void) __attribute__ ((interrupt));
//;0x008C D1FIFO0
void INT_Excep_USB0_D1FIFO0(void) __attribute__ ((interrupt));
//;0x0090 Reserved
//;0x0094 Reserved
//;0x0098 SPRI0
void INT_Excep_RSPI0_SPRI0(void) __attribute__ ((interrupt));
//;0x009C SPTI0
void INT_Excep_RSPI0_SPTI0(void) __attribute__ ((interrupt));
//;0x00A0 Reserved
//;0x00A4 Reserved
//;0x00A8 SPRI
void INT_Excep_QSPI_SPRI(void) __attribute__ ((interrupt));
//;0x00AC SPTI
void INT_Excep_QSPI_SPTI(void) __attribute__ ((interrupt));
//;0x00B0 SBFAI
void INT_Excep_SHDI_SBFAI(void) __attribute__ ((interrupt));
//;0x00B4 MBFAI
void INT_Excep_MMC_MBFAI(void) __attribute__ ((interrupt));
//;0x00B8 SSITX0
void INT_Excep_SSI0_SSITXI0(void) __attribute__ ((interrupt));
//;0x00BC SSIRX0
void INT_Excep_SSI0_SSIRXI0(void) __attribute__ ((interrupt));
//;0x00C0 SSIRTI1
void INT_Excep_SSI1_SSIRTI1(void) __attribute__ ((interrupt));
//;0x00C4 Reserved
//;0x00C8 IDEI
void INT_Excep_SRC_IDEI(void) __attribute__ ((interrupt));
//;0x00CC ODFI
void INT_Excep_SRC_ODFI(void) __attribute__ ((interrupt));
//;0x00D0 RXI0
void INT_Excep_RIIC0_RXI0(void) __attribute__ ((interrupt));
//;0x00D4C TXI0
void INT_Excep_RIIC0_TXI0(void) __attribute__ ((interrupt));
//;0x00D8 RXI2
void INT_Excep_RIIC2_RXI2(void) __attribute__ ((interrupt));
//;0x00DC TXI2
void INT_Excep_RIIC2_TXI2(void) __attribute__ ((interrupt));
//;0x00E0 Reserved
//;0x00E4 Reserved
//;0x00E8 RXI0
void INT_Excep_SCI0_RXI0(void) __attribute__ ((interrupt));
//;0x00EC TXI0
void INT_Excep_SCI0_TXI0(void) __attribute__ ((interrupt));
//;0x00F0 RXI1
void INT_Excep_SCI1_RXI1(void) __attribute__ ((interrupt));
//;0x00F4 TXI1
void INT_Excep_SCI1_TXI1(void) __attribute__ ((interrupt));
//;0x00F8 RXI2
void INT_Excep_SCI2_RXI2(void) __attribute__ ((interrupt));
//;0x00FC TXI2
void INT_Excep_SCI2_TXI2(void) __attribute__ ((interrupt));
//;0x0100 IRQ0
void INT_Excep_ICU_IRQ0(void) __attribute__ ((interrupt));
//;0x0104 IRQ1
void INT_Excep_ICU_IRQ1(void) __attribute__ ((interrupt));
//;0x0108 IRQ2
void INT_Excep_ICU_IRQ2(void) __attribute__ ((interrupt));
//;0x010C IRQ3
void INT_Excep_ICU_IRQ3(void) __attribute__ ((interrupt));
//;0x0110 IRQ4
void INT_Excep_ICU_IRQ4(void) __attribute__ ((interrupt));
//;0x0114 IRQ5
void INT_Excep_ICU_IRQ5(void) __attribute__ ((interrupt));
//;0x0118 IRQ6
void INT_Excep_ICU_IRQ6(void) __attribute__ ((interrupt));
//;0x011C IRQ7
void INT_Excep_ICU_IRQ7(void) __attribute__ ((interrupt));
//;0x0120 IRQ8
void INT_Excep_ICU_IRQ8(void) __attribute__ ((interrupt));
//;0x0124 IRQ9
void INT_Excep_ICU_IRQ9(void) __attribute__ ((interrupt));
//;0x0128 IRQ10
void INT_Excep_ICU_IRQ10(void) __attribute__ ((interrupt));
//;0x012C IRQ11
void INT_Excep_ICU_IRQ11(void) __attribute__ ((interrupt));
//;0x0130 IRQ12
void INT_Excep_ICU_IRQ12(void) __attribute__ ((interrupt));
//;0x0134 IRQ13
void INT_Excep_ICU_IRQ13(void) __attribute__ ((interrupt));
//;0x0138 IRQ14
void INT_Excep_ICU_IRQ14(void) __attribute__ ((interrupt));
//;0x013C IRQ15
void INT_Excep_ICU_IRQ15(void) __attribute__ ((interrupt));
//;0x0140 RXI3
void INT_Excep_SCI3_RXI3(void) __attribute__ ((interrupt));
//;0x0144 TXI3
void INT_Excep_SCI3_TXI3(void) __attribute__ ((interrupt));
//;0x0148 RXI4
void INT_Excep_SCI4_RXI4(void) __attribute__ ((interrupt));
//;0x014C TXI4
void INT_Excep_SCI4_TXI4(void) __attribute__ ((interrupt));
//;0x0150 RXI5
void INT_Excep_SCI5_RXI5(void) __attribute__ ((interrupt));
//;0x0154 TXI5
void INT_Excep_SCI5_TXI5(void) __attribute__ ((interrupt));
//;0x0158 RXI6
void INT_Excep_SCI6_RXI6(void) __attribute__ ((interrupt));
//;0x015C TXI6
void INT_Excep_SCI6_TXI6(void) __attribute__ ((interrupt));
//;0x0160 COMPA1
void INT_Excep_LVD1_COMPA1(void) __attribute__ ((interrupt));
//;0x0164 COMPA2
void INT_Excep_LVD2_COMPA2(void) __attribute__ ((interrupt));
//;0x0168 USBR0
void INT_Excep_USB_USBR0(void) __attribute__ ((interrupt));
//;0x016C Reserved
//;0x0170 ALM
void INT_Excep_RTC_ALM(void) __attribute__ ((interrupt));
//;0x0174 PRD
void INT_Excep_RTC_PRD(void) __attribute__ ((interrupt));
//;0x0178 HSUSBR
void INT_Excep_USBHS_USBHSR(void) __attribute__ ((interrupt));
//;0x017C IWUNI
void INT_Excep_IWDT_IWUNI(void) __attribute__ ((interrupt));
//;0x0180 WUNI
void INT_Excep_WDT_WUNI(void) __attribute__ ((interrupt));
//;0x0184 PCDFI
void INT_Excep_PDC_PCDFI(void) __attribute__ ((interrupt));
//;0x0188 RXI7
void INT_Excep_SCI7_RXI7(void) __attribute__ ((interrupt));
//;0x018C TXI7
void INT_Excep_SCI7_TXI7(void) __attribute__ ((interrupt));
//;0x0190 RXIF8
void INT_Excep_SCIF8_RXIF8(void) __attribute__ ((interrupt));
//;0x0194 TXIF8
void INT_Excep_SCIF8_TXIF8(void) __attribute__ ((interrupt));
//;0x0198 RXIF9
void INT_Excep_SCIF9_RXIF9(void) __attribute__ ((interrupt));
//;0x019C TXIF9
void INT_Excep_SCIF9_TXIF9(void) __attribute__ ((interrupt));
//;0x01A0 RXIF10
void INT_Excep_SCIF10_RXIF10(void) __attribute__ ((interrupt));
//;0x01A4 TXIF10
void INT_Excep_SCIF10_TXIF10(void) __attribute__ ((interrupt));
//;0x01A8 GROUPBE0
void INT_Excep_ICU_GROUPBE0(void) __attribute__ ((interrupt));
//;0x01AC Reserved
//;0x01B0 Reserved
//;0x01B4 Reserved
//;0x01B8 GROUPBL0
void INT_Excep_ICU_GROUPBL0(void) __attribute__ ((interrupt));
//;0x01BC GROUPBL1
void INT_Excep_ICU_GROUPBL1(void) __attribute__ ((interrupt));
//;0x01C0 GROUPAL0
void INT_Excep_ICU_GROUPAL0(void) __attribute__ ((interrupt));
//;0x01C4 GROUPAL1
void INT_Excep_ICU_GROUPAL1(void) __attribute__ ((interrupt));
//;0x01C8 RXIF11
void INT_Excep_SCIF11_RXIF11(void) __attribute__ ((interrupt));
//;0x01CC TXIF11
void INT_Excep_SCIF11_TXIF11(void) __attribute__ ((interrupt));
//;0x01D0 RXIF12
void INT_Excep_SCIF12_RXIF12(void) __attribute__ ((interrupt));
//;0x01D4 TXIF12
void INT_Excep_SCIF12_TXIF12(void) __attribute__ ((interrupt));
//;0x01D8 Reserved
//;0x01DC Reserved
//;0x01E0 DMAC0I
void INT_Excep_DMAC_DMAC0I(void) __attribute__ ((interrupt));
//;0x01E4 DMAC1I
void INT_Excep_DMAC_DMAC1I(void) __attribute__ ((interrupt));
//;0x01E8 DMAC2I
void INT_Excep_DMAC_DMAC2I(void) __attribute__ ((interrupt));
//;0x01EC DMAC3I
void INT_Excep_DMAC_DMAC3I(void) __attribute__ ((interrupt));
//;0x01F0 DMAC74I
void INT_Excep_DMAC_DMAC74I(void) __attribute__ ((interrupt));
//;0x01F4 OST
void INT_Excep_ICU_OST(void) __attribute__ ((interrupt));
//;0x01F8 EXDMAC0I
void INT_Excep_EXDMAC_EXDMAC0I(void) __attribute__ ((interrupt));
//;0x01FC EXDMAC1I
void INT_Excep_EXDMAC_EXDMAC1I(void) __attribute__ ((interrupt));
//;0x0200 INTB128
void INT_Excep_PERIB_INTB128(void) __attribute__ ((interrupt));
//;0x0204 INTB129
void INT_Excep_PERIB_INTB129(void) __attribute__ ((interrupt));
//;0x0208 INTB130
void INT_Excep_PERIB_INTB130(void) __attribute__ ((interrupt));
//;0x020C INTB131
void INT_Excep_PERIB_INTB131(void) __attribute__ ((interrupt));
//;0x0210 INTB132
void INT_Excep_PERIB_INTB132(void) __attribute__ ((interrupt));
//;0x0214 INTB133
void INT_Excep_PERIB_INTB133(void) __attribute__ ((interrupt));
//;0x0218 INTB134
void INT_Excep_PERIB_INTB134(void) __attribute__ ((interrupt));
//;0x021C INTB135
void INT_Excep_PERIB_INTB135(void) __attribute__ ((interrupt));
//;0x0220 INTB136
void INT_Excep_PERIB_INTB136(void) __attribute__ ((interrupt));
//;0x0224 INTB137
void INT_Excep_PERIB_INTB137(void) __attribute__ ((interrupt));
//;0x0228 INTB138
void INT_Excep_PERIB_INTB138(void) __attribute__ ((interrupt));
//;0x022C INTB139
void INT_Excep_PERIB_INTB139(void) __attribute__ ((interrupt));
//;0x0230 INTB140
void INT_Excep_PERIB_INTB140(void) __attribute__ ((interrupt));
//;0x0234 INTB141
void INT_Excep_PERIB_INTB141(void) __attribute__ ((interrupt));
//;0x0238 INTB142
void INT_Excep_PERIB_INTB142(void) __attribute__ ((interrupt));
//;0x023C INTB143
void INT_Excep_PERIB_INTB143(void) __attribute__ ((interrupt));
//;0x0240 INTB144
void INT_Excep_PERIB_INTB144(void) __attribute__ ((interrupt));
//;0x0244 INTB145
void INT_Excep_PERIB_INTB145(void) __attribute__ ((interrupt));
//;0x0248 INTB146
void INT_Excep_PERIB_INTB146(void) __attribute__ ((interrupt));
//;0x024C INTB147
void INT_Excep_PERIB_INTB147(void) __attribute__ ((interrupt));
//;0x0250 INTB148
void INT_Excep_PERIB_INTB148(void) __attribute__ ((interrupt));
//;0x02540 INTB149
void INT_Excep_PERIB_INTB149(void) __attribute__ ((interrupt));
//;0x0258 INTB150
void INT_Excep_PERIB_INTB150(void) __attribute__ ((interrupt));
//;0x025C INTB151
void INT_Excep_PERIB_INTB151(void) __attribute__ ((interrupt));
//;0x0260 INTB152
void INT_Excep_PERIB_INTB152(void) __attribute__ ((interrupt));
//;0x0264 INTB153
void INT_Excep_PERIB_INTB153(void) __attribute__ ((interrupt));
//;0x0268 INTB154
void INT_Excep_PERIB_INTB154(void) __attribute__ ((interrupt));
//;0x026C INTB155
void INT_Excep_PERIB_INTB155(void) __attribute__ ((interrupt));
//;0x0270 INTB156
void INT_Excep_PERIB_INTB156(void) __attribute__ ((interrupt));
//;0x0274 INTB157
void INT_Excep_PERIB_INTB157(void) __attribute__ ((interrupt));
//;0x0278 INTB158
void INT_Excep_PERIB_INTB158(void) __attribute__ ((interrupt));
//;0x027C INTB159
void INT_Excep_PERIB_INTB159(void) __attribute__ ((interrupt));
//;0x0280 INTB160
void INT_Excep_PERIB_INTB160(void) __attribute__ ((interrupt));
//;0x0284 INTB161
void INT_Excep_PERIB_INTB161(void) __attribute__ ((interrupt));
//;0x0288 INTB162
void INT_Excep_PERIB_INTB162(void) __attribute__ ((interrupt));
//;0x028C INTB163
void INT_Excep_PERIB_INTB163(void) __attribute__ ((interrupt));
//;0x0290 INTB164
void INT_Excep_PERIB_INTB164(void) __attribute__ ((interrupt));
//;0x0294 PERIB INTB165
void INT_Excep_PERIB_INTB165(void) __attribute__ ((interrupt));
//;0x0298 PERIB INTB166
void INT_Excep_PERIB_INTB166(void) __attribute__ ((interrupt));
//;0x029C PERIB INTB167
void INT_Excep_PERIB_INTB167(void) __attribute__ ((interrupt));
//;0x02A0 PERIB INTB168
void INT_Excep_PERIB_INTB168(void) __attribute__ ((interrupt));
//;0x02A4 PERIB INTB169
void INT_Excep_PERIB_INTB169(void) __attribute__ ((interrupt));
//;0x02A8 PERIB INTB170
void INT_Excep_PERIB_INTB170(void) __attribute__ ((interrupt));
//;0x02AC PERIB INTB171
void INT_Excep_PERIB_INTB171(void) __attribute__ ((interrupt));
//;0x02B0 PERIB INTB172
void INT_Excep_PERIB_INTB172(void) __attribute__ ((interrupt));
//;0x02B4 PERIB INTB173
void INT_Excep_PERIB_INTB173(void) __attribute__ ((interrupt));
//;0x02B8 PERIB INTB174
void INT_Excep_PERIB_INTB174(void) __attribute__ ((interrupt));
//;0x02BC PERIB INTB175
void INT_Excep_PERIB_INTB175(void) __attribute__ ((interrupt));
//;0x02C0 PERIB INTB176
void INT_Excep_PERIB_INTB176(void) __attribute__ ((interrupt));
//;0x02C4 PERIB INTB177
void INT_Excep_PERIB_INTB177(void) __attribute__ ((interrupt));
//;0x02C8 PERIB INTB178
void INT_Excep_PERIB_INTB178(void) __attribute__ ((interrupt));
//;0x02CC PERIB INTB179
void INT_Excep_PERIB_INTB179(void) __attribute__ ((interrupt));
//;0x02D0 PERIB INTB180
void INT_Excep_PERIB_INTB180(void) __attribute__ ((interrupt));
//;0x02D4 PERIB INTB181
void INT_Excep_PERIB_INTB181(void) __attribute__ ((interrupt));
//;0x02D8 PERIB INTB182
void INT_Excep_PERIB_INTB182(void) __attribute__ ((interrupt));
//;0x02DC PERIB INTB183
void INT_Excep_PERIB_INTB183(void) __attribute__ ((interrupt));
//;0x02E0 PERIB INTB184
void INT_Excep_PERIB_INTB184(void) __attribute__ ((interrupt));
//;0x02E4 PERIB INTB185
void INT_Excep_PERIB_INTB185(void) __attribute__ ((interrupt));
//;0x02E8 PERIB INTB186
void INT_Excep_PERIB_INTB186(void) __attribute__ ((interrupt));
//;0x02EC PERIB INTB187
void INT_Excep_PERIB_INTB187(void) __attribute__ ((interrupt));
//;0x02F0 PERIB INTB188
void INT_Excep_PERIB_INTB188(void) __attribute__ ((interrupt));
//;0x02F4 PERIB INTB189
void INT_Excep_PERIB_INTB189(void) __attribute__ ((interrupt));
//;0x02F8 PERIB INTB190
void INT_Excep_PERIB_INTB190(void) __attribute__ ((interrupt));
//;0x02FC PERIB INTB191
void INT_Excep_PERIB_INTB191(void) __attribute__ ((interrupt));
//;0x0300 PERIB INTB192
void INT_Excep_PERIB_INTB192(void) __attribute__ ((interrupt));
//;0x0304 PERIB INTB193
void INT_Excep_PERIB_INTB193(void) __attribute__ ((interrupt));
//;0x0308 PERIB INTB194
void INT_Excep_PERIB_INTB194(void) __attribute__ ((interrupt));
//;0x030C PERIB INTB195
void INT_Excep_PERIB_INTB195(void) __attribute__ ((interrupt));
//;0x0310 PERIB INTB196
void INT_Excep_PERIB_INTB196(void) __attribute__ ((interrupt));
//;0x0314 PERIB INTB197
void INT_Excep_PERIB_INTB197(void) __attribute__ ((interrupt));
//;0x0318 PERIB INTB198
void INT_Excep_PERIB_INTB198(void) __attribute__ ((interrupt));
//;0x031C PERIB INTB199
void INT_Excep_PERIB_INTB199(void) __attribute__ ((interrupt));
//;0x0320 PERIB INTB200
void INT_Excep_PERIB_INTB200(void) __attribute__ ((interrupt));
//;0x0324 PERIB INTB201
void INT_Excep_PERIB_INTB201(void) __attribute__ ((interrupt));
//;0x0328 PERIB INTB202
void INT_Excep_PERIB_INTB202(void) __attribute__ ((interrupt));
//;0x032C PERIB INTB203
void INT_Excep_PERIB_INTB203(void) __attribute__ ((interrupt));
//;0x0320 PERIB INTB204
void INT_Excep_PERIB_INTB204(void) __attribute__ ((interrupt));
//;0x0334 PERIB INTB205
void INT_Excep_PERIB_INTB205(void) __attribute__ ((interrupt));
//;0x0338 PERIB INTB206
void INT_Excep_PERIB_INTB206(void) __attribute__ ((interrupt));
//;0x033C PERIB INTB207
void INT_Excep_PERIB_INTB207(void) __attribute__ ((interrupt));
//;0x0340 PERIA INTA208
void INT_Excep_PERIA_INTA208(void) __attribute__ ((interrupt));
//;0x0344 PERIA INTA209
void INT_Excep_PERIA_INTA209(void) __attribute__ ((interrupt));
//;0x0348 PERIA INTA210
void INT_Excep_PERIA_INTA210(void) __attribute__ ((interrupt));
//;0x034C PERIA INTA211
void INT_Excep_PERIA_INTA211(void) __attribute__ ((interrupt));
//;0x0350 PERIA INTA212
void INT_Excep_PERIA_INTA212(void) __attribute__ ((interrupt));
//;0x0354 PERIA INTA213
void INT_Excep_PERIA_INTA213(void) __attribute__ ((interrupt));
//;0x0358 PERIA INTA214
void INT_Excep_PERIA_INTA214(void) __attribute__ ((interrupt));
//;0x035C PERIA INTA215
void INT_Excep_PERIA_INTA215(void) __attribute__ ((interrupt));
//;0x0360 PERIA INTA216
void INT_Excep_PERIA_INTA216(void) __attribute__ ((interrupt));
//;0x0364 PERIA INTA217
void INT_Excep_PERIA_INTA217(void) __attribute__ ((interrupt));
//;0x0368 PERIA INTA218
void INT_Excep_PERIA_INTA218(void) __attribute__ ((interrupt));
//;0x036C PERIA INTA219
void INT_Excep_PERIA_INTA219(void) __attribute__ ((interrupt));
//;0x0370 PERIA INTA220
void INT_Excep_PERIA_INTA220(void) __attribute__ ((interrupt));
//;0x0374 PERIA INTA221
void INT_Excep_PERIA_INTA221(void) __attribute__ ((interrupt));
//;0x0378 PERIA INTA222
void INT_Excep_PERIA_INTA222(void) __attribute__ ((interrupt));
//;0x037C PERIA INTA223
void INT_Excep_PERIA_INTA223(void) __attribute__ ((interrupt));
//;0x0380 PERIA INTA224
void INT_Excep_PERIA_INTA224(void) __attribute__ ((interrupt));
//;0x0384 PERIA INTA225
void INT_Excep_PERIA_INTA225(void) __attribute__ ((interrupt));
//;0x0388 PERIA INTA226
void INT_Excep_PERIA_INTA226(void) __attribute__ ((interrupt));
//;0x038C PERIA INTA227
void INT_Excep_PERIA_INTA227(void) __attribute__ ((interrupt));
//;0x0390 PERIA INTA228
void INT_Excep_PERIA_INTA228(void) __attribute__ ((interrupt));
//;0x0394 PERIA INTA229
void INT_Excep_PERIA_INTA229(void) __attribute__ ((interrupt));
//;0x0398 PERIA INTA230
void INT_Excep_PERIA_INTA230(void) __attribute__ ((interrupt));
//;0x039C PERIA INTA231
void INT_Excep_PERIA_INTA231(void) __attribute__ ((interrupt));
//;0x03A0 PERIA INTA232
void INT_Excep_PERIA_INTA232(void) __attribute__ ((interrupt));
//;0x03A4 PERIA INTA233
void INT_Excep_PERIA_INTA233(void) __attribute__ ((interrupt));
//;0x03A8 PERIA INTA234
void INT_Excep_PERIA_INTA234(void) __attribute__ ((interrupt));
//;0x03AC PERIA INTA235
void INT_Excep_PERIA_INTA235(void) __attribute__ ((interrupt));
//;0x03B0 PERIA INTA236
void INT_Excep_PERIA_INTA236(void) __attribute__ ((interrupt));
//;0x04B4 PERIA INTA237
void INT_Excep_PERIA_INTA237(void) __attribute__ ((interrupt));
//;0x03B8 PERIA INTA238
void INT_Excep_PERIA_INTA238(void) __attribute__ ((interrupt));
//;0x03BC PERIA INTA239
void INT_Excep_PERIA_INTA239(void) __attribute__ ((interrupt));
//;0x03C0 PERIA INTA240
void INT_Excep_PERIA_INTA240(void) __attribute__ ((interrupt));
//;0x03C4 PERIA INTA241
void INT_Excep_PERIA_INTA241(void) __attribute__ ((interrupt));
//;0x03C8 PERIA INTA242
void INT_Excep_PERIA_INTA242(void) __attribute__ ((interrupt));
//;0x03CC PERIA INTA243
void INT_Excep_PERIA_INTA243(void) __attribute__ ((interrupt));
//;0x03D0 PERIA INTA244
void INT_Excep_PERIA_INTA244(void) __attribute__ ((interrupt));
//;0x03D4 PERIA INTA245
void INT_Excep_PERIA_INTA245(void) __attribute__ ((interrupt));
//;0x03D8 PERIA INTA246
void INT_Excep_PERIA_INTA246(void) __attribute__ ((interrupt));
//;0x03DC PERIA INTA247
void INT_Excep_PERIA_INTA247(void) __attribute__ ((interrupt));
//;0x03E0 PERIA INTA248
void INT_Excep_PERIA_INTA248(void) __attribute__ ((interrupt));
//;0x03E4 PERIA INTA249
void INT_Excep_PERIA_INTA249(void) __attribute__ ((interrupt));
//;0x03E8 PERIA INTA250
void INT_Excep_PERIA_INTA250(void) __attribute__ ((interrupt));
//;0x03EC PERIA INTA251
void INT_Excep_PERIA_INTA251(void) __attribute__ ((interrupt));
//;0x03F0 PERIA INTA252
void INT_Excep_PERIA_INTA252(void) __attribute__ ((interrupt));
//;0x03F4 PERIA INTA253
void INT_Excep_PERIA_INTA253(void) __attribute__ ((interrupt));
//;0x03F8 PERIA INTA254
void INT_Excep_PERIA_INTA254(void) __attribute__ ((interrupt));
//;0x03FC PERIA INTA255
void INT_Excep_PERIA_INTA255(void) __attribute__ ((interrupt));
//;<<VECTOR DATA START (POWER ON RESET)>>
//;Power On Reset PC
extern void PowerON_Reset(void);
//;<<VECTOR DATA END (POWER ON RESET)>>
#endif

@ -0,0 +1,180 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : reset_program.asm */
/* DESCRIPTION : Reset Program */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 08/07/2013 */
/************************************************************************/
/*reset_program.asm*/
.list
.section .text
.global _PowerON_Reset /*global Start routine */
.extern _HardwareSetup /*external Sub-routine to initialise Hardware*/
.extern _data
.extern _mdata
.extern _ebss
.extern _bss
.extern _edata
.extern _main
.extern _ustack
.extern _istack
.extern _rvectors
.extern _exit
_PowerON_Reset :
/* initialise user stack pointer */
mvtc #_ustack,USP
/* initialise interrupt stack pointer */
mvtc #_istack,ISP
/* setup intb */
mvtc #_rvectors_start, intb /* INTERRUPT VECTOR ADDRESS definition */
/* setup FPSW */
mvtc #100h, fpsw
/* load data section from ROM to RAM */
mov #_mdata,r2 /* src ROM address of data section in R2 */
mov #_data,r1 /* dest start RAM address of data section in R1 */
mov #_edata,r3 /* end RAM address of data section in R3 */
sub r1,r3 /* size of data section in R3 (R3=R3-R1) */
smovf /* block copy R3 bytes from R2 to R1 */
/* bss initialisation : zero out bss */
mov #00h,r2 /* load R2 reg with zero */
mov #_ebss, r3 /* store the end address of bss in R3 */
mov #_bss, r1 /* store the start address of bss in R1 */
sub r1,r3 /* size of bss section in R3 (R3=R3-R1) */
sstr.b
/* call the hardware initialiser */
bsr.a _HardwareSetup
nop
/* setup PSW */
mvtc #10000h, psw /* Set Ubit & Ibit for PSW */
/* change PSW PM to user-mode */
MVFC PSW,R1
OR #00100000h,R1
PUSH.L R1
MVFC PC,R1
ADD #10,R1
PUSH.L R1
RTE
NOP
NOP
#ifdef CPPAPP
bsr.a __rx_init
#endif
/* start user program */
bsr.a _main
bsr.a _exit
#ifdef CPPAPP
.global _rx_run_preinit_array
.type _rx_run_preinit_array,@function
_rx_run_preinit_array:
mov #__preinit_array_start,r1
mov #__preinit_array_end,r2
bra.a _rx_run_inilist
.global _rx_run_init_array
.type _rx_run_init_array,@function
_rx_run_init_array:
mov #__init_array_start,r1
mov #__init_array_end,r2
mov #4, r3
bra.a _rx_run_inilist
.global _rx_run_fini_array
.type _rx_run_fini_array,@function
_rx_run_fini_array:
mov #__fini_array_start,r2
mov #__fini_array_end,r1
mov #-4, r3
/* fall through */
_rx_run_inilist:
next_inilist:
cmp r1,r2
beq.b done_inilist
mov.l [r1],r4
cmp #-1, r4
beq.b skip_inilist
cmp #0, r4
beq.b skip_inilist
pushm r1-r3
jsr r4
popm r1-r3
skip_inilist:
add r3,r1
bra.b next_inilist
done_inilist:
rts
.section .init,"ax"
.balign 4
.global __rx_init
__rx_init:
.section .fini,"ax"
.balign 4
.global __rx_fini
__rx_fini:
bsr.a _rx_run_fini_array
.section .sdata
.balign 4
.global __gp
.weak __gp
__gp:
.section .data
.global ___dso_handle
.weak ___dso_handle
___dso_handle:
.long 0
.section .init,"ax"
bsr.a _rx_run_preinit_array
bsr.a _rx_run_init_array
rts
.global __rx_init_end
__rx_init_end:
.section .fini,"ax"
rts
.global __rx_fini_end
__rx_fini_end:
#endif
/* call to exit*/
_exit:
bra _loop_here
_loop_here:
bra _loop_here
.text
.end

@ -0,0 +1,28 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : typedefine.h */
/* DESCRIPTION : Aliases of Integer Type */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 08/07/2013 */
/************************************************************************/
typedef signed char _SBYTE;
typedef unsigned char _UBYTE;
typedef signed short _SWORD;
typedef unsigned short _UWORD;
typedef signed int _SINT;
typedef unsigned int _UINT;
typedef signed long _SDWORD;
typedef unsigned long _UDWORD;
typedef signed long long _SQWORD;
typedef unsigned long long _UQWORD;

@ -0,0 +1,822 @@
/***********************************************************************/
/* */
/* PROJECT NAME : RTOSDemo */
/* FILE : vector_table.c */
/* DESCRIPTION : Vector Table */
/* CPU SERIES : RX600 */
/* CPU TYPE : RX64M */
/* */
/* This file is generated by e2 studio. */
/* */
/***********************************************************************/
/************************************************************************/
/* File Version: V1.00 */
/* Date Generated: 03/10/2013 */
/************************************************************************/
#include "interrupt_handlers.h"
typedef void (*fp) (void);
extern void PowerON_Reset (void);
extern void stack (void);
#define FVECT_SECT __attribute__ ((section (".fvectors")))
const void *HardwareVectors[] FVECT_SECT = {
//;0xffffff80 Reserved
(fp)0,
//;0xffffff84 Reserved
(fp)0,
//;0xffffff88 Reserved
(fp)0,
//;0xffffff8C Reserved
(fp)0,
//;0xffffff90 Reserved
(fp)0,
//;0xffffff94 Reserved
(fp)0,
//;0xffffff98 Reserved
(fp)0,
//;0xffffff9C Reserved
(fp)0,
//;0xffffffA0 Reserved
(fp)0xFFFFFFFF,
//;0xffffffA4 Reserved
(fp)0xFFFFFFFF,
//;0xffffffA8 Reserved
(fp)0xFFFFFFFF,
//;0xffffffAC Reserved
(fp)0xFFFFFFFF,
//;0xffffffB0 Reserved
(fp)0,
//;0xffffffB4 Reserved
(fp)0,
//;0xffffffB8 Reserved
(fp)0,
//;0xffffffBC Reserved
(fp)0,
//;0xffffffC0 Reserved
(fp)0,
//;0xffffffC4 Reserved
(fp)0,
//;0xffffffC8 Reserved
(fp)0,
//;0xffffffCC Reserved
(fp)0,
//;0xffffffd0 Exception(Supervisor Instruction)
INT_Excep_SuperVisorInst,
//;0xffffffd4 Exception(Access Instruction)
INT_Excep_AccessInst,
//;0xffffffd8 Reserved
Dummy,
//;0xffffffdc Exception(Undefined Instruction)
INT_Excep_UndefinedInst,
//;0xffffffe0 Reserved
Dummy,
//;0xffffffe4 Exception(Floating Point)
INT_Excep_FloatingPoint,
//;0xffffffe8 Reserved
Dummy,
//;0xffffffec Reserved
Dummy,
//;0xfffffff0 Reserved
Dummy,
//;0xfffffff4 Reserved
Dummy,
//;0xfffffff8 NMI
INT_NonMaskableInterrupt,
//;0xfffffffc RESET
//;<<VECTOR DATA START (POWER ON RESET)>>
//;Power On Reset PC
/*(void*)*/ PowerON_Reset
//;<<VECTOR DATA END (POWER ON RESET)>>
};
#define RVECT_SECT __attribute__ ((section (".rvectors")))
const fp RelocatableVectors[] RVECT_SECT = {
//;0x0000 Reserved
//;0x0004 Reserved
//;0x0008 Reserved
//;0x000C Reserved
//;0x0010 Reserved
//;0x0014 Reserved
//;0x0018 Reserved
//;0x001C Reserved
//;0x0020 Reserved
//;0x0024 Reserved
//;0x0028 Reserved
//;0x002C Reserved
//;0x0030 Reserved
//;0x0034 Reserved
//;0x0038 Reserved
//;0x003C Reserved
//;0x0040 BUSERR
(fp)INT_Excep_BSC_BUSERR,
//;0x0044 Reserved
//;0x0048 RAMERR
(fp)INT_Excep_RAM_RAMERR,
//;0x004C Reserved
//;0x0050 Reserved
//;0x0054 FIFERR
(fp)INT_Excep_FCU_FIFERR,
//;0x0058 Reserved
//;0x005C FRDYI
(fp)INT_Excep_FCU_FRDYI,
//;0x0060 Reserved
//;0x0064 Reserved
//;0x0068 SWINT2
(fp)INT_Excep_ICU_SWINT2,
//;0x006C SWINT
(fp)INT_Excep_ICU_SWINT,
//;0x0070 CMI0
(fp)INT_Excep_CMT0_CMI0,
//;0x0074 CMI1
(fp)INT_Excep_CMT1_CMI1,
//;0x0078 CMWI0
(fp)INT_Excep_CMTW0_CMWI0,
//;0x007C CMWI1
(fp)INT_Excep_CMTW1_CMWI1,
//;0x0080 D0FIFO2
(fp)INT_Excep_USBHS_D0FIFO2,
//;0x0084 D1FIFO2
(fp)INT_Excep_USBHS_D1FIFO2,
//;0x0088 D0FIFO0
(fp)INT_Excep_USB0_D0FIFO0,
//;0x008C D1FIFO0
(fp)INT_Excep_USB0_D1FIFO0,
//;0x0090 Reserved
//;0x0094 Reserved
//;0x0098 SPRI0
(fp)INT_Excep_RSPI0_SPRI0,
//;0x009C SPTI0
(fp)INT_Excep_RSPI0_SPTI0,
//;0x00A0 Reserved
//;0x00A4 Reserved
//;0x00A8 SPRI
(fp)INT_Excep_QSPI_SPRI,
//;0x00AC SPTI
(fp)INT_Excep_QSPI_SPTI,
//;0x00B0 SBFAI
(fp)INT_Excep_SHDI_SBFAI,
//;0x00B4 MBFAI
(fp)INT_Excep_MMC_MBFAI,
//;0x00B8 SSITX0
(fp)INT_Excep_SSI0_SSITXI0,
//;0x00BC SSIRX0
(fp)INT_Excep_SSI0_SSIRXI0,
//;0x00C0 SSIRTI1
(fp)INT_Excep_SSI1_SSIRTI1,
//;0x00C4 Reserved
//;0x00C8 IDEI
(fp)INT_Excep_SRC_IDEI,
//;0x00CC ODFI
(fp)INT_Excep_SRC_ODFI,
//;0x00D0 RXI0
(fp)INT_Excep_RIIC0_RXI0,
//;0x00D4C TXI0
(fp)INT_Excep_RIIC0_TXI0,
//;0x00D8 RXI2
(fp)INT_Excep_RIIC2_RXI2,
//;0x00DC TXI2
(fp)INT_Excep_RIIC2_TXI2,
//;0x00E0 Reserved
//;0x00E4 Reserved
//;0x00E8 RXI0
(fp)INT_Excep_SCI0_RXI0,
//;0x00EC TXI0
(fp)INT_Excep_SCI0_TXI0,
//;0x00F0 RXI1
(fp)INT_Excep_SCI1_RXI1,
//;0x00F4 TXI1
(fp)INT_Excep_SCI1_TXI1,
//;0x00F8 RXI2
(fp)INT_Excep_SCI2_RXI2,
//;0x00FC TXI2
(fp)INT_Excep_SCI2_TXI2,
//;0x0100 IRQ0
(fp)INT_Excep_ICU_IRQ0,
//;0x0104 IRQ1
(fp)INT_Excep_ICU_IRQ1,
//;0x0108 IRQ2
(fp)INT_Excep_ICU_IRQ2,
//;0x010C IRQ3
(fp)INT_Excep_ICU_IRQ3,
//;0x0110 IRQ4
(fp)INT_Excep_ICU_IRQ4,
//;0x0114 IRQ5
(fp)INT_Excep_ICU_IRQ5,
//;0x0118 IRQ6
(fp)INT_Excep_ICU_IRQ6,
//;0x011C IRQ7
(fp)INT_Excep_ICU_IRQ7,
//;0x0120 IRQ8
(fp)INT_Excep_ICU_IRQ8,
//;0x0124 IRQ9
(fp)INT_Excep_ICU_IRQ9,
//;0x0128 IRQ10
(fp)INT_Excep_ICU_IRQ10,
//;0x012C IRQ11
(fp)INT_Excep_ICU_IRQ11,
//;0x0130 IRQ12
(fp)INT_Excep_ICU_IRQ12,
//;0x0134 IRQ13
(fp)INT_Excep_ICU_IRQ13,
//;0x0138 IRQ14
(fp)INT_Excep_ICU_IRQ14,
//;0x013C IRQ15
(fp)INT_Excep_ICU_IRQ15,
//;0x0140 RXI3
(fp)INT_Excep_SCI3_RXI3,
//;0x0144 TXI3
(fp)INT_Excep_SCI3_TXI3,
//;0x0148 RXI4
(fp)INT_Excep_SCI4_RXI4,
//;0x014C TXI4
(fp)INT_Excep_SCI4_TXI4,
//;0x0150 RXI5
(fp)INT_Excep_SCI5_RXI5,
//;0x0154 TXI5
(fp)INT_Excep_SCI5_TXI5,
//;0x0158 RXI6
(fp)INT_Excep_SCI6_RXI6,
//;0x015C TXI6
(fp)INT_Excep_SCI6_TXI6,
//;0x0160 COMPA1
(fp)INT_Excep_LVD1_COMPA1,
//;0x0164 COMPA2
(fp)INT_Excep_LVD2_COMPA2,
//;0x0168 USBR0
(fp)INT_Excep_USB_USBR0,
//;0x016C Reserved
//;0x0170 ALM
(fp)INT_Excep_RTC_ALM,
//;0x0174 PRD
(fp)INT_Excep_RTC_PRD,
//;0x0178 HSUSBR
(fp)INT_Excep_USBHS_USBHSR,
//;0x017C IWUNI
(fp)INT_Excep_IWDT_IWUNI,
//;0x0180 WUNI
(fp)INT_Excep_WDT_WUNI,
//;0x0184 PCDFI
(fp)INT_Excep_PDC_PCDFI,
//;0x0188 RXI7
(fp)INT_Excep_SCI7_RXI7,
//;0x018C TXI7
(fp)INT_Excep_SCI7_TXI7,
//;0x0190 RXIF8
(fp)INT_Excep_SCIF8_RXIF8,
//;0x0194 TXIF8
(fp)INT_Excep_SCIF8_TXIF8,
//;0x0198 RXIF9
(fp)INT_Excep_SCIF9_RXIF9,
//;0x019C TXIF9
(fp)INT_Excep_SCIF9_TXIF9,
//;0x01A0 RXIF10
(fp)INT_Excep_SCIF10_RXIF10,
//;0x01A4 TXIF10
(fp)INT_Excep_SCIF10_TXIF10,
//;0x01A8 GROUPBE0
(fp)INT_Excep_ICU_GROUPBE0,
//;0x01AC Reserved
//;0x01B0 Reserved
//;0x01B4 Reserved
//;0x01B8 GROUPBL0
(fp)INT_Excep_ICU_GROUPBL0,
//;0x01BC GROUPBL1
(fp)INT_Excep_ICU_GROUPBL1,
//;0x01C0 GROUPAL0
(fp)INT_Excep_ICU_GROUPAL0,
//;0x01C4 GROUPAL1
(fp)INT_Excep_ICU_GROUPAL1,
//;0x01C8 RXIF11
(fp)INT_Excep_SCIF11_RXIF11,
//;0x01CC TXIF11
(fp)INT_Excep_SCIF11_TXIF11,
//;0x01D0 RXIF12
(fp)INT_Excep_SCIF12_RXIF12,
//;0x01D4 TXIF12
(fp)INT_Excep_SCIF12_TXIF12,
//;0x01D8 Reserved
//;0x01DC Reserved
//;0x01E0 DMAC0I
(fp)INT_Excep_DMAC_DMAC0I,
//;0x01E4 DMAC1I
(fp)INT_Excep_DMAC_DMAC1I,
//;0x01E8 DMAC2I
(fp)INT_Excep_DMAC_DMAC2I,
//;0x01EC DMAC3I
(fp)INT_Excep_DMAC_DMAC3I,
//;0x01F0 DMAC74I
(fp)INT_Excep_DMAC_DMAC74I,
//;0x01F4 OST
(fp)INT_Excep_ICU_OST,
//;0x01F8 EXDMAC0I
(fp)INT_Excep_EXDMAC_EXDMAC0I,
//;0x01FC EXDMAC1I
(fp)INT_Excep_EXDMAC_EXDMAC1I,
//;0x0200 INTB128
(fp)INT_Excep_PERIB_INTB128,
//;0x0204 INTB129
(fp)INT_Excep_PERIB_INTB129,
//;0x0208 INTB130
(fp)INT_Excep_PERIB_INTB130,
//;0x020C INTB131
(fp)INT_Excep_PERIB_INTB131,
//;0x0210 INTB132
(fp)INT_Excep_PERIB_INTB132,
//;0x0214 INTB133
(fp)INT_Excep_PERIB_INTB133,
//;0x0218 INTB134
(fp)INT_Excep_PERIB_INTB134,
//;0x021C INTB135
(fp)INT_Excep_PERIB_INTB135,
//;0x0220 INTB136
(fp)INT_Excep_PERIB_INTB136,
//;0x0224 INTB137
(fp)INT_Excep_PERIB_INTB137,
//;0x0228 INTB138
(fp)INT_Excep_PERIB_INTB138,
//;0x022C INTB139
(fp)INT_Excep_PERIB_INTB139,
//;0x0230 INTB140
(fp)INT_Excep_PERIB_INTB140,
//;0x0234 INTB141
(fp)INT_Excep_PERIB_INTB141,
//;0x0238 INTB142
(fp)INT_Excep_PERIB_INTB142,
//;0x023C INTB143
(fp)INT_Excep_PERIB_INTB143,
//;0x0240 INTB144
(fp)INT_Excep_PERIB_INTB144,
//;0x0244 INTB145
(fp)INT_Excep_PERIB_INTB145,
//;0x0248 INTB146
(fp)INT_Excep_PERIB_INTB146,
//;0x024C INTB147
(fp)INT_Excep_PERIB_INTB147,
//;0x0250 INTB148
(fp)INT_Excep_PERIB_INTB148,
//;0x02540 INTB149
(fp)INT_Excep_PERIB_INTB149,
//;0x0258 INTB150
(fp)INT_Excep_PERIB_INTB150,
//;0x025C INTB151
(fp)INT_Excep_PERIB_INTB151,
//;0x0260 INTB152
(fp)INT_Excep_PERIB_INTB152,
//;0x0264 INTB153
(fp)INT_Excep_PERIB_INTB153,
//;0x0268 INTB154
(fp)INT_Excep_PERIB_INTB154,
//;0x026C INTB155
(fp)INT_Excep_PERIB_INTB155,
//;0x0270 INTB156
(fp)INT_Excep_PERIB_INTB156,
//;0x0274 INTB157
(fp)INT_Excep_PERIB_INTB157,
//;0x0278 INTB158
(fp)INT_Excep_PERIB_INTB158,
//;0x027C INTB159
(fp)INT_Excep_PERIB_INTB159,
//;0x0280 INTB160
(fp)INT_Excep_PERIB_INTB160,
//;0x0284 INTB161
(fp)INT_Excep_PERIB_INTB161,
//;0x0288 INTB162
(fp)INT_Excep_PERIB_INTB162,
//;0x028C INTB163
(fp)INT_Excep_PERIB_INTB163,
//;0x0290 INTB164
(fp)INT_Excep_PERIB_INTB164,
//;0x0294 PERIB INTB165
(fp)INT_Excep_PERIB_INTB165,
//;0x0298 PERIB INTB166
(fp)INT_Excep_PERIB_INTB166,
//;0x029C PERIB INTB167
(fp)INT_Excep_PERIB_INTB167,
//;0x02A0 PERIB INTB168
(fp)INT_Excep_PERIB_INTB168,
//;0x02A4 PERIB INTB169
(fp)INT_Excep_PERIB_INTB169,
//;0x02A8 PERIB INTB170
(fp)INT_Excep_PERIB_INTB170,
//;0x02AC PERIB INTB171
(fp)INT_Excep_PERIB_INTB171,
//;0x02B0 PERIB INTB172
(fp)INT_Excep_PERIB_INTB172,
//;0x02B4 PERIB INTB173
(fp)INT_Excep_PERIB_INTB173,
//;0x02B8 PERIB INTB174
(fp)INT_Excep_PERIB_INTB174,
//;0x02BC PERIB INTB175
(fp)INT_Excep_PERIB_INTB175,
//;0x02C0 PERIB INTB176
(fp)INT_Excep_PERIB_INTB176,
//;0x02C4 PERIB INTB177
(fp)INT_Excep_PERIB_INTB177,
//;0x02C8 PERIB INTB178
(fp)INT_Excep_PERIB_INTB178,
//;0x02CC PERIB INTB179
(fp)INT_Excep_PERIB_INTB179,
//;0x02D0 PERIB INTB180
(fp)INT_Excep_PERIB_INTB180,
//;0x02D4 PERIB INTB181
(fp)INT_Excep_PERIB_INTB181,
//;0x02D8 PERIB INTB182
(fp)INT_Excep_PERIB_INTB182,
//;0x02DC PERIB INTB183
(fp)INT_Excep_PERIB_INTB183,
//;0x02E0 PERIB INTB184
(fp)INT_Excep_PERIB_INTB184,
//;0x02E4 PERIB INTB185
(fp)INT_Excep_PERIB_INTB185,
//;0x02E8 PERIB INTB186
(fp)INT_Excep_PERIB_INTB186,
//;0x02EC PERIB INTB187
(fp)INT_Excep_PERIB_INTB187,
//;0x02F0 PERIB INTB188
(fp)INT_Excep_PERIB_INTB188,
//;0x02F4 PERIB INTB189
(fp)INT_Excep_PERIB_INTB189,
//;0x02F8 PERIB INTB190
(fp)INT_Excep_PERIB_INTB190,
//;0x02FC PERIB INTB191
(fp)INT_Excep_PERIB_INTB191,
//;0x0300 PERIB INTB192
(fp)INT_Excep_PERIB_INTB192,
//;0x0304 PERIB INTB193
(fp)INT_Excep_PERIB_INTB193,
//;0x0308 PERIB INTB194
(fp)INT_Excep_PERIB_INTB194,
//;0x030C PERIB INTB195
(fp)INT_Excep_PERIB_INTB195,
//;0x0310 PERIB INTB196
(fp)INT_Excep_PERIB_INTB196,
//;0x0314 PERIB INTB197
(fp)INT_Excep_PERIB_INTB197,
//;0x0318 PERIB INTB198
(fp)INT_Excep_PERIB_INTB198,
//;0x031C PERIB INTB199
(fp)INT_Excep_PERIB_INTB199,
//;0x0320 PERIB INTB200
(fp)INT_Excep_PERIB_INTB200,
//;0x0324 PERIB INTB201
(fp)INT_Excep_PERIB_INTB201,
//;0x0328 PERIB INTB202
(fp)INT_Excep_PERIB_INTB202,
//;0x032C PERIB INTB203
(fp)INT_Excep_PERIB_INTB203,
//;0x0320 PERIB INTB204
(fp)INT_Excep_PERIB_INTB204,
//;0x0334 PERIB INTB205
(fp)INT_Excep_PERIB_INTB205,
//;0x0338 PERIB INTB206
(fp)INT_Excep_PERIB_INTB206,
//;0x033C PERIB INTB207
(fp)INT_Excep_PERIB_INTB207,
//;0x0340 PERIA INTA208
(fp)INT_Excep_PERIA_INTA208,
//;0x0344 PERIA INTA209
(fp)INT_Excep_PERIA_INTA209,
//;0x0348 PERIA INTA210
(fp)INT_Excep_PERIA_INTA210,
//;0x034C PERIA INTA211
(fp)INT_Excep_PERIA_INTA211,
//;0x0350 PERIA INTA212
(fp)INT_Excep_PERIA_INTA212,
//;0x0354 PERIA INTA213
(fp)INT_Excep_PERIA_INTA213,
//;0x0358 PERIA INTA214
(fp)INT_Excep_PERIA_INTA214,
//;0x035C PERIA INTA215
(fp)INT_Excep_PERIA_INTA215,
//;0x0360 PERIA INTA216
(fp)INT_Excep_PERIA_INTA216,
//;0x0364 PERIA INTA217
(fp)INT_Excep_PERIA_INTA217,
//;0x0368 PERIA INTA218
(fp)INT_Excep_PERIA_INTA218,
//;0x036C PERIA INTA219
(fp)INT_Excep_PERIA_INTA219,
//;0x0370 PERIA INTA220
(fp)INT_Excep_PERIA_INTA220,
//;0x0374 PERIA INTA221
(fp)INT_Excep_PERIA_INTA221,
//;0x0378 PERIA INTA222
(fp)INT_Excep_PERIA_INTA222,
//;0x037C PERIA INTA223
(fp)INT_Excep_PERIA_INTA223,
//;0x0380 PERIA INTA224
(fp)INT_Excep_PERIA_INTA224,
//;0x0384 PERIA INTA225
(fp)INT_Excep_PERIA_INTA225,
//;0x0388 PERIA INTA226
(fp)INT_Excep_PERIA_INTA226,
//;0x038C PERIA INTA227
(fp)INT_Excep_PERIA_INTA227,
//;0x0390 PERIA INTA228
(fp)INT_Excep_PERIA_INTA228,
//;0x0394 PERIA INTA229
(fp)INT_Excep_PERIA_INTA229,
//;0x0398 PERIA INTA230
(fp)INT_Excep_PERIA_INTA230,
//;0x039C PERIA INTA231
(fp)INT_Excep_PERIA_INTA231,
//;0x03A0 PERIA INTA232
(fp)INT_Excep_PERIA_INTA232,
//;0x03A4 PERIA INTA233
(fp)INT_Excep_PERIA_INTA233,
//;0x03A8 PERIA INTA234
(fp)INT_Excep_PERIA_INTA234,
//;0x03AC PERIA INTA235
(fp)INT_Excep_PERIA_INTA235,
//;0x03B0 PERIA INTA236
(fp)INT_Excep_PERIA_INTA236,
//;0x04B4 PERIA INTA237
(fp)INT_Excep_PERIA_INTA237,
//;0x03B8 PERIA INTA238
(fp)INT_Excep_PERIA_INTA238,
//;0x03BC PERIA INTA239
(fp)INT_Excep_PERIA_INTA239,
//;0x03C0 PERIA INTA240
(fp)INT_Excep_PERIA_INTA240,
//;0x03C4 PERIA INTA241
(fp)INT_Excep_PERIA_INTA241,
//;0x03C8 PERIA INTA242
(fp)INT_Excep_PERIA_INTA242,
//;0x03CC PERIA INTA243
(fp)INT_Excep_PERIA_INTA243,
//;0x03D0 PERIA INTA244
(fp)INT_Excep_PERIA_INTA244,
//;0x03D4 PERIA INTA245
(fp)INT_Excep_PERIA_INTA245,
//;0x03D8 PERIA INTA246
(fp)INT_Excep_PERIA_INTA246,
//;0x03DC PERIA INTA247
(fp)INT_Excep_PERIA_INTA247,
//;0x03E0 PERIA INTA248
(fp)INT_Excep_PERIA_INTA248,
//;0x03E4 PERIA INTA249
(fp)INT_Excep_PERIA_INTA249,
//;0x03E8 PERIA INTA250
(fp)INT_Excep_PERIA_INTA250,
//;0x03EC PERIA INTA251
(fp)INT_Excep_PERIA_INTA251,
//;0x03F0 PERIA INTA252
(fp)INT_Excep_PERIA_INTA252,
//;0x03F4 PERIA INTA253
(fp)INT_Excep_PERIA_INTA253,
//;0x03F8 PERIA INTA254
(fp)INT_Excep_PERIA_INTA254,
//;0x03FC PERIA INTA255
(fp)INT_Excep_PERIA_INTA255,
};

@ -0,0 +1,280 @@
/*
FreeRTOS V8.0.0 - Copyright (C) 2014 Real Time Engineers Ltd.
All rights reserved
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
***************************************************************************
* *
* FreeRTOS provides completely free yet professionally developed, *
* robust, strictly quality controlled, supported, and cross *
* platform software that has become a de facto standard. *
* *
* Help yourself get started quickly and support the FreeRTOS *
* project by purchasing a FreeRTOS tutorial book, reference *
* manual, or both from: http://www.FreeRTOS.org/Documentation *
* *
* Thank you! *
* *
***************************************************************************
This file is part of the FreeRTOS distribution.
FreeRTOS is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License (version 2) as published by the
Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
>>! NOTE: The modification to the GPL is included to allow you to distribute
>>! a combined work that includes FreeRTOS without being obliged to provide
>>! the source code for proprietary components outside of the FreeRTOS
>>! kernel.
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. Full license text is available from the following
link: http://www.freertos.org/a00114.html
1 tab == 4 spaces!
***************************************************************************
* *
* Having a problem? Start by reading the FAQ "My application does *
* not run, what could be wrong?" *
* *
* http://www.FreeRTOS.org/FAQHelp.html *
* *
***************************************************************************
http://www.FreeRTOS.org - Documentation, books, training, latest versions,
license and Real Time Engineers Ltd. contact details.
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
compatible FAT file system, and our tiny thread aware UDP/IP stack.
http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High
Integrity Systems to sell under the OpenRTOS brand. Low cost OpenRTOS
licenses offer ticketed support, indemnification and middleware.
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
engineered and independently SIL3 certified version for use in safety and
mission critical applications that require provable dependability.
1 tab == 4 spaces!
*/
/******************************************************************************
* This project provides two demo applications. A simple blinky style project,
* and a more comprehensive test and demo application. The
* mainCREATE_SIMPLE_BLINKY_DEMO_ONLY setting (defined in this file) is used to
* select between the two. The simply blinky demo is implemented and described
* in main_blinky.c. The more comprehensive test and demo application is
* implemented and described in main_full.c.
*
* This file implements the code that is not demo specific, including the
* hardware setup and FreeRTOS hook functions.
*
* ENSURE TO READ THE DOCUMENTATION PAGE FOR THIS PORT AND DEMO APPLICATION ON
* THE http://www.FreeRTOS.org WEB SITE FOR FULL INFORMATION ON USING THIS DEMO
* APPLICATION, AND ITS ASSOCIATE FreeRTOS ARCHITECTURE PORT!
*
*/
/* Scheduler include files. */
#include "FreeRTOS.h"
#include "task.h"
#include "semphr.h"
/* Standard demo includes. */
#include "partest.h"
#include "TimerDemo.h"
#include "QueueOverwrite.h"
#include "EventGroupsDemo.h"
/* Renesas includes. */
#include "iodefine.h"
/* Set option bytes */
#pragma address OFS0_location = 0xFFFFFF8CUL
#pragma address OFS1_location = 0xFFFFFF88UL
volatile const uint32_t OFS0_location = 0xFFFFFFFFUL;
volatile const uint32_t OFS1_location = 0xFFFFFFFFUL;
/* Set mainCREATE_SIMPLE_BLINKY_DEMO_ONLY to one to run the simple blinky demo,
or 0 to run the more comprehensive test and demo application. */
#define mainCREATE_SIMPLE_BLINKY_DEMO_ONLY 1
/*-----------------------------------------------------------*/
/*
* Configure the hardware as necessary to run this demo.
*/
static void prvSetupHardware( void );
/*
* main_blinky() is used when mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 1.
* main_full() is used when mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 0.
*/
#if mainCREATE_SIMPLE_BLINKY_DEMO_ONLY == 1
extern void main_blinky( void );
#else
extern void main_full( void );
#endif /* #if mainCREATE_SIMPLE_BLINKY_DEMO_ONLY == 1 */
/*
* The Xilinx projects use a BSP that do not allow the start up code to be
* altered easily. Therefore the vector table used by FreeRTOS is defined in
* FreeRTOS_asm_vectors.S, which is part of this project. Switch to use the
* FreeRTOS vector table.
*/
extern void vPortInstallFreeRTOSVectorTable( void );
/* Prototypes for the standard FreeRTOS callback/hook functions implemented
within this file. */
void vApplicationMallocFailedHook( void );
void vApplicationIdleHook( void );
void vApplicationStackOverflowHook( TaskHandle_t pxTask, char *pcTaskName );
void vApplicationTickHook( void );
/*-----------------------------------------------------------*/
int main( void )
{
/* Configure the hardware ready to run the demo. */
prvSetupHardware();
/* The mainCREATE_SIMPLE_BLINKY_DEMO_ONLY setting is described at the top
of this file. */
#if( mainCREATE_SIMPLE_BLINKY_DEMO_ONLY == 1 )
{
main_blinky();
}
#else
{
main_full();
}
#endif
/* Don't expect to reach here. */
return 0;
}
/*-----------------------------------------------------------*/
static void prvSetupHardware( void )
{
}
/*-----------------------------------------------------------*/
void vApplicationMallocFailedHook( void )
{
/* Called if a call to pvPortMalloc() fails because there is insufficient
free memory available in the FreeRTOS heap. pvPortMalloc() is called
internally by FreeRTOS API functions that create tasks, queues, software
timers, and semaphores. The size of the FreeRTOS heap is set by the
configTOTAL_HEAP_SIZE configuration constant in FreeRTOSConfig.h. */
taskDISABLE_INTERRUPTS();
for( ;; );
}
/*-----------------------------------------------------------*/
void vApplicationStackOverflowHook( TaskHandle_t pxTask, char *pcTaskName )
{
( void ) pcTaskName;
( void ) pxTask;
/* Run time stack overflow checking is performed if
configCHECK_FOR_STACK_OVERFLOW is defined to 1 or 2. This hook
function is called if a stack overflow is detected. */
taskDISABLE_INTERRUPTS();
for( ;; );
}
/*-----------------------------------------------------------*/
void vApplicationIdleHook( void )
{
volatile size_t xFreeHeapSpace;
/* This is just a trivial example of an idle hook. It is called on each
cycle of the idle task. It must *NOT* attempt to block. In this case the
idle task just queries the amount of FreeRTOS heap that remains. See the
memory management section on the http://www.FreeRTOS.org web site for memory
management options. If there is a lot of heap memory free then the
configTOTAL_HEAP_SIZE value in FreeRTOSConfig.h can be reduced to free up
RAM. */
xFreeHeapSpace = xPortGetFreeHeapSize();
/* Remove compiler warning about xFreeHeapSpace being set but never used. */
( void ) xFreeHeapSpace;
}
/*-----------------------------------------------------------*/
void vApplicationTickHook( void )
{
#if( mainCREATE_SIMPLE_BLINKY_DEMO_ONLY == 0 )
{
/* The full demo includes a software timer demo/test that requires
prodding periodically from the tick interrupt. */
vTimerPeriodicISRTests();
/* Call the periodic queue overwrite from ISR demo. */
vQueueOverwritePeriodicISRDemo();
/* Call the periodic event group from ISR demo. */
vPeriodicEventGroupsProcessing();
}
#endif
}
/*-----------------------------------------------------------*/
void vAssertCalled( void )
{
volatile unsigned long ul = 0;
taskENTER_CRITICAL();
{
/* Use the debugger to set ul to a non-zero value in order to step out
of this function to determine why it was called. */
while( ul == 0 )
{
portNOP();
}
}
taskEXIT_CRITICAL();
}
/*-----------------------------------------------------------*/
/* The RX port uses this callback function to configure its tick interrupt.
This allows the application to choose the tick interrupt source. */
void vApplicationSetupTimerInterrupt( void )
{
const uint32_t ulEnableRegisterWrite = 0xA50BUL, ulDisableRegisterWrite = 0xA500UL;
/* Disable register write protection. */
SYSTEM.PRCR.WORD = ulEnableRegisterWrite;
/* Enable compare match timer 0. */
MSTP( CMT0 ) = 0;
/* Interrupt on compare match. */
CMT0.CMCR.BIT.CMIE = 1;
/* Set the compare match value. */
CMT0.CMCOR = ( unsigned short ) ( ( ( configPERIPHERAL_CLOCK_HZ / configTICK_RATE_HZ ) -1 ) / 8 );
/* Divide the PCLK by 8. */
CMT0.CMCR.BIT.CKS = 0;
/* Enable the interrupt... */
_IEN( _CMT0_CMI0 ) = 1;
/* ...and set its priority to the application defined kernel priority. */
_IPR( _CMT0_CMI0 ) = configKERNEL_INTERRUPT_PRIORITY;
/* Start the timer. */
CMT.CMSTR0.BIT.STR0 = 1;
/* Reneable register protection. */
SYSTEM.PRCR.WORD = ulDisableRegisterWrite;
}
/*-----------------------------------------------------------*/

@ -0,0 +1,235 @@
/*
FreeRTOS V8.0.0 - Copyright (C) 2014 Real Time Engineers Ltd.
All rights reserved
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
***************************************************************************
* *
* FreeRTOS provides completely free yet professionally developed, *
* robust, strictly quality controlled, supported, and cross *
* platform software that has become a de facto standard. *
* *
* Help yourself get started quickly and support the FreeRTOS *
* project by purchasing a FreeRTOS tutorial book, reference *
* manual, or both from: http://www.FreeRTOS.org/Documentation *
* *
* Thank you! *
* *
***************************************************************************
This file is part of the FreeRTOS distribution.
FreeRTOS is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License (version 2) as published by the
Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
>>! NOTE: The modification to the GPL is included to allow you to distribute
>>! a combined work that includes FreeRTOS without being obliged to provide
>>! the source code for proprietary components outside of the FreeRTOS
>>! kernel.
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. Full license text is available from the following
link: http://www.freertos.org/a00114.html
1 tab == 4 spaces!
***************************************************************************
* *
* Having a problem? Start by reading the FAQ "My application does *
* not run, what could be wrong?" *
* *
* http://www.FreeRTOS.org/FAQHelp.html *
* *
***************************************************************************
http://www.FreeRTOS.org - Documentation, books, training, latest versions,
license and Real Time Engineers Ltd. contact details.
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
compatible FAT file system, and our tiny thread aware UDP/IP stack.
http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High
Integrity Systems to sell under the OpenRTOS brand. Low cost OpenRTOS
licenses offer ticketed support, indemnification and middleware.
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
engineered and independently SIL3 certified version for use in safety and
mission critical applications that require provable dependability.
1 tab == 4 spaces!
*/
/******************************************************************************
* NOTE 1: This project provides two demo applications. A simple blinky style
* project, and a more comprehensive test and demo application. The
* mainCREATE_SIMPLE_BLINKY_DEMO_ONLY setting in main.c is used to select
* between the two. See the notes on using mainCREATE_SIMPLE_BLINKY_DEMO_ONLY
* in main.c. This file implements the simply blinky style version.
*
* NOTE 2: This file only contains the source code that is specific to the
* basic demo. Generic functions, such FreeRTOS hook functions, and functions
* required to configure the hardware are defined in main.c.
******************************************************************************
*
* main_blinky() creates one queue, and two tasks. It then starts the
* scheduler.
*
* The Queue Send Task:
* The queue send task is implemented by the prvQueueSendTask() function in
* this file. prvQueueSendTask() sits in a loop that causes it to repeatedly
* block for 200 milliseconds, before sending the value 100 to the queue that
* was created within main_blinky(). Once the value is sent, the task loops
* back around to block for another 200 milliseconds...and so on.
*
* The Queue Receive Task:
* The queue receive task is implemented by the prvQueueReceiveTask() function
* in this file. prvQueueReceiveTask() sits in a loop where it repeatedly
* blocks on attempts to read data from the queue that was created within
* main_blinky(). When data is received, the task checks the value of the
* data, and if the value equals the expected 100, toggles an LED. The 'block
* time' parameter passed to the queue receive function specifies that the
* task should be held in the Blocked state indefinitely to wait for data to
* be available on the queue. The queue receive task will only leave the
* Blocked state when the queue send task writes to the queue. As the queue
* send task writes to the queue every 200 milliseconds, the queue receive
* task leaves the Blocked state every 200 milliseconds, and therefore toggles
* the LED every 200 milliseconds.
*/
/* Kernel includes. */
#include "FreeRTOS.h"
#include "task.h"
#include "semphr.h"
/* Standard demo includes. */
#include "partest.h"
/* Priorities at which the tasks are created. */
#define mainQUEUE_RECEIVE_TASK_PRIORITY ( tskIDLE_PRIORITY + 2 )
#define mainQUEUE_SEND_TASK_PRIORITY ( tskIDLE_PRIORITY + 1 )
/* The rate at which data is sent to the queue. The 200ms value is converted
to ticks using the portTICK_PERIOD_MS constant. */
#define mainQUEUE_SEND_FREQUENCY_MS ( 200 / portTICK_PERIOD_MS )
/* The number of items the queue can hold. This is 1 as the receive task
will remove items as they are added, meaning the send task should always find
the queue empty. */
#define mainQUEUE_LENGTH ( 1 )
/* The LED toggled by the Rx task. */
#define mainTASK_LED ( 0 )
/*-----------------------------------------------------------*/
/*
* The tasks as described in the comments at the top of this file.
*/
static void prvQueueReceiveTask( void *pvParameters );
static void prvQueueSendTask( void *pvParameters );
/*
* Called by main() to create the simply blinky style application if
* mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 1.
*/
void main_blinky( void );
/*-----------------------------------------------------------*/
/* The queue used by both tasks. */
static QueueHandle_t xQueue = NULL;
/*-----------------------------------------------------------*/
void main_blinky( void )
{
/* Create the queue. */
xQueue = xQueueCreate( mainQUEUE_LENGTH, sizeof( uint32_t ) );
if( xQueue != NULL )
{
/* Start the two tasks as described in the comments at the top of this
file. */
xTaskCreate( prvQueueReceiveTask, /* The function that implements the task. */
"Rx", /* The text name assigned to the task - for debug only as it is not used by the kernel. */
configMINIMAL_STACK_SIZE, /* The size of the stack to allocate to the task. */
NULL, /* The parameter passed to the task - not used in this case. */
mainQUEUE_RECEIVE_TASK_PRIORITY, /* The priority assigned to the task. */
NULL ); /* The task handle is not required, so NULL is passed. */
xTaskCreate( prvQueueSendTask, "TX", configMINIMAL_STACK_SIZE, NULL, mainQUEUE_SEND_TASK_PRIORITY, NULL );
/* Start the tasks and timer running. */
vTaskStartScheduler();
}
/* If all is well, the scheduler will now be running, and the following
line will never be reached. If the following line does execute, then
there was either insufficient FreeRTOS heap memory available for the idle
and/or timer tasks to be created, or vTaskStartScheduler() was called from
User mode. See the memory management section on the FreeRTOS web site for
more details on the FreeRTOS heap http://www.freertos.org/a00111.html. The
mode from which main() is called is set in the C start up code and must be
a privileged mode (not user mode). */
for( ;; );
}
/*-----------------------------------------------------------*/
static void prvQueueSendTask( void *pvParameters )
{
TickType_t xNextWakeTime;
const uint32_t ulValueToSend = 100UL;
/* Remove compiler warning about unused parameter. */
( void ) pvParameters;
/* Initialise xNextWakeTime - this only needs to be done once. */
xNextWakeTime = xTaskGetTickCount();
for( ;; )
{
/* Place this task in the blocked state until it is time to run again. */
vTaskDelayUntil( &xNextWakeTime, mainQUEUE_SEND_FREQUENCY_MS );
/* Send to the queue - causing the queue receive task to unblock and
toggle the LED. 0 is used as the block time so the sending operation
will not block - it shouldn't need to block as the queue should always
be empty at this point in the code. */
xQueueSend( xQueue, &ulValueToSend, 0U );
}
}
/*-----------------------------------------------------------*/
volatile uint32_t ulRxEvents = 0;
static void prvQueueReceiveTask( void *pvParameters )
{
uint32_t ulReceivedValue;
const uint32_t ulExpectedValue = 100UL;
/* Remove compiler warning about unused parameter. */
( void ) pvParameters;
for( ;; )
{
/* Wait until something arrives in the queue - this task will block
indefinitely provided INCLUDE_vTaskSuspend is set to 1 in
FreeRTOSConfig.h. */
xQueueReceive( xQueue, &ulReceivedValue, portMAX_DELAY );
/* To get here something must have been received from the queue, but
is it the expected value? If it is, toggle the LED. */
if( ulReceivedValue == ulExpectedValue )
{
vParTestToggleLED( mainTASK_LED );
ulReceivedValue = 0U;
ulRxEvents++;
}
}
}
/*-----------------------------------------------------------*/
Loading…
Cancel
Save