Version du moniteur proche de la version finale, petits bugs corrigés dans le testeur du superviseur
|  | @ -1,11 +0,0 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <module type="PYTHON_MODULE" version="4"> | ||||
|   <component name="NewModuleRootManager"> | ||||
|     <content url="file://$MODULE_DIR$" /> | ||||
|     <orderEntry type="inheritedJdk" /> | ||||
|     <orderEntry type="sourceFolder" forTests="false" /> | ||||
|   </component> | ||||
|   <component name="TestRunnerService"> | ||||
|     <option name="PROJECT_TEST_RUNNER" value="Unittests" /> | ||||
|   </component> | ||||
| </module> | ||||
|  | @ -1,7 +0,0 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="JavaScriptSettings"> | ||||
|     <option name="languageLevel" value="ES6" /> | ||||
|   </component> | ||||
|   <component name="ProjectRootManager" version="2" project-jdk-name="Python 3.5" project-jdk-type="Python SDK" /> | ||||
| </project> | ||||
|  | @ -1,8 +0,0 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="ProjectModuleManager"> | ||||
|     <modules> | ||||
|       <module fileurl="file://$PROJECT_DIR$/.idea/Aruco_opencv.iml" filepath="$PROJECT_DIR$/.idea/Aruco_opencv.iml" /> | ||||
|     </modules> | ||||
|   </component> | ||||
| </project> | ||||
|  | @ -1,546 +0,0 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="ChangeListManager"> | ||||
|     <list default="true" id="47ca631b-dc62-4446-a33d-e49bb58e0642" name="Default" comment="" /> | ||||
|     <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" /> | ||||
|     <option name="TRACKING_ENABLED" value="true" /> | ||||
|     <option name="SHOW_DIALOG" value="false" /> | ||||
|     <option name="HIGHLIGHT_CONFLICTS" value="true" /> | ||||
|     <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" /> | ||||
|     <option name="LAST_RESOLUTION" value="IGNORE" /> | ||||
|   </component> | ||||
|   <component name="CoverageDataManager"> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$opengl_opencv.coverage" NAME="opengl_opencv Coverage Results" MODIFIED="1524744453708" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$camera_calibration.coverage" NAME="camera_calibration Coverage Results" MODIFIED="1524665271117" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$calibrate.coverage" NAME="calibrate Coverage Results" MODIFIED="1530281069792" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$opencv_opengl.coverage" NAME="opencv_opengl Coverage Results" MODIFIED="1524734429270" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$aruco_create.coverage" NAME="aruco_create Coverage Results" MODIFIED="1524673519668" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$aruco_detection.coverage" NAME="aruco_detection Coverage Results" MODIFIED="1530282416329" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|     <SUITE FILE_PATH="coverage/Aruco_opencv$getCalibrationImage.coverage" NAME="getCalibrationImage Coverage Results" MODIFIED="1530282201001" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" /> | ||||
|   </component> | ||||
|   <component name="FileEditorManager"> | ||||
|     <leaf SIDE_TABS_SIZE_LIMIT_KEY="300"> | ||||
|       <file leaf-file-name="aruco_detection.py" pinned="false" current-in-tab="true"> | ||||
|         <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state relative-caret-position="315"> | ||||
|               <caret line="21" column="17" lean-forward="true" selection-start-line="21" selection-start-column="17" selection-end-line="21" selection-end-column="17" /> | ||||
|               <folding> | ||||
|                 <element signature="e#0#16#0" expanded="true" /> | ||||
|               </folding> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="aruco_create.py" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/aruco_create.py"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state relative-caret-position="120"> | ||||
|               <caret line="8" column="9" selection-start-line="8" selection-start-column="9" selection-end-line="15" /> | ||||
|               <folding> | ||||
|                 <element signature="e#0#16#0" expanded="true" /> | ||||
|               </folding> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="aruco_11.jpg" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/img_aruco/aruco_11.jpg"> | ||||
|           <provider selected="true" editor-type-id="images" /> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="aruco_10.jpg" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/img_aruco/aruco_10.jpg"> | ||||
|           <provider selected="true" editor-type-id="images" /> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="aruco_8.jpg" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/img_aruco/aruco_8.jpg"> | ||||
|           <provider selected="true" editor-type-id="images" /> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="calibrate.py" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/calibrate.py"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state relative-caret-position="480"> | ||||
|               <caret line="34" column="47" lean-forward="true" selection-start-line="34" selection-start-column="47" selection-end-line="34" selection-end-column="47" /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="opengl_opencv.py" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/opengl_opencv.py"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state relative-caret-position="592"> | ||||
|               <caret line="72" column="20" selection-start-line="72" selection-start-column="20" selection-end-line="72" selection-end-column="20" /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="getCalibrationImage.py" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/getCalibrationImage.py"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state relative-caret-position="315"> | ||||
|               <caret line="21" selection-start-line="21" selection-end-line="21" /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="calibration_1.jpg" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_1.jpg"> | ||||
|           <provider selected="true" editor-type-id="images" /> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="calibration_6.jpg" pinned="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_6.jpg"> | ||||
|           <provider selected="true" editor-type-id="images" /> | ||||
|         </entry> | ||||
|       </file> | ||||
|     </leaf> | ||||
|   </component> | ||||
|   <component name="FileTemplateManagerImpl"> | ||||
|     <option name="RECENT_TEMPLATES"> | ||||
|       <list> | ||||
|         <option value="Python Script" /> | ||||
|       </list> | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="FindInProjectRecents"> | ||||
|     <findStrings> | ||||
|       <find>ret</find> | ||||
|       <find>criteria</find> | ||||
|       <find>720</find> | ||||
|       <find>cv2array</find> | ||||
|       <find>init</find> | ||||
|       <find>idle</find> | ||||
|       <find>fl</find> | ||||
|       <find>flip</find> | ||||
|     </findStrings> | ||||
|   </component> | ||||
|   <component name="IdeDocumentHistory"> | ||||
|     <option name="CHANGED_PATHS"> | ||||
|       <list> | ||||
|         <option value="$PROJECT_DIR$/camera_calibration.py" /> | ||||
|         <option value="$PROJECT_DIR$/calibrate.py" /> | ||||
|         <option value="$PROJECT_DIR$/img_calibrate/drawCube.py" /> | ||||
|         <option value="$PROJECT_DIR$/drawCube.py" /> | ||||
|         <option value="$PROJECT_DIR$/opencv_opengl.py" /> | ||||
|         <option value="$PROJECT_DIR$/aruco_create.py" /> | ||||
|         <option value="$PROJECT_DIR$/opengl_opencv.py" /> | ||||
|         <option value="$PROJECT_DIR$/getCalibrationImage.py" /> | ||||
|         <option value="$PROJECT_DIR$/aruco_detection.py" /> | ||||
|       </list> | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="JsBuildToolGruntFileManager" detection-done="true" sorting="DEFINITION_ORDER" /> | ||||
|   <component name="JsBuildToolPackageJson" detection-done="true" sorting="DEFINITION_ORDER" /> | ||||
|   <component name="JsGulpfileManager"> | ||||
|     <detection-done>true</detection-done> | ||||
|     <sorting>DEFINITION_ORDER</sorting> | ||||
|   </component> | ||||
|   <component name="NodePackageJsonFileManager"> | ||||
|     <packageJsonPaths /> | ||||
|   </component> | ||||
|   <component name="ProjectFrameBounds" extendedState="6"> | ||||
|     <option name="x" value="1926" /> | ||||
|     <option name="y" value="24" /> | ||||
|     <option name="width" value="1914" /> | ||||
|     <option name="height" value="1032" /> | ||||
|   </component> | ||||
|   <component name="ProjectView"> | ||||
|     <navigator proportions="" version="1"> | ||||
|       <foldersAlwaysOnTop value="true" /> | ||||
|     </navigator> | ||||
|     <panes> | ||||
|       <pane id="Scope" /> | ||||
|       <pane id="ProjectPane"> | ||||
|         <subPane> | ||||
|           <expand> | ||||
|             <path> | ||||
|               <item name="Aruco_opencv" type="b2602c69:ProjectViewProjectNode" /> | ||||
|               <item name="Aruco_opencv" type="462c0819:PsiDirectoryNode" /> | ||||
|             </path> | ||||
|             <path> | ||||
|               <item name="Aruco_opencv" type="b2602c69:ProjectViewProjectNode" /> | ||||
|               <item name="Aruco_opencv" type="462c0819:PsiDirectoryNode" /> | ||||
|               <item name="img_calibrate" type="462c0819:PsiDirectoryNode" /> | ||||
|             </path> | ||||
|           </expand> | ||||
|           <select /> | ||||
|         </subPane> | ||||
|       </pane> | ||||
|     </panes> | ||||
|   </component> | ||||
|   <component name="PropertiesComponent"> | ||||
|     <property name="WebServerToolWindowFactoryState" value="false" /> | ||||
|     <property name="nodejs_interpreter_path.stuck_in_default_project" value="undefined stuck path" /> | ||||
|     <property name="nodejs_npm_path_reset_for_default_project" value="true" /> | ||||
|     <property name="settings.editor.selected.configurable" value="configurable.group.tools" /> | ||||
|   </component> | ||||
|   <component name="RecentsManager"> | ||||
|     <key name="CopyFile.RECENT_KEYS"> | ||||
|       <recent name="$PROJECT_DIR$" /> | ||||
|     </key> | ||||
|   </component> | ||||
|   <component name="RunDashboard"> | ||||
|     <option name="ruleStates"> | ||||
|       <list> | ||||
|         <RuleState> | ||||
|           <option name="name" value="ConfigurationTypeDashboardGroupingRule" /> | ||||
|         </RuleState> | ||||
|         <RuleState> | ||||
|           <option name="name" value="StatusDashboardGroupingRule" /> | ||||
|         </RuleState> | ||||
|       </list> | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="RunManager" selected="Python.aruco_detection"> | ||||
|     <configuration name="aruco_detection" type="PythonConfigurationType" factoryName="Python" temporary="true"> | ||||
|       <module name="Aruco_opencv" /> | ||||
|       <option name="INTERPRETER_OPTIONS" value="" /> | ||||
|       <option name="PARENT_ENVS" value="true" /> | ||||
|       <envs> | ||||
|         <env name="PYTHONUNBUFFERED" value="1" /> | ||||
|       </envs> | ||||
|       <option name="SDK_HOME" value="" /> | ||||
|       <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" /> | ||||
|       <option name="IS_MODULE_SDK" value="true" /> | ||||
|       <option name="ADD_CONTENT_ROOTS" value="true" /> | ||||
|       <option name="ADD_SOURCE_ROOTS" value="true" /> | ||||
|       <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" /> | ||||
|       <option name="SCRIPT_NAME" value="$PROJECT_DIR$/aruco_detection.py" /> | ||||
|       <option name="PARAMETERS" value="" /> | ||||
|       <option name="SHOW_COMMAND_LINE" value="false" /> | ||||
|       <option name="EMULATE_TERMINAL" value="false" /> | ||||
|       <option name="MODULE_MODE" value="false" /> | ||||
|     </configuration> | ||||
|     <configuration name="calibrate" type="PythonConfigurationType" factoryName="Python" temporary="true"> | ||||
|       <module name="Aruco_opencv" /> | ||||
|       <option name="INTERPRETER_OPTIONS" value="" /> | ||||
|       <option name="PARENT_ENVS" value="true" /> | ||||
|       <envs> | ||||
|         <env name="PYTHONUNBUFFERED" value="1" /> | ||||
|       </envs> | ||||
|       <option name="SDK_HOME" value="" /> | ||||
|       <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" /> | ||||
|       <option name="IS_MODULE_SDK" value="true" /> | ||||
|       <option name="ADD_CONTENT_ROOTS" value="true" /> | ||||
|       <option name="ADD_SOURCE_ROOTS" value="true" /> | ||||
|       <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" /> | ||||
|       <option name="SCRIPT_NAME" value="$PROJECT_DIR$/calibrate.py" /> | ||||
|       <option name="PARAMETERS" value="" /> | ||||
|       <option name="SHOW_COMMAND_LINE" value="false" /> | ||||
|       <option name="EMULATE_TERMINAL" value="false" /> | ||||
|       <option name="MODULE_MODE" value="false" /> | ||||
|     </configuration> | ||||
|     <configuration name="getCalibrationImage" type="PythonConfigurationType" factoryName="Python" temporary="true"> | ||||
|       <module name="Aruco_opencv" /> | ||||
|       <option name="INTERPRETER_OPTIONS" value="" /> | ||||
|       <option name="PARENT_ENVS" value="true" /> | ||||
|       <envs> | ||||
|         <env name="PYTHONUNBUFFERED" value="1" /> | ||||
|       </envs> | ||||
|       <option name="SDK_HOME" value="" /> | ||||
|       <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" /> | ||||
|       <option name="IS_MODULE_SDK" value="true" /> | ||||
|       <option name="ADD_CONTENT_ROOTS" value="true" /> | ||||
|       <option name="ADD_SOURCE_ROOTS" value="true" /> | ||||
|       <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" /> | ||||
|       <option name="SCRIPT_NAME" value="$PROJECT_DIR$/getCalibrationImage.py" /> | ||||
|       <option name="PARAMETERS" value="" /> | ||||
|       <option name="SHOW_COMMAND_LINE" value="false" /> | ||||
|       <option name="EMULATE_TERMINAL" value="false" /> | ||||
|       <option name="MODULE_MODE" value="false" /> | ||||
|     </configuration> | ||||
|     <configuration name="opencv_opengl" type="PythonConfigurationType" factoryName="Python" temporary="true"> | ||||
|       <module name="Aruco_opencv" /> | ||||
|       <option name="INTERPRETER_OPTIONS" value="" /> | ||||
|       <option name="PARENT_ENVS" value="true" /> | ||||
|       <envs> | ||||
|         <env name="PYTHONUNBUFFERED" value="1" /> | ||||
|       </envs> | ||||
|       <option name="SDK_HOME" value="" /> | ||||
|       <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" /> | ||||
|       <option name="IS_MODULE_SDK" value="true" /> | ||||
|       <option name="ADD_CONTENT_ROOTS" value="true" /> | ||||
|       <option name="ADD_SOURCE_ROOTS" value="true" /> | ||||
|       <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" /> | ||||
|       <option name="SCRIPT_NAME" value="$PROJECT_DIR$/opencv_opengl.py" /> | ||||
|       <option name="PARAMETERS" value="" /> | ||||
|       <option name="SHOW_COMMAND_LINE" value="false" /> | ||||
|       <option name="EMULATE_TERMINAL" value="false" /> | ||||
|       <option name="MODULE_MODE" value="false" /> | ||||
|     </configuration> | ||||
|     <configuration name="opengl_opencv" type="PythonConfigurationType" factoryName="Python" temporary="true"> | ||||
|       <module name="Aruco_opencv" /> | ||||
|       <option name="INTERPRETER_OPTIONS" value="" /> | ||||
|       <option name="PARENT_ENVS" value="true" /> | ||||
|       <envs> | ||||
|         <env name="PYTHONUNBUFFERED" value="1" /> | ||||
|       </envs> | ||||
|       <option name="SDK_HOME" value="" /> | ||||
|       <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" /> | ||||
|       <option name="IS_MODULE_SDK" value="true" /> | ||||
|       <option name="ADD_CONTENT_ROOTS" value="true" /> | ||||
|       <option name="ADD_SOURCE_ROOTS" value="true" /> | ||||
|       <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" /> | ||||
|       <option name="SCRIPT_NAME" value="$PROJECT_DIR$/opengl_opencv.py" /> | ||||
|       <option name="PARAMETERS" value="" /> | ||||
|       <option name="SHOW_COMMAND_LINE" value="false" /> | ||||
|       <option name="EMULATE_TERMINAL" value="false" /> | ||||
|       <option name="MODULE_MODE" value="false" /> | ||||
|     </configuration> | ||||
|     <list> | ||||
|       <item itemvalue="Python.aruco_detection" /> | ||||
|       <item itemvalue="Python.getCalibrationImage" /> | ||||
|       <item itemvalue="Python.opencv_opengl" /> | ||||
|       <item itemvalue="Python.opengl_opencv" /> | ||||
|       <item itemvalue="Python.calibrate" /> | ||||
|     </list> | ||||
|     <recent_temporary> | ||||
|       <list> | ||||
|         <item itemvalue="Python.aruco_detection" /> | ||||
|         <item itemvalue="Python.getCalibrationImage" /> | ||||
|         <item itemvalue="Python.calibrate" /> | ||||
|         <item itemvalue="Python.opengl_opencv" /> | ||||
|         <item itemvalue="Python.opencv_opengl" /> | ||||
|       </list> | ||||
|     </recent_temporary> | ||||
|   </component> | ||||
|   <component name="SvnConfiguration"> | ||||
|     <configuration /> | ||||
|   </component> | ||||
|   <component name="TaskManager"> | ||||
|     <task active="true" id="Default" summary="Default task"> | ||||
|       <changelist id="47ca631b-dc62-4446-a33d-e49bb58e0642" name="Default" comment="" /> | ||||
|       <created>1524648559812</created> | ||||
|       <option name="number" value="Default" /> | ||||
|       <option name="presentableId" value="Default" /> | ||||
|       <updated>1524648559812</updated> | ||||
|     </task> | ||||
|     <servers /> | ||||
|   </component> | ||||
|   <component name="ToolWindowManager"> | ||||
|     <frame x="1919" y="24" width="1922" height="1033" extended-state="6" /> | ||||
|     <layout> | ||||
|       <window_info anchor="bottom" id="TODO" order="6" /> | ||||
|       <window_info anchor="bottom" id="Event Log" order="7" side_tool="true" /> | ||||
|       <window_info anchor="bottom" id="Database Changes" order="7" show_stripe_button="false" /> | ||||
|       <window_info anchor="bottom" id="Run" order="2" weight="0.29913607" /> | ||||
|       <window_info anchor="bottom" id="Version Control" order="7" show_stripe_button="false" /> | ||||
|       <window_info anchor="bottom" id="Python Console" order="7" /> | ||||
|       <window_info anchor="bottom" id="Terminal" order="7" /> | ||||
|       <window_info content_ui="combo" id="Project" order="0" visible="true" weight="0.18177083" /> | ||||
|       <window_info anchor="bottom" id="Docker" order="7" show_stripe_button="false" /> | ||||
|       <window_info anchor="right" id="Database" order="3" /> | ||||
|       <window_info anchor="right" id="SciView" order="3" weight="0.3296875" /> | ||||
|       <window_info id="Structure" order="1" side_tool="true" weight="0.25" /> | ||||
|       <window_info anchor="bottom" id="Debug" order="3" weight="0.39956802" /> | ||||
|       <window_info id="Favorites" order="2" side_tool="true" /> | ||||
|       <window_info anchor="right" content_ui="combo" id="Hierarchy" order="2" weight="0.25" /> | ||||
|       <window_info anchor="bottom" id="Inspection" order="5" weight="0.4" /> | ||||
|       <window_info anchor="right" id="Commander" internal_type="SLIDING" order="0" type="SLIDING" weight="0.4" /> | ||||
|       <window_info anchor="right" id="Ant Build" order="1" weight="0.25" /> | ||||
|       <window_info anchor="bottom" id="Message" order="0" /> | ||||
|       <window_info anchor="bottom" id="Cvs" order="4" weight="0.25" /> | ||||
|       <window_info anchor="bottom" id="Find" order="1" weight="0.32937366" /> | ||||
|     </layout> | ||||
|   </component> | ||||
|   <component name="TypeScriptGeneratedFilesManager"> | ||||
|     <option name="version" value="1" /> | ||||
|   </component> | ||||
|   <component name="VcsContentAnnotationSettings"> | ||||
|     <option name="myLimit" value="2678400000" /> | ||||
|   </component> | ||||
|   <component name="XDebuggerManager"> | ||||
|     <breakpoint-manager> | ||||
|       <option name="time" value="24" /> | ||||
|     </breakpoint-manager> | ||||
|   </component> | ||||
|   <component name="editorHistoryManager"> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="375"> | ||||
|           <caret line="27" lean-forward="true" selection-start-line="27" selection-end-line="27" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_create.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="135"> | ||||
|           <caret line="10" column="17" selection-start-line="10" selection-start-column="17" selection-end-line="10" selection-end-column="17" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="375"> | ||||
|           <caret line="27" lean-forward="true" selection-start-line="27" selection-end-line="27" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_create.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="135"> | ||||
|           <caret line="10" column="17" selection-start-line="10" selection-start-column="17" selection-end-line="10" selection-end-column="17" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="375"> | ||||
|           <caret line="27" lean-forward="true" selection-start-line="27" selection-end-line="27" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_create.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="135"> | ||||
|           <caret line="10" column="17" lean-forward="true" selection-start-line="10" selection-start-column="17" selection-end-line="10" selection-end-column="17" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="90"> | ||||
|           <caret line="8" column="15" selection-start-line="8" selection-start-column="15" selection-end-line="8" selection-end-column="15" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/drawCube.py" /> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_4.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_15.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_14.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_8.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_10.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_3.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_2.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_11.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_13.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_12.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_7.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_4.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_5.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_9.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_3.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_1.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_2.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_7.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_5.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_8.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_10.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_aruco/aruco_11.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_create.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="120"> | ||||
|           <caret line="8" column="9" selection-start-line="8" selection-start-column="9" selection-end-line="15" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/opengl_opencv.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="592"> | ||||
|           <caret line="72" column="20" selection-start-line="72" selection-start-column="20" selection-end-line="72" selection-end-column="20" /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/getCalibrationImage.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="315"> | ||||
|           <caret line="21" selection-start-line="21" selection-end-line="21" /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_1.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/img_calibrate/calibration_6.jpg"> | ||||
|       <provider selected="true" editor-type-id="images" /> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/calibrate.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="480"> | ||||
|           <caret line="34" column="47" lean-forward="true" selection-start-line="34" selection-start-column="47" selection-end-line="34" selection-end-column="47" /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/aruco_detection.py"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state relative-caret-position="315"> | ||||
|           <caret line="21" column="17" lean-forward="true" selection-start-line="21" selection-start-column="17" selection-end-line="21" selection-end-column="17" /> | ||||
|           <folding> | ||||
|             <element signature="e#0#16#0" expanded="true" /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|   </component> | ||||
| </project> | ||||
|  | @ -1,15 +0,0 @@ | |||
| import cv2 as cv | ||||
| import cv2.aruco as aruco | ||||
| 
 | ||||
| ''' | ||||
|     drawMarker(...) | ||||
|         drawMarker(dictionary, id, sidePixels[, img[, borderBits]]) -> img | ||||
| ''' | ||||
| 
 | ||||
| aruco_dict = aruco.Dictionary_get(aruco.DICT_4X4_50) # Un aruco est composé d'une bande noire et d'un code en blanc et noir | ||||
|                                                      #4x4 indique la partie ou sera généré le code (blanc et noir donc). | ||||
| print(aruco_dict) | ||||
| 
 | ||||
| for aruco_id in range(1,12): | ||||
|     img = aruco.drawMarker(aruco_dict, aruco_id, 200) | ||||
|     cv.imwrite("./img_aruco/aruco_"+str(aruco_id)+".jpg", img) | ||||
|  | @ -1,34 +0,0 @@ | |||
| import cv2 as cv | ||||
| import cv2.aruco as aruco | ||||
| from calibrate import calculareCameraCalibration | ||||
| 
 | ||||
| cap = cv.VideoCapture(0) | ||||
| ret, mtx, dist, rvecs, tvecs = calculareCameraCalibration() | ||||
| parameters = aruco.DetectorParameters_create() | ||||
| aruco_dict = aruco.Dictionary_get(aruco.DICT_4X4_50) | ||||
| drawAxis = True | ||||
| 
 | ||||
| while (True): | ||||
| 
 | ||||
|     ret, frame = cap.read() | ||||
|     gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY) | ||||
| 
 | ||||
|     corners, ids, rejectedImgPoints = aruco.detectMarkers(gray, aruco_dict, parameters=parameters) | ||||
| 
 | ||||
|     frame = aruco.drawDetectedMarkers(frame, corners, ids) | ||||
|     rvecs, tvecs, _ = aruco.estimatePoseSingleMarkers(corners, 0.05, mtx, dist) | ||||
|     if ids is not None: | ||||
|         for idx, marker in enumerate(ids): | ||||
|             print(corners[idx][0]) #Affiche les coordonée tout les coins Top Left | ||||
|             try: | ||||
|                 if drawAxis is True: | ||||
|                     aruco.drawAxis(frame, mtx,dist,rvecs[idx], tvecs[idx], 0.1) | ||||
|             except: | ||||
|                 print(" Erreur calcul des axes") | ||||
| 
 | ||||
|     cv.imshow('frame', frame) | ||||
|     if cv.waitKey(1) & 0xFF == ord('q'): | ||||
|         break | ||||
| 
 | ||||
| cap.release() | ||||
| cv.destroyAllWindows() | ||||
|  | @ -1,35 +0,0 @@ | |||
| import numpy as np | ||||
| import cv2 | ||||
| import glob | ||||
| 
 | ||||
| 
 | ||||
| def calculareCameraCalibration(): | ||||
|     # termination criteria | ||||
|     criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 23, 0.001) | ||||
| 
 | ||||
|     # prepare object points, like (0,0,0), (1,0,0), (2,0,0) ....,(6,5,0) | ||||
|     objp = np.zeros((6*7,3), np.float32) | ||||
|     objp[:,:2] = np.mgrid[0:7,0:6].T.reshape(-1,2) | ||||
| 
 | ||||
|     # Arrays to store object points and image points from all the images. | ||||
|     objpoints = [] # 3d point in real world space | ||||
|     imgpoints = [] # 2d points in image plane. | ||||
| 
 | ||||
|     images = glob.glob('./img_calibrate/*.jpg') | ||||
| 
 | ||||
|     for fname in images: | ||||
|         img = cv2.imread(fname) | ||||
|         gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) | ||||
| 
 | ||||
|         # Find the chess board corners | ||||
|         ret, corners = cv2.findChessboardCorners(gray, (7,6),None) | ||||
| 
 | ||||
|         # If found, add object points, image points (after refining them) | ||||
|         if ret == True: | ||||
|             objpoints.append(objp) | ||||
| 
 | ||||
|             corners2 = cv2.cornerSubPix(gray,corners,(11,11),(-1,-1),criteria) | ||||
|             imgpoints.append(corners2) | ||||
| 
 | ||||
|             ret, mtx, dist, rvecs, tvecs = cv2.calibrateCamera(objpoints, imgpoints, gray.shape[::-1], None, None) | ||||
|             return ret, mtx, dist, rvecs, tvecs | ||||
|  | @ -1,21 +0,0 @@ | |||
| import cv2 | ||||
| 
 | ||||
| 
 | ||||
| cap = cv2.VideoCapture(0) | ||||
| nbrImage = 0 | ||||
| while nbrImage < 15: | ||||
|     ret, img = cap.read() | ||||
|     gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) | ||||
| 
 | ||||
|     # Find the chess board corners | ||||
|     ret, corners = cv2.findChessboardCorners(gray, (7,6),None) | ||||
| 
 | ||||
|     # If found, add object points, image points (after refining them) | ||||
|     if ret == True: | ||||
|         nbrImage = nbrImage+1 | ||||
|         cv2.imwrite("./img_calibrate/calibration_" + str(nbrImage) + ".jpg", img) | ||||
|         cv2.putText(img, 'Image ' + str(nbrImage) + ' /15', (5, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (255, 255, 255), 2, cv2.LINE_AA) | ||||
|         cv2.imshow('img',img) | ||||
|         cv2.waitKey(1000) | ||||
| 
 | ||||
| cv2.destroyAllWindows() | ||||
| Before Width: | Height: | Size: 2.8 KiB | 
| Before Width: | Height: | Size: 2.8 KiB | 
| Before Width: | Height: | Size: 2.9 KiB | 
| Before Width: | Height: | Size: 2.8 KiB | 
| Before Width: | Height: | Size: 2.9 KiB | 
| Before Width: | Height: | Size: 3.3 KiB | 
| Before Width: | Height: | Size: 3.3 KiB | 
| Before Width: | Height: | Size: 3 KiB | 
| Before Width: | Height: | Size: 2.7 KiB | 
| Before Width: | Height: | Size: 3.2 KiB | 
| Before Width: | Height: | Size: 2.9 KiB | 
| Before Width: | Height: | Size: 86 KiB | 
| Before Width: | Height: | Size: 82 KiB | 
| Before Width: | Height: | Size: 83 KiB | 
| Before Width: | Height: | Size: 82 KiB | 
| Before Width: | Height: | Size: 82 KiB | 
| Before Width: | Height: | Size: 78 KiB | 
| Before Width: | Height: | Size: 79 KiB | 
| Before Width: | Height: | Size: 81 KiB | 
| Before Width: | Height: | Size: 82 KiB | 
| Before Width: | Height: | Size: 79 KiB | 
| Before Width: | Height: | Size: 81 KiB | 
| Before Width: | Height: | Size: 83 KiB | 
| Before Width: | Height: | Size: 84 KiB | 
| Before Width: | Height: | Size: 84 KiB | 
| Before Width: | Height: | Size: 85 KiB | 
|  | @ -1,138 +0,0 @@ | |||
| import cv2 | ||||
| from OpenGL.GL import * | ||||
| from OpenGL.GLU import * | ||||
| from OpenGL.GLUT import * | ||||
| import numpy as np | ||||
| import sys | ||||
| 
 | ||||
| # window dimensions | ||||
| width = 1280 | ||||
| height = 720 | ||||
| nRange = 1.0 | ||||
| 
 | ||||
| global capture | ||||
| capture = None | ||||
| 
 | ||||
| 
 | ||||
| def cv2array(im): | ||||
|     h, w, c = im.shape | ||||
|     a = np.fromstring( | ||||
|         im.tostring(), | ||||
|         dtype=im.dtype, | ||||
|         count=w * h * c) | ||||
|     a.shape = (h, w, c) | ||||
|     return a | ||||
| 
 | ||||
| 
 | ||||
| def init(): | ||||
|     # glclearcolor (r, g, b, alpha) | ||||
|     glClearColor(0.0, 0.0, 0.0, 1.0) | ||||
| 
 | ||||
|     glutDisplayFunc(display) | ||||
|     glutReshapeFunc(reshape) | ||||
|     glutKeyboardFunc(keyboard) | ||||
|     glutIdleFunc(idle) | ||||
| 
 | ||||
| 
 | ||||
| def idle(): | ||||
|     # capture next frame | ||||
| 
 | ||||
|     global capture | ||||
|     _, image = capture.read() | ||||
| 
 | ||||
|     cv2.cvtColor(image, cv2.COLOR_BGR2RGB) | ||||
|     # you must convert the image to array for glTexImage2D to work | ||||
|     # maybe there is a faster way that I don't know about yet... | ||||
| 
 | ||||
|     # print image_arr | ||||
| 
 | ||||
|     # Create Texture | ||||
|     glTexImage2D(GL_TEXTURE_2D, | ||||
|                  0, | ||||
|                  GL_RGB, | ||||
|                  1280, 720, | ||||
|                  0, | ||||
|                  GL_RGB, | ||||
|                  GL_UNSIGNED_BYTE, | ||||
|                  image) | ||||
|     cv2.imshow('frame', image) | ||||
|     glutPostRedisplay() | ||||
| 
 | ||||
| 
 | ||||
| def display(): | ||||
|     glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT) | ||||
|     glEnable(GL_TEXTURE_2D) | ||||
|     # glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT) | ||||
|     # glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT) | ||||
|     # glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_DECAL) | ||||
|     # this one is necessary with texture2d for some reason | ||||
|     glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST) | ||||
| 
 | ||||
|     # Set Projection Matrix | ||||
|     glMatrixMode(GL_PROJECTION) | ||||
|     glLoadIdentity() | ||||
|     gluOrtho2D(0, width, 0, height) | ||||
| 
 | ||||
|     # Switch to Model View Matrix | ||||
|     glMatrixMode(GL_MODELVIEW) | ||||
|     glLoadIdentity() | ||||
| 
 | ||||
|     # Draw textured Quads | ||||
|     glBegin(GL_QUADS) | ||||
|     glTexCoord2f(0.0, 0.0) | ||||
|     glVertex2f(0.0, 0.0) | ||||
|     glTexCoord2f(1.0, 0.0) | ||||
|     glVertex2f(width, 0.0) | ||||
|     glTexCoord2f(1.0, 1.0) | ||||
|     glVertex2f(width, height) | ||||
|     glTexCoord2f(0.0, 1.0) | ||||
|     glVertex2f(0.0, height) | ||||
|     glEnd() | ||||
| 
 | ||||
|     glFlush() | ||||
|     glutSwapBuffers() | ||||
| 
 | ||||
| 
 | ||||
| def reshape(w, h): | ||||
|     if h == 0: | ||||
|         h = 1 | ||||
| 
 | ||||
|     glViewport(0, 0, w, h) | ||||
|     glMatrixMode(GL_PROJECTION) | ||||
| 
 | ||||
|     glLoadIdentity() | ||||
|     # allows for reshaping the window without distoring shape | ||||
| 
 | ||||
|     if w <= h: | ||||
|         glOrtho(-nRange, nRange, -nRange * h / w, nRange * h / w, -nRange, nRange) | ||||
|     else: | ||||
|         glOrtho(-nRange * w / h, nRange * w / h, -nRange, nRange, -nRange, nRange) | ||||
| 
 | ||||
|     glMatrixMode(GL_MODELVIEW) | ||||
|     glLoadIdentity() | ||||
| 
 | ||||
| 
 | ||||
| def keyboard(key, x, y): | ||||
|     global anim | ||||
|     if key == chr(27): | ||||
|         sys.exit() | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     global capture | ||||
|     # start openCV capturefromCAM | ||||
|     capture = cv2.VideoCapture(0) | ||||
|     print(capture) | ||||
|     capture.set(3, 1280) | ||||
|     capture.set(4, 720) | ||||
|     glutInit(sys.argv) | ||||
|     glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH) | ||||
|     glutInitWindowSize(width, height) | ||||
|     glutInitWindowPosition(100, 100) | ||||
|     glutCreateWindow("OpenGL + OpenCV") | ||||
| 
 | ||||
|     init() | ||||
|     glutMainLoop() | ||||
| 
 | ||||
| 
 | ||||
| main() | ||||
|  | @ -1,6 +0,0 @@ | |||
| D'aprés mes souvenir : | ||||
| - Asservissement complétement pourrave | ||||
| - Architecture globalement correcte | ||||
| - Reprendre la façon de recevoir des messages pour que ça colle avec la norme 802.15.4 | ||||
| 	J'essayais de lire avec une DMA (taille fixe) mais la norme fait bouger la taille en ajoutant  | ||||
| 	parfois des caractéres d'échapement | ||||
|  | @ -1,13 +0,0 @@ | |||
| [PreviousGenFiles] | ||||
| HeaderPath=D:/Users/senaneuc/Documents/dumby_rtos2/dumby2/Inc | ||||
| HeaderFiles=FreeRTOSConfig.h;stm32f1xx_it.h;stm32f1xx_hal_conf.h;main.h;gpio.h;adc.h;dma.h;tim.h;usart.h; | ||||
| SourcePath=D:/Users/senaneuc/Documents/dumby_rtos2/dumby2/Src | ||||
| SourceFiles=freertos.c;stm32f1xx_it.c;stm32f1xx_hal_msp.c;stm32f1xx_hal_timebase_TIM.c;main.c;gpio.c;adc.c;dma.c;tim.c;usart.c; | ||||
| 
 | ||||
| [PreviousLibFiles] | ||||
| LibFiles=Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_adc.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_adc_ex.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_uart.h;Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_gpio_ex.c;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h;Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h;Middlewares/Third_Party/FreeRTOS/Source/portable/RVDS/ARM_CM3/portmacro.h;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_adc.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_adc_ex.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_tim.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_tim_ex.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_uart.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_rcc.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_rcc_ex.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_gpio.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_dma.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_cortex.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_pwr.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_flash.c;Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_flash_ex.c;Middlewares/Third_Party/FreeRTOS/Source/portable/MemMang/heap_4.c;Middlewares/Third_Party/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c;Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xb.h;Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h;Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h;Drivers/CMSIS/Device/ST/STM32F1xx/Source/Templates/system_stm32f1xx.c;Middlewares/Third_Party/FreeRTOS/Source/include/croutine.h;Middlewares/Third_Party/FreeRTOS/Source/include/deprecated_definitions.h;Middlewares/Third_Party/FreeRTOS/Source/include/event_groups.h;Middlewares/Third_Party/FreeRTOS/Source/include/FreeRTOS.h;Middlewares/Third_Party/FreeRTOS/Source/include/FreeRTOSConfig_template.h;Middlewares/Third_Party/FreeRTOS/Source/include/list.h;Middlewares/Third_Party/FreeRTOS/Source/include/mpu_prototypes.h;Middlewares/Third_Party/FreeRTOS/Source/include/mpu_wrappers.h;Middlewares/Third_Party/FreeRTOS/Source/include/portable.h;Middlewares/Third_Party/FreeRTOS/Source/include/projdefs.h;Middlewares/Third_Party/FreeRTOS/Source/include/queue.h;Middlewares/Third_Party/FreeRTOS/Source/include/semphr.h;Middlewares/Third_Party/FreeRTOS/Source/include/StackMacros.h;Middlewares/Third_Party/FreeRTOS/Source/include/task.h;Middlewares/Third_Party/FreeRTOS/Source/include/timers.h;Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS/cmsis_os.h;Middlewares/Third_Party/FreeRTOS/Source/croutine.c;Middlewares/Third_Party/FreeRTOS/Source/event_groups.c;Middlewares/Third_Party/FreeRTOS/Source/list.c;Middlewares/Third_Party/FreeRTOS/Source/queue.c;Middlewares/Third_Party/FreeRTOS/Source/tasks.c;Middlewares/Third_Party/FreeRTOS/Source/timers.c;Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS/cmsis_os.c;Drivers/CMSIS/Include/arm_common_tables.h;Drivers/CMSIS/Include/arm_const_structs.h;Drivers/CMSIS/Include/arm_math.h;Drivers/CMSIS/Include/cmsis_armcc.h;Drivers/CMSIS/Include/cmsis_armcc_V6.h;Drivers/CMSIS/Include/cmsis_gcc.h;Drivers/CMSIS/Include/core_cm0.h;Drivers/CMSIS/Include/core_cm0plus.h;Drivers/CMSIS/Include/core_cm3.h;Drivers/CMSIS/Include/core_cm4.h;Drivers/CMSIS/Include/core_cm7.h;Drivers/CMSIS/Include/core_cmFunc.h;Drivers/CMSIS/Include/core_cmInstr.h;Drivers/CMSIS/Include/core_cmSimd.h;Drivers/CMSIS/Include/core_sc000.h;Drivers/CMSIS/Include/core_sc300.h; | ||||
| 
 | ||||
| [PreviousUsedKeilFiles] | ||||
| SourceFiles=..\Src\main.c;..\Src\gpio.c;..\Src\adc.c;..\Src\dma.c;..\Src\freertos.c;..\Src\tim.c;..\Src\usart.c;..\Src\stm32f1xx_it.c;..\Src\stm32f1xx_hal_msp.c;..\Src\stm32f1xx_hal_timebase_TIM.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_gpio_ex.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_adc.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_adc_ex.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_tim.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_tim_ex.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_uart.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_rcc.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_rcc_ex.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_gpio.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_dma.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_cortex.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_pwr.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_flash.c;../Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_flash_ex.c;../Middlewares/Third_Party/FreeRTOS/Source/portable/MemMang/heap_4.c;../Middlewares/Third_Party/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c;../Middlewares/Third_Party/FreeRTOS/Source/croutine.c;../Middlewares/Third_Party/FreeRTOS/Source/event_groups.c;../Middlewares/Third_Party/FreeRTOS/Source/list.c;../Middlewares/Third_Party/FreeRTOS/Source/queue.c;../Middlewares/Third_Party/FreeRTOS/Source/tasks.c;../Middlewares/Third_Party/FreeRTOS/Source/timers.c;../Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS/cmsis_os.c;../Src/system_stm32f1xx.c;../Drivers/CMSIS/Device/ST/STM32F1xx/Source/Templates/system_stm32f1xx.c;../Drivers/CMSIS/Device/ST/STM32F1xx/Source/Templates/arm/startup_stm32f103xb.s;../Middlewares/Third_Party/FreeRTOS/Source/portable/MemMang/heap_4.c;../Middlewares/Third_Party/FreeRTOS/Source/portable/RVDS/ARM_CM3/port.c;../Middlewares/Third_Party/FreeRTOS/Source/croutine.c;../Middlewares/Third_Party/FreeRTOS/Source/event_groups.c;../Middlewares/Third_Party/FreeRTOS/Source/list.c;../Middlewares/Third_Party/FreeRTOS/Source/queue.c;../Middlewares/Third_Party/FreeRTOS/Source/tasks.c;../Middlewares/Third_Party/FreeRTOS/Source/timers.c;../Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS/cmsis_os.c; | ||||
| HeaderPath=..\Drivers\STM32F1xx_HAL_Driver\Inc;..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy;..\Middlewares\Third_Party\FreeRTOS\Source\portable\RVDS\ARM_CM3;..\Drivers\CMSIS\Device\ST\STM32F1xx\Include;..\Middlewares\Third_Party\FreeRTOS\Source\include;..\Middlewares\Third_Party\FreeRTOS\Source\CMSIS_RTOS;..\Drivers\CMSIS\Include;..\Inc; | ||||
| 
 | ||||
|  | @ -1,238 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V4.2.0 | ||||
|   * @date    31-March-2017 | ||||
|   * @brief   CMSIS STM32F1xx Device Peripheral Access Layer Header File.  | ||||
|   * | ||||
|   *          The file is the unique include file that the application programmer | ||||
|   *          is using in the C source code, usually in main.c. This file contains: | ||||
|   *            - Configuration section that allows to select: | ||||
|   *              - The STM32F1xx device used in the target application | ||||
|   *              - To use or not the peripheral’s drivers in application code(i.e.  | ||||
|   *                code will be based on direct access to peripheral’s registers  | ||||
|   *                rather than drivers API), this option is controlled by  | ||||
|   *                "#define USE_HAL_DRIVER" | ||||
|   *   | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup stm32f1xx
 | ||||
|   * @{ | ||||
|   */ | ||||
|      | ||||
| #ifndef __STM32F1XX_H | ||||
| #define __STM32F1XX_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif /* __cplusplus */ | ||||
|    | ||||
| /** @addtogroup Library_configuration_section
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief STM32 Family | ||||
|   */ | ||||
| #if !defined (STM32F1) | ||||
| #define STM32F1 | ||||
| #endif /* STM32F1 */ | ||||
| 
 | ||||
| /* Uncomment the line below according to the target STM32L device used in your 
 | ||||
|    application  | ||||
|   */ | ||||
| 
 | ||||
| #if !defined (STM32F100xB) && !defined (STM32F100xE) && !defined (STM32F101x6) && \ | ||||
|     !defined (STM32F101xB) && !defined (STM32F101xE) && !defined (STM32F101xG) && !defined (STM32F102x6) && !defined (STM32F102xB) && !defined (STM32F103x6) && \ | ||||
|     !defined (STM32F103xB) && !defined (STM32F103xE) && !defined (STM32F103xG) && !defined (STM32F105xC) && !defined (STM32F107xC) | ||||
|   /* #define STM32F100xB  */   /*!< STM32F100C4, STM32F100R4, STM32F100C6, STM32F100R6, STM32F100C8, STM32F100R8, STM32F100V8, STM32F100CB, STM32F100RB and STM32F100VB */ | ||||
|   /* #define STM32F100xE */    /*!< STM32F100RC, STM32F100VC, STM32F100ZC, STM32F100RD, STM32F100VD, STM32F100ZD, STM32F100RE, STM32F100VE and STM32F100ZE */ | ||||
|   /* #define STM32F101x6  */   /*!< STM32F101C4, STM32F101R4, STM32F101T4, STM32F101C6, STM32F101R6 and STM32F101T6 Devices */ | ||||
|   /* #define STM32F101xB  */   /*!< STM32F101C8, STM32F101R8, STM32F101T8, STM32F101V8, STM32F101CB, STM32F101RB, STM32F101TB and STM32F101VB */ | ||||
|   /* #define STM32F101xE */    /*!< STM32F101RC, STM32F101VC, STM32F101ZC, STM32F101RD, STM32F101VD, STM32F101ZD, STM32F101RE, STM32F101VE and STM32F101ZE */  | ||||
|   /* #define STM32F101xG  */   /*!< STM32F101RF, STM32F101VF, STM32F101ZF, STM32F101RG, STM32F101VG and STM32F101ZG */ | ||||
|   /* #define STM32F102x6 */    /*!< STM32F102C4, STM32F102R4, STM32F102C6 and STM32F102R6 */ | ||||
|   /* #define STM32F102xB  */   /*!< STM32F102C8, STM32F102R8, STM32F102CB and STM32F102RB */ | ||||
|   /* #define STM32F103x6  */   /*!< STM32F103C4, STM32F103R4, STM32F103T4, STM32F103C6, STM32F103R6 and STM32F103T6 */ | ||||
|   /* #define STM32F103xB  */   /*!< STM32F103C8, STM32F103R8, STM32F103T8, STM32F103V8, STM32F103CB, STM32F103RB, STM32F103TB and STM32F103VB */ | ||||
|   /* #define STM32F103xE */    /*!< STM32F103RC, STM32F103VC, STM32F103ZC, STM32F103RD, STM32F103VD, STM32F103ZD, STM32F103RE, STM32F103VE and STM32F103ZE */ | ||||
|   /* #define STM32F103xG  */   /*!< STM32F103RF, STM32F103VF, STM32F103ZF, STM32F103RG, STM32F103VG and STM32F103ZG */ | ||||
|   /* #define STM32F105xC */    /*!< STM32F105R8, STM32F105V8, STM32F105RB, STM32F105VB, STM32F105RC and STM32F105VC */ | ||||
|   /* #define STM32F107xC  */   /*!< STM32F107RB, STM32F107VB, STM32F107RC and STM32F107VC */   | ||||
| #endif | ||||
| 
 | ||||
| /*  Tip: To avoid modifying this file each time you need to switch between these
 | ||||
|         devices, you can define the device in your toolchain compiler preprocessor. | ||||
|   */ | ||||
|    | ||||
| #if !defined  (USE_HAL_DRIVER) | ||||
| /**
 | ||||
|  * @brief Comment the line below if you will not use the peripherals drivers. | ||||
|    In this case, these drivers will not be included and the application code will  | ||||
|    be based on direct access to peripherals registers  | ||||
|    */ | ||||
|   /*#define USE_HAL_DRIVER */ | ||||
| #endif /* USE_HAL_DRIVER */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief CMSIS Device version number V4.2.0 | ||||
|   */ | ||||
| #define __STM32F1_CMSIS_VERSION_MAIN   (0x04) /*!< [31:24] main version */ | ||||
| #define __STM32F1_CMSIS_VERSION_SUB1   (0x02) /*!< [23:16] sub1 version */ | ||||
| #define __STM32F1_CMSIS_VERSION_SUB2   (0x00) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32F1_CMSIS_VERSION_RC     (0x00) /*!< [7:0]  release candidate */  | ||||
| #define __STM32F1_CMSIS_VERSION        ((__STM32F1_CMSIS_VERSION_MAIN << 24)\ | ||||
|                                        |(__STM32F1_CMSIS_VERSION_SUB1 << 16)\ | ||||
|                                        |(__STM32F1_CMSIS_VERSION_SUB2 << 8 )\ | ||||
|                                        |(__STM32F1_CMSIS_VERSION_RC)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup Device_Included
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #if defined(STM32F100xB) | ||||
|   #include "stm32f100xb.h" | ||||
| #elif defined(STM32F100xE) | ||||
|   #include "stm32f100xe.h" | ||||
| #elif defined(STM32F101x6) | ||||
|   #include "stm32f101x6.h" | ||||
| #elif defined(STM32F101xB) | ||||
|   #include "stm32f101xb.h" | ||||
| #elif defined(STM32F101xE) | ||||
|   #include "stm32f101xe.h" | ||||
| #elif defined(STM32F101xG) | ||||
|   #include "stm32f101xg.h" | ||||
| #elif defined(STM32F102x6) | ||||
|   #include "stm32f102x6.h" | ||||
| #elif defined(STM32F102xB) | ||||
|   #include "stm32f102xb.h" | ||||
| #elif defined(STM32F103x6) | ||||
|   #include "stm32f103x6.h" | ||||
| #elif defined(STM32F103xB) | ||||
|   #include "stm32f103xb.h" | ||||
| #elif defined(STM32F103xE) | ||||
|   #include "stm32f103xe.h" | ||||
| #elif defined(STM32F103xG) | ||||
|   #include "stm32f103xg.h" | ||||
| #elif defined(STM32F105xC) | ||||
|   #include "stm32f105xc.h" | ||||
| #elif defined(STM32F107xC) | ||||
|   #include "stm32f107xc.h" | ||||
| #else | ||||
|  #error "Please select first the target STM32F1xx device used in your application (in stm32f1xx.h file)" | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup Exported_types
 | ||||
|   * @{ | ||||
|   */   | ||||
| typedef enum  | ||||
| { | ||||
|   RESET = 0,  | ||||
|   SET = !RESET | ||||
| } FlagStatus, ITStatus; | ||||
| 
 | ||||
| typedef enum  | ||||
| { | ||||
|   DISABLE = 0,  | ||||
|   ENABLE = !DISABLE | ||||
| } FunctionalState; | ||||
| #define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE)) | ||||
| 
 | ||||
| typedef enum  | ||||
| { | ||||
|   ERROR = 0,  | ||||
|   SUCCESS = !ERROR | ||||
| } ErrorStatus; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /** @addtogroup Exported_macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define SET_BIT(REG, BIT)     ((REG) |= (BIT)) | ||||
| 
 | ||||
| #define CLEAR_BIT(REG, BIT)   ((REG) &= ~(BIT)) | ||||
| 
 | ||||
| #define READ_BIT(REG, BIT)    ((REG) & (BIT)) | ||||
| 
 | ||||
| #define CLEAR_REG(REG)        ((REG) = (0x0)) | ||||
| 
 | ||||
| #define WRITE_REG(REG, VAL)   ((REG) = (VAL)) | ||||
| 
 | ||||
| #define READ_REG(REG)         ((REG)) | ||||
| 
 | ||||
| #define MODIFY_REG(REG, CLEARMASK, SETMASK)  WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK))) | ||||
| 
 | ||||
| #define POSITION_VAL(VAL)     (__CLZ(__RBIT(VAL)))  | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if defined (USE_HAL_DRIVER) | ||||
|  #include "stm32f1xx_hal.h" | ||||
| #endif /* USE_HAL_DRIVER */ | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif /* __cplusplus */ | ||||
| 
 | ||||
| #endif /* __STM32F1xx_H */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,116 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32f10x.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V4.2.0 | ||||
|   * @date    31-March-2017 | ||||
|   * @brief   CMSIS Cortex-M3 Device Peripheral Access Layer System Header File. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup stm32f10x_system
 | ||||
|   * @{ | ||||
|   */   | ||||
|    | ||||
| /**
 | ||||
|   * @brief Define to prevent recursive inclusion | ||||
|   */ | ||||
| #ifndef __SYSTEM_STM32F10X_H | ||||
| #define __SYSTEM_STM32F10X_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif  | ||||
| 
 | ||||
| /** @addtogroup STM32F10x_System_Includes
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /** @addtogroup STM32F10x_System_Exported_types
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| extern uint32_t SystemCoreClock;          /*!< System Clock Frequency (Core Clock) */ | ||||
| extern const uint8_t  AHBPrescTable[16U];  /*!< AHB prescalers table values */ | ||||
| extern const uint8_t  APBPrescTable[8U];   /*!< APB prescalers table values */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32F10x_System_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32F10x_System_Exported_Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32F10x_System_Exported_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| extern void SystemInit(void); | ||||
| extern void SystemCoreClockUpdate(void); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__SYSTEM_STM32F10X_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @} | ||||
|   */   | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,332 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f100xb.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F100xB Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp                    ; Top of Stack
 | ||||
|                 DCD     Reset_Handler                   ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                     ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler               ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler               ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler                ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler              ; Usage Fault Handler
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     SVC_Handler                     ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler                ; Debug Monitor Handler
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     PendSV_Handler                  ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler                 ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler                 ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler                  ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler               ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler                  ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler                ; Flash
 | ||||
|                 DCD     RCC_IRQHandler                  ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler                ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler                ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler                ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler                ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler                ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler        ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler        ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler        ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler        ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler        ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler        ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler        ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler                 ; ADC1
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler              ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_TIM15_IRQHandler       ; TIM1 Break and TIM15
 | ||||
|                 DCD     TIM1_UP_TIM16_IRQHandler        ; TIM1 Update and TIM16
 | ||||
|                 DCD     TIM1_TRG_COM_TIM17_IRQHandler   ; TIM1 Trigger and Commutation and TIM17
 | ||||
|                 DCD     TIM1_CC_IRQHandler              ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler                 ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler                 ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler                 ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler              ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler              ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler              ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler              ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler                 ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler                 ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler               ; USART1
 | ||||
|                 DCD     USART2_IRQHandler               ; USART2
 | ||||
|                 DCD     USART3_IRQHandler               ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler            ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler             ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     CEC_IRQHandler                  ; HDMI-CEC
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved 
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved 
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     TIM6_DAC_IRQHandler             ; TIM6 and DAC underrun
 | ||||
|                 DCD     TIM7_IRQHandler                 ; TIM7
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                      [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler                 [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler               [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                      [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler                 [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler                   [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler                  [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler                  [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler                   [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler                [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler                 [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler                 [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler         [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler                  [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM1_BRK_TIM15_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_TIM16_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_TIM17_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler                  [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler                  [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler                  [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler                  [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler                  [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler                [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler                [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler                [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler             [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler              [WEAK] | ||||
|                 EXPORT  CEC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  TIM6_DAC_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler                  [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_TIM15_IRQHandler | ||||
| TIM1_UP_TIM16_IRQHandler | ||||
| TIM1_TRG_COM_TIM17_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| CEC_IRQHandler | ||||
| TIM6_DAC_IRQHandler | ||||
| TIM7_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB            | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,363 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f100xe.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F100xE Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system and also configure the external 
 | ||||
| ;*                        SRAM mounted on STM32100E-EVAL board to be used as data 
 | ||||
| ;*                        memory (optional, to be enabled by user)
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp                    ; Top of Stack
 | ||||
|                 DCD     Reset_Handler                   ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                     ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler               ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler               ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler                ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler              ; Usage Fault Handler
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     SVC_Handler                     ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler                ; Debug Monitor Handler
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     PendSV_Handler                  ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler                 ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler                 ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler                  ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler               ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler                  ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler                ; Flash
 | ||||
|                 DCD     RCC_IRQHandler                  ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler                ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler                ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler                ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler                ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler                ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler        ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler        ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler        ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler        ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler        ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler        ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler        ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler                 ; ADC1
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler              ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_TIM15_IRQHandler       ; TIM1 Break and TIM15
 | ||||
|                 DCD     TIM1_UP_TIM16_IRQHandler        ; TIM1 Update and TIM16
 | ||||
|                 DCD     TIM1_TRG_COM_TIM17_IRQHandler   ; TIM1 Trigger and Commutation and TIM17
 | ||||
|                 DCD     TIM1_CC_IRQHandler              ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler                 ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler                 ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler                 ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler              ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler              ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler              ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler              ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler                 ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler                 ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler               ; USART1
 | ||||
|                 DCD     USART2_IRQHandler               ; USART2
 | ||||
|                 DCD     USART3_IRQHandler               ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler            ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler             ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     CEC_IRQHandler                  ; HDMI CEC
 | ||||
|                 DCD     TIM12_IRQHandler                ; TIM12
 | ||||
|                 DCD     TIM13_IRQHandler                ; TIM13 
 | ||||
|                 DCD     TIM14_IRQHandler                ; TIM14
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     0                               ; Reserved
 | ||||
|                 DCD     TIM5_IRQHandler                 ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler                 ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler                ; UART4
 | ||||
|                 DCD     UART5_IRQHandler                ; UART5
 | ||||
|                 DCD     TIM6_DAC_IRQHandler             ; TIM6 and DAC underrun
 | ||||
|                 DCD     TIM7_IRQHandler                 ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler        ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler        ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler        ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_5_IRQHandler      ; DMA2 Channel4 & Channel5
 | ||||
|                 DCD     DMA2_Channel5_IRQHandler        ; DMA2 Channel5                
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                      [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler                 [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler               [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                      [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler                 [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler                   [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler                  [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler                  [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler                   [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler                [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler                 [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler                 [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler                 [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler         [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler                  [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM1_BRK_TIM15_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_TIM16_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_TIM17_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler                  [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler                  [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler                  [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler                  [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler                  [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler                [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler                [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler                [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler             [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler             [WEAK] | ||||
|                 EXPORT  CEC_IRQHandler                   [WEAK] | ||||
|                 EXPORT  TIM12_IRQHandler                 [WEAK] | ||||
|                 EXPORT  TIM13_IRQHandler                 [WEAK] | ||||
|                 EXPORT  TIM14_IRQHandler                 [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler                  [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler                  [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler                 [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler                 [WEAK] | ||||
|                 EXPORT  TIM6_DAC_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler                  [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler         [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_5_IRQHandler       [WEAK] | ||||
|                 EXPORT  DMA2_Channel5_IRQHandler         [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_TIM15_IRQHandler | ||||
| TIM1_UP_TIM16_IRQHandler | ||||
| TIM1_TRG_COM_TIM17_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| CEC_IRQHandler | ||||
| TIM12_IRQHandler | ||||
| TIM13_IRQHandler | ||||
| TIM14_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_DAC_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_5_IRQHandler | ||||
| DMA2_Channel5_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB            | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,295 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f101x6.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F101x6 Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler            ; ADC1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler routine
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler            [WEAK]             | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,305 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f101xb.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F101xB Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler            ; ADC1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler            [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB            | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,343 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f101xe.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F101xE Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
|                                                    | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler            ; ADC1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     FSMC_IRQHandler            ; FSMC
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM5_IRQHandler            ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler            ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler           ; UART4
 | ||||
|                 DCD     UART5_IRQHandler           ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler            ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler            ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler   ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler   ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler   ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_5_IRQHandler ; DMA2 Channel4 & Channel5
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
|                  | ||||
| ; Reset handler
 | ||||
| Reset_Handler   PROC | ||||
|                 EXPORT  Reset_Handler             [WEAK] | ||||
|                 IMPORT  __main | ||||
|                 IMPORT  SystemInit | ||||
|                 LDR     R0, =SystemInit | ||||
|                 BLX     R0                | ||||
|                 LDR     R0, =__main | ||||
|                 BX      R0 | ||||
|                 ENDP | ||||
|                  | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler            [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler       [WEAK] | ||||
|                 EXPORT  FSMC_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler            [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler           [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler           [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler            [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_5_IRQHandler [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| FSMC_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_5_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,355 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f101xg.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F101xG Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
|                                                    | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler               ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler                ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler             ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler                ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler              ; Flash
 | ||||
|                 DCD     RCC_IRQHandler                ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler              ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler              ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler              ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler              ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler              ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler      ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler      ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler      ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler      ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler      ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler      ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler      ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler             ; ADC1_2
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler            ; EXTI Line 9..5
 | ||||
|                 DCD     TIM9_IRQHandler               ; TIM9
 | ||||
|                 DCD     TIM10_IRQHandler              ; TIM10
 | ||||
|                 DCD     TIM11_IRQHandler              ; TIM11
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler               ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler               ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler               ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler            ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler            ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler            ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler            ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler               ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler               ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler             ; USART1
 | ||||
|                 DCD     USART2_IRQHandler             ; USART2
 | ||||
|                 DCD     USART3_IRQHandler             ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler          ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler           ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM12_IRQHandler                ; TIM12
 | ||||
|                 DCD     TIM13_IRQHandler                ; TIM13 
 | ||||
|                 DCD     TIM14_IRQHandler                ; TIM14
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     FSMC_IRQHandler               ; FSMC
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM5_IRQHandler               ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler               ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler              ; UART4
 | ||||
|                 DCD     UART5_IRQHandler              ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler               ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler               ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler      ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler      ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler      ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_5_IRQHandler    ; DMA2 Channel4 & Channel5
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
|                  | ||||
| ; Reset handler
 | ||||
| Reset_Handler   PROC | ||||
|                 EXPORT  Reset_Handler             [WEAK] | ||||
|                 IMPORT  __main | ||||
|                 IMPORT  SystemInit | ||||
|                 LDR     R0, =SystemInit | ||||
|                 BLX     R0                | ||||
|                 LDR     R0, =__main | ||||
|                 BX      R0 | ||||
|                 ENDP | ||||
|                  | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler               [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler                [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler             [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler                [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler              [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler                [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler              [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler      [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM9_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM10_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM11_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler               [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler             [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler             [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler          [WEAK] | ||||
|                 EXPORT  TIM12_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM13_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM14_IRQHandler              [WEAK] | ||||
|                 EXPORT  FSMC_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler               [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler              [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler               [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_5_IRQHandler    [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM9_IRQHandler | ||||
| TIM10_IRQHandler | ||||
| TIM11_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| TIM12_IRQHandler | ||||
| TIM13_IRQHandler | ||||
| TIM14_IRQHandler | ||||
| FSMC_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_5_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,302 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f102x6.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F102x6 Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler            ; ADC1
 | ||||
|                 DCD     USB_HP_IRQHandler          ; USB High Priority
 | ||||
|                 DCD     USB_LP_IRQHandler          ; USB Low  Priority
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler routine
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler            [WEAK] | ||||
|                 EXPORT  USB_HP_IRQHandler          [WEAK] | ||||
|                 EXPORT  USB_LP_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| USB_HP_IRQHandler | ||||
| USB_LP_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,312 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f102xb.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F102xB Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_IRQHandler            ; ADC1
 | ||||
|                 DCD     USB_HP_IRQHandler          ; USB High Priority
 | ||||
|                 DCD     USB_LP_IRQHandler          ; USB Low  Priority
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_IRQHandler            [WEAK] | ||||
|                 EXPORT  USB_HP_IRQHandler          [WEAK] | ||||
|                 EXPORT  USB_LP_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_IRQHandler | ||||
| USB_HP_IRQHandler | ||||
| USB_LP_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB            | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,314 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f103x6.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F103x6 Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler          ; ADC1_2
 | ||||
|                 DCD     USB_HP_CAN1_TX_IRQHandler  ; USB High Priority or CAN1 TX
 | ||||
|                 DCD     USB_LP_CAN1_RX0_IRQHandler ; USB Low  Priority or CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
 | ||||
|                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
 | ||||
|                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
 | ||||
|                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler routine
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USB_HP_CAN1_TX_IRQHandler  [WEAK] | ||||
|                 EXPORT  USB_LP_CAN1_RX0_IRQHandler [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| USB_HP_CAN1_TX_IRQHandler | ||||
| USB_LP_CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_IRQHandler | ||||
| TIM1_UP_IRQHandler | ||||
| TIM1_TRG_COM_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,324 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f103xb.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F103xB Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler          ; ADC1_2
 | ||||
|                 DCD     USB_HP_CAN1_TX_IRQHandler  ; USB High Priority or CAN1 TX
 | ||||
|                 DCD     USB_LP_CAN1_RX0_IRQHandler ; USB Low  Priority or CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
 | ||||
|                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
 | ||||
|                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
 | ||||
|                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|      IMPORT  __main | ||||
|      IMPORT  SystemInit | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USB_HP_CAN1_TX_IRQHandler  [WEAK] | ||||
|                 EXPORT  USB_LP_CAN1_RX0_IRQHandler [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler       [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| USB_HP_CAN1_TX_IRQHandler | ||||
| USB_LP_CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_IRQHandler | ||||
| TIM1_UP_IRQHandler | ||||
| TIM1_TRG_COM_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB            | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,373 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f103xe.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F103xE Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
|                                                    | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler          ; ADC1 & ADC2
 | ||||
|                 DCD     USB_HP_CAN1_TX_IRQHandler  ; USB High Priority or CAN1 TX
 | ||||
|                 DCD     USB_LP_CAN1_RX0_IRQHandler ; USB Low  Priority or CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
 | ||||
|                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
 | ||||
|                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
 | ||||
|                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
 | ||||
|                 DCD     TIM8_BRK_IRQHandler        ; TIM8 Break
 | ||||
|                 DCD     TIM8_UP_IRQHandler         ; TIM8 Update
 | ||||
|                 DCD     TIM8_TRG_COM_IRQHandler    ; TIM8 Trigger and Commutation
 | ||||
|                 DCD     TIM8_CC_IRQHandler         ; TIM8 Capture Compare
 | ||||
|                 DCD     ADC3_IRQHandler            ; ADC3
 | ||||
|                 DCD     FSMC_IRQHandler            ; FSMC
 | ||||
|                 DCD     SDIO_IRQHandler            ; SDIO
 | ||||
|                 DCD     TIM5_IRQHandler            ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler            ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler           ; UART4
 | ||||
|                 DCD     UART5_IRQHandler           ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler            ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler            ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler   ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler   ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler   ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_5_IRQHandler ; DMA2 Channel4 & Channel5
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
|                  | ||||
| ; Reset handler
 | ||||
| Reset_Handler   PROC | ||||
|                 EXPORT  Reset_Handler             [WEAK] | ||||
|                 IMPORT  __main | ||||
|                 IMPORT  SystemInit | ||||
|                 LDR     R0, =SystemInit | ||||
|                 BLX     R0                | ||||
|                 LDR     R0, =__main | ||||
|                 BX      R0 | ||||
|                 ENDP | ||||
|                  | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USB_HP_CAN1_TX_IRQHandler  [WEAK] | ||||
|                 EXPORT  USB_LP_CAN1_RX0_IRQHandler [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler       [WEAK] | ||||
|                 EXPORT  TIM8_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM8_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM8_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM8_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  ADC3_IRQHandler            [WEAK] | ||||
|                 EXPORT  FSMC_IRQHandler            [WEAK] | ||||
|                 EXPORT  SDIO_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler            [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler           [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler           [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler            [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_5_IRQHandler [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| USB_HP_CAN1_TX_IRQHandler | ||||
| USB_LP_CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_IRQHandler | ||||
| TIM1_UP_IRQHandler | ||||
| TIM1_TRG_COM_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| TIM8_BRK_IRQHandler | ||||
| TIM8_UP_IRQHandler | ||||
| TIM8_TRG_COM_IRQHandler | ||||
| TIM8_CC_IRQHandler | ||||
| ADC3_IRQHandler | ||||
| FSMC_IRQHandler | ||||
| SDIO_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_5_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,373 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f103xg.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F103xG Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
|                                                    | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler               ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler                ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler             ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler                ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler              ; Flash
 | ||||
|                 DCD     RCC_IRQHandler                ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler              ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler              ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler              ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler              ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler              ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler      ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler      ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler      ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler      ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler      ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler      ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler      ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler             ; ADC1 & ADC2
 | ||||
|                 DCD     USB_HP_CAN1_TX_IRQHandler     ; USB High Priority or CAN1 TX
 | ||||
|                 DCD     USB_LP_CAN1_RX0_IRQHandler    ; USB Low  Priority or CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler           ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler           ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler            ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_TIM9_IRQHandler      ; TIM1 Break and TIM9
 | ||||
|                 DCD     TIM1_UP_TIM10_IRQHandler      ; TIM1 Update and TIM10
 | ||||
|                 DCD     TIM1_TRG_COM_TIM11_IRQHandler ; TIM1 Trigger and Commutation and TIM11
 | ||||
|                 DCD     TIM1_CC_IRQHandler            ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler               ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler               ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler               ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler            ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler            ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler            ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler            ; I2C2 Error
 | ||||
|                 DCD     SPI1_IRQHandler               ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler               ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler             ; USART1
 | ||||
|                 DCD     USART2_IRQHandler             ; USART2
 | ||||
|                 DCD     USART3_IRQHandler             ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler          ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler           ; RTC Alarm through EXTI Line
 | ||||
|                 DCD     USBWakeUp_IRQHandler          ; USB Wakeup from suspend
 | ||||
|                 DCD     TIM8_BRK_TIM12_IRQHandler     ; TIM8 Break and TIM12
 | ||||
|                 DCD     TIM8_UP_TIM13_IRQHandler      ; TIM8 Update and TIM13
 | ||||
|                 DCD     TIM8_TRG_COM_TIM14_IRQHandler ; TIM8 Trigger and Commutation and TIM14
 | ||||
|                 DCD     TIM8_CC_IRQHandler            ; TIM8 Capture Compare
 | ||||
|                 DCD     ADC3_IRQHandler               ; ADC3
 | ||||
|                 DCD     FSMC_IRQHandler               ; FSMC
 | ||||
|                 DCD     SDIO_IRQHandler               ; SDIO
 | ||||
|                 DCD     TIM5_IRQHandler               ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler               ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler              ; UART4
 | ||||
|                 DCD     UART5_IRQHandler              ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler               ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler               ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler      ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler      ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler      ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_5_IRQHandler    ; DMA2 Channel4 & Channel5
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
|                  | ||||
| ; Reset handler
 | ||||
| Reset_Handler   PROC | ||||
|                 EXPORT  Reset_Handler             [WEAK] | ||||
|                 IMPORT  __main | ||||
|                 IMPORT  SystemInit | ||||
|                 LDR     R0, =SystemInit | ||||
|                 BLX     R0                | ||||
|                 LDR     R0, =__main | ||||
|                 BX      R0 | ||||
|                 ENDP | ||||
|                  | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler               [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler                [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler             [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler                [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler              [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler                [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler              [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler              [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler      [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler             [WEAK] | ||||
|                 EXPORT  USB_HP_CAN1_TX_IRQHandler     [WEAK] | ||||
|                 EXPORT  USB_LP_CAN1_RX0_IRQHandler    [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler           [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM1_BRK_TIM9_IRQHandler      [WEAK] | ||||
|                 EXPORT  TIM1_UP_TIM10_IRQHandler      [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_TIM11_IRQHandler [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler               [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler               [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler             [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler             [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler           [WEAK] | ||||
|                 EXPORT  USBWakeUp_IRQHandler          [WEAK] | ||||
|                 EXPORT  TIM8_BRK_TIM12_IRQHandler     [WEAK] | ||||
|                 EXPORT  TIM8_UP_TIM13_IRQHandler      [WEAK] | ||||
|                 EXPORT  TIM8_TRG_COM_TIM14_IRQHandler [WEAK] | ||||
|                 EXPORT  TIM8_CC_IRQHandler            [WEAK] | ||||
|                 EXPORT  ADC3_IRQHandler               [WEAK] | ||||
|                 EXPORT  FSMC_IRQHandler               [WEAK] | ||||
|                 EXPORT  SDIO_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler               [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler               [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler              [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler              [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler               [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler               [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler      [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_5_IRQHandler    [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| USB_HP_CAN1_TX_IRQHandler | ||||
| USB_LP_CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_TIM9_IRQHandler | ||||
| TIM1_UP_TIM10_IRQHandler | ||||
| TIM1_TRG_COM_TIM11_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| USBWakeUp_IRQHandler | ||||
| TIM8_BRK_TIM12_IRQHandler | ||||
| TIM8_UP_TIM13_IRQHandler | ||||
| TIM8_TRG_COM_TIM14_IRQHandler | ||||
| TIM8_CC_IRQHandler | ||||
| ADC3_IRQHandler | ||||
| FSMC_IRQHandler | ||||
| SDIO_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_5_IRQHandler | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,381 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f105xc.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F105xC Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler          ; ADC1 and ADC2
 | ||||
|                 DCD     CAN1_TX_IRQHandler         ; CAN1 TX
 | ||||
|                 DCD     CAN1_RX0_IRQHandler        ; CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
 | ||||
|                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
 | ||||
|                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
 | ||||
|                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC alarm through EXTI line
 | ||||
|                 DCD     OTG_FS_WKUP_IRQHandler     ; USB OTG FS Wakeup through EXTI line
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM5_IRQHandler            ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler            ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler           ; UART4
 | ||||
|                 DCD     UART5_IRQHandler           ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler            ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler            ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler   ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler   ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler   ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_IRQHandler   ; DMA2 Channel4
 | ||||
|                 DCD     DMA2_Channel5_IRQHandler   ; DMA2 Channel5
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     CAN2_TX_IRQHandler         ; CAN2 TX
 | ||||
|                 DCD     CAN2_RX0_IRQHandler        ; CAN2 RX0
 | ||||
|                 DCD     CAN2_RX1_IRQHandler        ; CAN2 RX1
 | ||||
|                 DCD     CAN2_SCE_IRQHandler        ; CAN2 SCE
 | ||||
|                 DCD     OTG_FS_IRQHandler          ; USB OTG FS
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|         IMPORT  SystemInit | ||||
|         IMPORT  __main | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler          [WEAK] | ||||
|                 EXPORT  CAN1_TX_IRQHandler         [WEAK] | ||||
|                 EXPORT  CAN1_RX0_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  OTG_FS_WKUP_IRQHandler     [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler            [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler           [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler           [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler            [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  CAN2_TX_IRQHandler         [WEAK] | ||||
|                 EXPORT  CAN2_RX0_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN2_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN2_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  OTG_FS_IRQHandler          [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| CAN1_TX_IRQHandler | ||||
| CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_IRQHandler | ||||
| TIM1_UP_IRQHandler | ||||
| TIM1_TRG_COM_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| OTG_FS_WKUP_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_IRQHandler | ||||
| DMA2_Channel5_IRQHandler | ||||
| CAN2_TX_IRQHandler | ||||
| CAN2_RX0_IRQHandler | ||||
| CAN2_RX1_IRQHandler | ||||
| CAN2_SCE_IRQHandler | ||||
| OTG_FS_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,385 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f107xc.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F107xC Devices vector table for MDK-ARM toolchain. 
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == Reset_Handler
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR address
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Branches to __main in the C library (which eventually
 | ||||
| ;*                        calls main()).
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;*
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;*
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;*
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ; 
 | ||||
| ;*******************************************************************************
 | ||||
| 
 | ||||
| ; Amount of memory (in bytes) allocated for Stack
 | ||||
| ; Tailor this value to your application needs
 | ||||
| ; <h> Stack Configuration
 | ||||
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Stack_Size      EQU     0x00000400 | ||||
| 
 | ||||
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3 | ||||
| Stack_Mem       SPACE   Stack_Size | ||||
| __initial_sp | ||||
| 
 | ||||
| 
 | ||||
| ; <h> Heap Configuration
 | ||||
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | ||||
| ; </h>
 | ||||
| 
 | ||||
| Heap_Size       EQU     0x00000200 | ||||
| 
 | ||||
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 | ||||
| __heap_base | ||||
| Heap_Mem        SPACE   Heap_Size | ||||
| __heap_limit | ||||
| 
 | ||||
|                 PRESERVE8 | ||||
|                 THUMB | ||||
| 
 | ||||
| 
 | ||||
| ; Vector Table Mapped to Address 0 at Reset
 | ||||
|                 AREA    RESET, DATA, READONLY | ||||
|                 EXPORT  __Vectors | ||||
|                 EXPORT  __Vectors_End | ||||
|                 EXPORT  __Vectors_Size | ||||
| 
 | ||||
| __Vectors       DCD     __initial_sp               ; Top of Stack
 | ||||
|                 DCD     Reset_Handler              ; Reset Handler
 | ||||
|                 DCD     NMI_Handler                ; NMI Handler
 | ||||
|                 DCD     HardFault_Handler          ; Hard Fault Handler
 | ||||
|                 DCD     MemManage_Handler          ; MPU Fault Handler
 | ||||
|                 DCD     BusFault_Handler           ; Bus Fault Handler
 | ||||
|                 DCD     UsageFault_Handler         ; Usage Fault Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     SVC_Handler                ; SVCall Handler
 | ||||
|                 DCD     DebugMon_Handler           ; Debug Monitor Handler
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     PendSV_Handler             ; PendSV Handler
 | ||||
|                 DCD     SysTick_Handler            ; SysTick Handler
 | ||||
| 
 | ||||
|                 ; External Interrupts
 | ||||
|                 DCD     WWDG_IRQHandler            ; Window Watchdog
 | ||||
|                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
 | ||||
|                 DCD     TAMPER_IRQHandler          ; Tamper
 | ||||
|                 DCD     RTC_IRQHandler             ; RTC
 | ||||
|                 DCD     FLASH_IRQHandler           ; Flash
 | ||||
|                 DCD     RCC_IRQHandler             ; RCC
 | ||||
|                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
 | ||||
|                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
 | ||||
|                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
 | ||||
|                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
 | ||||
|                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
 | ||||
|                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
 | ||||
|                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
 | ||||
|                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
 | ||||
|                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
 | ||||
|                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
 | ||||
|                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
 | ||||
|                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
 | ||||
|                 DCD     ADC1_2_IRQHandler          ; ADC1 and ADC2
 | ||||
|                 DCD     CAN1_TX_IRQHandler         ; CAN1 TX
 | ||||
|                 DCD     CAN1_RX0_IRQHandler        ; CAN1 RX0
 | ||||
|                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
 | ||||
|                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
 | ||||
|                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
 | ||||
|                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
 | ||||
|                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
 | ||||
|                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
 | ||||
|                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
 | ||||
|                 DCD     TIM2_IRQHandler            ; TIM2
 | ||||
|                 DCD     TIM3_IRQHandler            ; TIM3
 | ||||
|                 DCD     TIM4_IRQHandler            ; TIM4
 | ||||
|                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
 | ||||
|                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
 | ||||
|                 DCD     I2C2_ER_IRQHandler         ; I2C1 Error
 | ||||
|                 DCD     SPI1_IRQHandler            ; SPI1
 | ||||
|                 DCD     SPI2_IRQHandler            ; SPI2
 | ||||
|                 DCD     USART1_IRQHandler          ; USART1
 | ||||
|                 DCD     USART2_IRQHandler          ; USART2
 | ||||
|                 DCD     USART3_IRQHandler          ; USART3
 | ||||
|                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
 | ||||
|                 DCD     RTC_Alarm_IRQHandler        ; RTC alarm through EXTI line
 | ||||
|                 DCD     OTG_FS_WKUP_IRQHandler     ; USB OTG FS Wakeup through EXTI line
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     0                          ; Reserved
 | ||||
|                 DCD     TIM5_IRQHandler            ; TIM5
 | ||||
|                 DCD     SPI3_IRQHandler            ; SPI3
 | ||||
|                 DCD     UART4_IRQHandler           ; UART4
 | ||||
|                 DCD     UART5_IRQHandler           ; UART5
 | ||||
|                 DCD     TIM6_IRQHandler            ; TIM6
 | ||||
|                 DCD     TIM7_IRQHandler            ; TIM7
 | ||||
|                 DCD     DMA2_Channel1_IRQHandler   ; DMA2 Channel1
 | ||||
|                 DCD     DMA2_Channel2_IRQHandler   ; DMA2 Channel2
 | ||||
|                 DCD     DMA2_Channel3_IRQHandler   ; DMA2 Channel3
 | ||||
|                 DCD     DMA2_Channel4_IRQHandler   ; DMA2 Channel4
 | ||||
|                 DCD     DMA2_Channel5_IRQHandler   ; DMA2 Channel5
 | ||||
|                 DCD     ETH_IRQHandler             ; Ethernet
 | ||||
|                 DCD     ETH_WKUP_IRQHandler        ; Ethernet Wakeup through EXTI line
 | ||||
|                 DCD     CAN2_TX_IRQHandler         ; CAN2 TX
 | ||||
|                 DCD     CAN2_RX0_IRQHandler        ; CAN2 RX0
 | ||||
|                 DCD     CAN2_RX1_IRQHandler        ; CAN2 RX1
 | ||||
|                 DCD     CAN2_SCE_IRQHandler        ; CAN2 SCE
 | ||||
|                 DCD     OTG_FS_IRQHandler          ; USB OTG FS
 | ||||
| __Vectors_End | ||||
| 
 | ||||
| __Vectors_Size  EQU  __Vectors_End - __Vectors | ||||
| 
 | ||||
|                 AREA    |.text|, CODE, READONLY | ||||
| 
 | ||||
| ; Reset handler
 | ||||
| Reset_Handler    PROC | ||||
|                  EXPORT  Reset_Handler             [WEAK] | ||||
|         IMPORT  SystemInit | ||||
|         IMPORT  __main | ||||
|                  LDR     R0, =SystemInit | ||||
|                  BLX     R0 | ||||
|                  LDR     R0, =__main | ||||
|                  BX      R0 | ||||
|                  ENDP | ||||
| 
 | ||||
| ; Dummy Exception Handlers (infinite loops which can be modified)
 | ||||
| 
 | ||||
| NMI_Handler     PROC | ||||
|                 EXPORT  NMI_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| HardFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  HardFault_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| MemManage_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  MemManage_Handler          [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| BusFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  BusFault_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| UsageFault_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  UsageFault_Handler         [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SVC_Handler     PROC | ||||
|                 EXPORT  SVC_Handler                [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| DebugMon_Handler\ | ||||
|                 PROC | ||||
|                 EXPORT  DebugMon_Handler           [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| PendSV_Handler  PROC | ||||
|                 EXPORT  PendSV_Handler             [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| SysTick_Handler PROC | ||||
|                 EXPORT  SysTick_Handler            [WEAK] | ||||
|                 B       . | ||||
|                 ENDP | ||||
| 
 | ||||
| Default_Handler PROC | ||||
| 
 | ||||
|                 EXPORT  WWDG_IRQHandler            [WEAK] | ||||
|                 EXPORT  PVD_IRQHandler             [WEAK] | ||||
|                 EXPORT  TAMPER_IRQHandler          [WEAK] | ||||
|                 EXPORT  RTC_IRQHandler             [WEAK] | ||||
|                 EXPORT  FLASH_IRQHandler           [WEAK] | ||||
|                 EXPORT  RCC_IRQHandler             [WEAK] | ||||
|                 EXPORT  EXTI0_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI1_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI2_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI3_IRQHandler           [WEAK] | ||||
|                 EXPORT  EXTI4_IRQHandler           [WEAK] | ||||
|                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK] | ||||
|                 EXPORT  ADC1_2_IRQHandler          [WEAK] | ||||
|                 EXPORT  CAN1_TX_IRQHandler         [WEAK] | ||||
|                 EXPORT  CAN1_RX0_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN1_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  EXTI9_5_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_BRK_IRQHandler        [WEAK] | ||||
|                 EXPORT  TIM1_UP_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK] | ||||
|                 EXPORT  TIM1_CC_IRQHandler         [WEAK] | ||||
|                 EXPORT  TIM2_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM3_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM4_IRQHandler            [WEAK] | ||||
|                 EXPORT  I2C1_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C1_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_EV_IRQHandler         [WEAK] | ||||
|                 EXPORT  I2C2_ER_IRQHandler         [WEAK] | ||||
|                 EXPORT  SPI1_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI2_IRQHandler            [WEAK] | ||||
|                 EXPORT  USART1_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART2_IRQHandler          [WEAK] | ||||
|                 EXPORT  USART3_IRQHandler          [WEAK] | ||||
|                 EXPORT  EXTI15_10_IRQHandler       [WEAK] | ||||
|                 EXPORT  RTC_Alarm_IRQHandler        [WEAK] | ||||
|                 EXPORT  OTG_FS_WKUP_IRQHandler     [WEAK] | ||||
|                 EXPORT  TIM5_IRQHandler            [WEAK] | ||||
|                 EXPORT  SPI3_IRQHandler            [WEAK] | ||||
|                 EXPORT  UART4_IRQHandler           [WEAK] | ||||
|                 EXPORT  UART5_IRQHandler           [WEAK] | ||||
|                 EXPORT  TIM6_IRQHandler            [WEAK] | ||||
|                 EXPORT  TIM7_IRQHandler            [WEAK] | ||||
|                 EXPORT  DMA2_Channel1_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel2_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel3_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel4_IRQHandler   [WEAK] | ||||
|                 EXPORT  DMA2_Channel5_IRQHandler   [WEAK] | ||||
|                 EXPORT  ETH_IRQHandler             [WEAK] | ||||
|                 EXPORT  ETH_WKUP_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN2_TX_IRQHandler         [WEAK] | ||||
|                 EXPORT  CAN2_RX0_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN2_RX1_IRQHandler        [WEAK] | ||||
|                 EXPORT  CAN2_SCE_IRQHandler        [WEAK] | ||||
|                 EXPORT  OTG_FS_IRQHandler          [WEAK] | ||||
| 
 | ||||
| WWDG_IRQHandler | ||||
| PVD_IRQHandler | ||||
| TAMPER_IRQHandler | ||||
| RTC_IRQHandler | ||||
| FLASH_IRQHandler | ||||
| RCC_IRQHandler | ||||
| EXTI0_IRQHandler | ||||
| EXTI1_IRQHandler | ||||
| EXTI2_IRQHandler | ||||
| EXTI3_IRQHandler | ||||
| EXTI4_IRQHandler | ||||
| DMA1_Channel1_IRQHandler | ||||
| DMA1_Channel2_IRQHandler | ||||
| DMA1_Channel3_IRQHandler | ||||
| DMA1_Channel4_IRQHandler | ||||
| DMA1_Channel5_IRQHandler | ||||
| DMA1_Channel6_IRQHandler | ||||
| DMA1_Channel7_IRQHandler | ||||
| ADC1_2_IRQHandler | ||||
| CAN1_TX_IRQHandler | ||||
| CAN1_RX0_IRQHandler | ||||
| CAN1_RX1_IRQHandler | ||||
| CAN1_SCE_IRQHandler | ||||
| EXTI9_5_IRQHandler | ||||
| TIM1_BRK_IRQHandler | ||||
| TIM1_UP_IRQHandler | ||||
| TIM1_TRG_COM_IRQHandler | ||||
| TIM1_CC_IRQHandler | ||||
| TIM2_IRQHandler | ||||
| TIM3_IRQHandler | ||||
| TIM4_IRQHandler | ||||
| I2C1_EV_IRQHandler | ||||
| I2C1_ER_IRQHandler | ||||
| I2C2_EV_IRQHandler | ||||
| I2C2_ER_IRQHandler | ||||
| SPI1_IRQHandler | ||||
| SPI2_IRQHandler | ||||
| USART1_IRQHandler | ||||
| USART2_IRQHandler | ||||
| USART3_IRQHandler | ||||
| EXTI15_10_IRQHandler | ||||
| RTC_Alarm_IRQHandler | ||||
| OTG_FS_WKUP_IRQHandler | ||||
| TIM5_IRQHandler | ||||
| SPI3_IRQHandler | ||||
| UART4_IRQHandler | ||||
| UART5_IRQHandler | ||||
| TIM6_IRQHandler | ||||
| TIM7_IRQHandler | ||||
| DMA2_Channel1_IRQHandler | ||||
| DMA2_Channel2_IRQHandler | ||||
| DMA2_Channel3_IRQHandler | ||||
| DMA2_Channel4_IRQHandler | ||||
| DMA2_Channel5_IRQHandler | ||||
| ETH_IRQHandler | ||||
| ETH_WKUP_IRQHandler | ||||
| CAN2_TX_IRQHandler | ||||
| CAN2_RX0_IRQHandler | ||||
| CAN2_RX1_IRQHandler | ||||
| CAN2_SCE_IRQHandler | ||||
| OTG_FS_IRQHandler | ||||
| 
 | ||||
|                 B       . | ||||
| 
 | ||||
|                 ENDP | ||||
| 
 | ||||
|                 ALIGN | ||||
| 
 | ||||
| ;*******************************************************************************
 | ||||
| ; User Stack and Heap initialization
 | ||||
| ;*******************************************************************************
 | ||||
|                  IF      :DEF:__MICROLIB | ||||
|                  | ||||
|                  EXPORT  __initial_sp | ||||
|                  EXPORT  __heap_base | ||||
|                  EXPORT  __heap_limit | ||||
|                  | ||||
|                  ELSE | ||||
|                  | ||||
|                  IMPORT  __use_two_region_memory | ||||
|                  EXPORT  __user_initial_stackheap | ||||
|                   | ||||
| __user_initial_stackheap | ||||
| 
 | ||||
|                  LDR     R0, =  Heap_Mem | ||||
|                  LDR     R1, =(Stack_Mem + Stack_Size) | ||||
|                  LDR     R2, = (Heap_Mem +  Heap_Size) | ||||
|                  LDR     R3, = Stack_Mem | ||||
|                  BX      LR | ||||
| 
 | ||||
|                  ALIGN | ||||
| 
 | ||||
|                  ENDIF | ||||
| 
 | ||||
|                  END | ||||
| 
 | ||||
| ;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****
 | ||||
|  | @ -1,422 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f100xb.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F100xB Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_TIM15_IRQHandler
 | ||||
|   .word TIM1_UP_TIM16_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_TIM17_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word CEC_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM6_DAC_IRQHandler
 | ||||
|   .word TIM7_IRQHandler   | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM          /* @0x01CC. This is for boot in RAM mode for 
 | ||||
|                             STM32F10xB Value Line devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|      | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
|    | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
|    | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
|    | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_BRK_TIM15_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_UP_TIM16_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_TRG_COM_TIM17_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
|    | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|    | ||||
|   .weak  I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
|    | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
|    | ||||
|   .weak  USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CEC_IRQHandler
 | ||||
|   .thumb_set CEC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM6_DAC_IRQHandler
 | ||||
|   .thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler   | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,464 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f100xe.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F100xE Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_TIM15_IRQHandler
 | ||||
|   .word TIM1_UP_TIM16_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_TIM17_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word CEC_IRQHandler
 | ||||
|   .word TIM12_IRQHandler
 | ||||
|   .word TIM13_IRQHandler
 | ||||
|   .word TIM14_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM5_IRQHandler
 | ||||
|   .word SPI3_IRQHandler
 | ||||
|   .word UART4_IRQHandler
 | ||||
|   .word UART5_IRQHandler
 | ||||
|   .word TIM6_DAC_IRQHandler
 | ||||
|   .word TIM7_IRQHandler   | ||||
|   .word DMA2_Channel1_IRQHandler
 | ||||
|   .word DMA2_Channel2_IRQHandler
 | ||||
|   .word DMA2_Channel3_IRQHandler
 | ||||
|   .word DMA2_Channel4_5_IRQHandler
 | ||||
|   .word DMA2_Channel5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word  BootRAM       /* @0x1E0. This is for boot in RAM mode for 
 | ||||
|                          STM32F10x High Density Value line devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|      | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
|    | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
|    | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
|    | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_BRK_TIM15_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_UP_TIM16_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_TRG_COM_TIM17_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CEC_IRQHandler
 | ||||
|   .thumb_set CEC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM12_IRQHandler
 | ||||
|   .thumb_set TIM12_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM13_IRQHandler
 | ||||
|   .thumb_set TIM13_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM14_IRQHandler
 | ||||
|   .thumb_set TIM14_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
|    | ||||
|   .weak  TIM6_DAC_IRQHandler
 | ||||
|   .thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler  | ||||
| 
 | ||||
|   .weak  DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel4_5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler   | ||||
| 
 | ||||
|   .weak  DMA2_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|    | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,337 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f101x6.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F101x6 Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM        /* @0x108. This is for boot in RAM mode for
 | ||||
|                           STM32F10x Low Density devices.*/ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,353 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f101xb.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F101xB Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM          /* @0x108. This is for boot in RAM mode for
 | ||||
|                             STM32F10x Medium Density devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,438 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f101xe.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F101xE Value Line Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word FSMC_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word TIM5_IRQHandler
 | ||||
|   .word SPI3_IRQHandler
 | ||||
|   .word UART4_IRQHandler
 | ||||
|   .word UART5_IRQHandler
 | ||||
|   .word TIM6_IRQHandler
 | ||||
|   .word TIM7_IRQHandler
 | ||||
|   .word DMA2_Channel1_IRQHandler
 | ||||
|   .word DMA2_Channel2_IRQHandler
 | ||||
|   .word DMA2_Channel3_IRQHandler
 | ||||
|   .word DMA2_Channel4_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM       /* @0x1E0. This is for boot in RAM mode for
 | ||||
|                          STM32F10x High Density devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FSMC_IRQHandler
 | ||||
|   .thumb_set FSMC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel4_5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,454 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f101xg.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F101xG Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * @param  None
 | ||||
|  * @retval None       
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word  _estack
 | ||||
|   .word  Reset_Handler
 | ||||
|   .word  NMI_Handler
 | ||||
|   .word  HardFault_Handler
 | ||||
|   .word  MemManage_Handler
 | ||||
|   .word  BusFault_Handler
 | ||||
|   .word  UsageFault_Handler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  SVC_Handler
 | ||||
|   .word  DebugMon_Handler
 | ||||
|   .word  0
 | ||||
|   .word  PendSV_Handler
 | ||||
|   .word  SysTick_Handler
 | ||||
|   .word  WWDG_IRQHandler
 | ||||
|   .word  PVD_IRQHandler
 | ||||
|   .word  TAMPER_IRQHandler
 | ||||
|   .word  RTC_IRQHandler
 | ||||
|   .word  FLASH_IRQHandler
 | ||||
|   .word  RCC_IRQHandler
 | ||||
|   .word  EXTI0_IRQHandler
 | ||||
|   .word  EXTI1_IRQHandler
 | ||||
|   .word  EXTI2_IRQHandler
 | ||||
|   .word  EXTI3_IRQHandler
 | ||||
|   .word  EXTI4_IRQHandler
 | ||||
|   .word  DMA1_Channel1_IRQHandler
 | ||||
|   .word  DMA1_Channel2_IRQHandler
 | ||||
|   .word  DMA1_Channel3_IRQHandler
 | ||||
|   .word  DMA1_Channel4_IRQHandler
 | ||||
|   .word  DMA1_Channel5_IRQHandler
 | ||||
|   .word  DMA1_Channel6_IRQHandler
 | ||||
|   .word  DMA1_Channel7_IRQHandler
 | ||||
|   .word  ADC1_2_IRQHandler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  EXTI9_5_IRQHandler
 | ||||
|   .word  TIM9_IRQHandler
 | ||||
|   .word  TIM10_IRQHandler
 | ||||
|   .word  TIM11_IRQHandler
 | ||||
|   .word  0
 | ||||
|   .word  TIM2_IRQHandler
 | ||||
|   .word  TIM3_IRQHandler
 | ||||
|   .word  TIM4_IRQHandler
 | ||||
|   .word  I2C1_EV_IRQHandler
 | ||||
|   .word  I2C1_ER_IRQHandler
 | ||||
|   .word  I2C2_EV_IRQHandler
 | ||||
|   .word  I2C2_ER_IRQHandler
 | ||||
|   .word  SPI1_IRQHandler
 | ||||
|   .word  SPI2_IRQHandler
 | ||||
|   .word  USART1_IRQHandler
 | ||||
|   .word  USART2_IRQHandler
 | ||||
|   .word  USART3_IRQHandler
 | ||||
|   .word  EXTI15_10_IRQHandler
 | ||||
|   .word  RTC_Alarm_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word TIM12_IRQHandler
 | ||||
|   .word TIM13_IRQHandler
 | ||||
|   .word TIM14_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word  FSMC_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word  TIM5_IRQHandler
 | ||||
|   .word  SPI3_IRQHandler
 | ||||
|   .word  UART4_IRQHandler
 | ||||
|   .word  UART5_IRQHandler
 | ||||
|   .word  TIM6_IRQHandler
 | ||||
|   .word  TIM7_IRQHandler
 | ||||
|   .word  DMA2_Channel1_IRQHandler
 | ||||
|   .word  DMA2_Channel2_IRQHandler
 | ||||
|   .word  DMA2_Channel3_IRQHandler
 | ||||
|   .word  DMA2_Channel4_5_IRQHandler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  BootRAM       /* @0x1E0. This is for boot in RAM mode for 
 | ||||
|                          STM32F10x XL-Density devices. */ | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler.  | ||||
| * As they are weak aliases, any function with the same name will override  | ||||
| * this definition. | ||||
| *  | ||||
| *******************************************************************************/ | ||||
|      | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
|    | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
|    | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
|    | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM9_IRQHandler
 | ||||
|   .thumb_set TIM9_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM10_IRQHandler
 | ||||
|   .thumb_set TIM10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM11_IRQHandler
 | ||||
|   .thumb_set TIM11_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM12_IRQHandler
 | ||||
|   .thumb_set TIM12_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM13_IRQHandler
 | ||||
|   .thumb_set TIM13_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM14_IRQHandler
 | ||||
|   .thumb_set TIM14_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FSMC_IRQHandler
 | ||||
|   .thumb_set FSMC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel4_5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,345 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f102x6.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F102x6 Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word USB_HP_IRQHandler
 | ||||
|   .word USB_LP_IRQHandler
 | ||||
|   .word 0  | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word USBWakeUp_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM        /* @0x108. This is for boot in RAM mode for
 | ||||
|                           STM32F10x Low Density devices.*/ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_HP_IRQHandler
 | ||||
|   .thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_LP_IRQHandler
 | ||||
|   .thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,361 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f102xb.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F102xB Value Line Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_IRQHandler
 | ||||
|   .word USB_HP_IRQHandler
 | ||||
|   .word USB_LP_IRQHandler
 | ||||
|   .word 0  | ||||
|   .word 0
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word USBWakeUp_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM          /* @0x108. This is for boot in RAM mode for
 | ||||
|                             STM32F10x Medium Density devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_IRQHandler
 | ||||
|   .thumb_set ADC1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_HP_IRQHandler
 | ||||
|   .thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_LP_IRQHandler
 | ||||
|   .thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,363 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f103x6.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F103x6 Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_2_IRQHandler
 | ||||
|   .word USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .word USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .word CAN1_RX1_IRQHandler
 | ||||
|   .word CAN1_SCE_IRQHandler
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_IRQHandler
 | ||||
|   .word TIM1_UP_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word USBWakeUp_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM        /* @0x108. This is for boot in RAM mode for
 | ||||
|                           STM32F10x Low Density devices.*/ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .thumb_set USB_HP_CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set USB_LP_CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_BRK_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_UP_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,379 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f103xb.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F103xB Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF108F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_2_IRQHandler
 | ||||
|   .word USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .word USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .word CAN1_RX1_IRQHandler
 | ||||
|   .word CAN1_SCE_IRQHandler
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_IRQHandler
 | ||||
|   .word TIM1_UP_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word USBWakeUp_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM          /* @0x108. This is for boot in RAM mode for
 | ||||
|                             STM32F10x Medium Density devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .thumb_set USB_HP_CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set USB_LP_CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_BRK_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_UP_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,485 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f103xe.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F103xE Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Configure external SRAM mounted on STM3210E-EVAL board | ||||
|   *                  to be used as data memory (optional, to be enabled by user) | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_2_IRQHandler
 | ||||
|   .word USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .word USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .word CAN1_RX1_IRQHandler
 | ||||
|   .word CAN1_SCE_IRQHandler
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_IRQHandler
 | ||||
|   .word TIM1_UP_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word USBWakeUp_IRQHandler
 | ||||
|   .word TIM8_BRK_IRQHandler
 | ||||
|   .word TIM8_UP_IRQHandler
 | ||||
|   .word TIM8_TRG_COM_IRQHandler
 | ||||
|   .word TIM8_CC_IRQHandler
 | ||||
|   .word ADC3_IRQHandler
 | ||||
|   .word FSMC_IRQHandler
 | ||||
|   .word SDIO_IRQHandler
 | ||||
|   .word TIM5_IRQHandler
 | ||||
|   .word SPI3_IRQHandler
 | ||||
|   .word UART4_IRQHandler
 | ||||
|   .word UART5_IRQHandler
 | ||||
|   .word TIM6_IRQHandler
 | ||||
|   .word TIM7_IRQHandler
 | ||||
|   .word DMA2_Channel1_IRQHandler
 | ||||
|   .word DMA2_Channel2_IRQHandler
 | ||||
|   .word DMA2_Channel3_IRQHandler
 | ||||
|   .word DMA2_Channel4_5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM       /* @0x1E0. This is for boot in RAM mode for
 | ||||
|                          STM32F10x High Density devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
| 
 | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .thumb_set USB_HP_CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set USB_LP_CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_BRK_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_UP_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM8_BRK_IRQHandler
 | ||||
|   .thumb_set TIM8_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM8_UP_IRQHandler
 | ||||
|   .thumb_set TIM8_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM8_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM8_CC_IRQHandler
 | ||||
|   .thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak ADC3_IRQHandler
 | ||||
|   .thumb_set ADC3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FSMC_IRQHandler
 | ||||
|   .thumb_set FSMC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SDIO_IRQHandler
 | ||||
|   .thumb_set SDIO_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel4_5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,482 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f103xb.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F103xB Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| 
 | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * @param  None
 | ||||
|  * @retval None       
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word  _estack
 | ||||
|   .word  Reset_Handler
 | ||||
|   .word  NMI_Handler
 | ||||
|   .word  HardFault_Handler
 | ||||
|   .word  MemManage_Handler
 | ||||
|   .word  BusFault_Handler
 | ||||
|   .word  UsageFault_Handler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  SVC_Handler
 | ||||
|   .word  DebugMon_Handler
 | ||||
|   .word  0
 | ||||
|   .word  PendSV_Handler
 | ||||
|   .word  SysTick_Handler
 | ||||
|   .word  WWDG_IRQHandler
 | ||||
|   .word  PVD_IRQHandler
 | ||||
|   .word  TAMPER_IRQHandler
 | ||||
|   .word  RTC_IRQHandler
 | ||||
|   .word  FLASH_IRQHandler
 | ||||
|   .word  RCC_IRQHandler
 | ||||
|   .word  EXTI0_IRQHandler
 | ||||
|   .word  EXTI1_IRQHandler
 | ||||
|   .word  EXTI2_IRQHandler
 | ||||
|   .word  EXTI3_IRQHandler
 | ||||
|   .word  EXTI4_IRQHandler
 | ||||
|   .word  DMA1_Channel1_IRQHandler
 | ||||
|   .word  DMA1_Channel2_IRQHandler
 | ||||
|   .word  DMA1_Channel3_IRQHandler
 | ||||
|   .word  DMA1_Channel4_IRQHandler
 | ||||
|   .word  DMA1_Channel5_IRQHandler
 | ||||
|   .word  DMA1_Channel6_IRQHandler
 | ||||
|   .word  DMA1_Channel7_IRQHandler
 | ||||
|   .word  ADC1_2_IRQHandler
 | ||||
|   .word  USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .word  USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .word  CAN1_RX1_IRQHandler
 | ||||
|   .word  CAN1_SCE_IRQHandler
 | ||||
|   .word  EXTI9_5_IRQHandler
 | ||||
|   .word  TIM1_BRK_TIM9_IRQHandler
 | ||||
|   .word  TIM1_UP_TIM10_IRQHandler
 | ||||
|   .word  TIM1_TRG_COM_TIM11_IRQHandler
 | ||||
|   .word  TIM1_CC_IRQHandler
 | ||||
|   .word  TIM2_IRQHandler
 | ||||
|   .word  TIM3_IRQHandler
 | ||||
|   .word  TIM4_IRQHandler
 | ||||
|   .word  I2C1_EV_IRQHandler
 | ||||
|   .word  I2C1_ER_IRQHandler
 | ||||
|   .word  I2C2_EV_IRQHandler
 | ||||
|   .word  I2C2_ER_IRQHandler
 | ||||
|   .word  SPI1_IRQHandler
 | ||||
|   .word  SPI2_IRQHandler
 | ||||
|   .word  USART1_IRQHandler
 | ||||
|   .word  USART2_IRQHandler
 | ||||
|   .word  USART3_IRQHandler
 | ||||
|   .word  EXTI15_10_IRQHandler
 | ||||
|   .word  RTC_Alarm_IRQHandler
 | ||||
|   .word  USBWakeUp_IRQHandler
 | ||||
|   .word  TIM8_BRK_TIM12_IRQHandler
 | ||||
|   .word  TIM8_UP_TIM13_IRQHandler
 | ||||
|   .word  TIM8_TRG_COM_TIM14_IRQHandler
 | ||||
|   .word  TIM8_CC_IRQHandler
 | ||||
|   .word  ADC3_IRQHandler
 | ||||
|   .word  FSMC_IRQHandler
 | ||||
|   .word  SDIO_IRQHandler
 | ||||
|   .word  TIM5_IRQHandler
 | ||||
|   .word  SPI3_IRQHandler
 | ||||
|   .word  UART4_IRQHandler
 | ||||
|   .word  UART5_IRQHandler
 | ||||
|   .word  TIM6_IRQHandler
 | ||||
|   .word  TIM7_IRQHandler
 | ||||
|   .word  DMA2_Channel1_IRQHandler
 | ||||
|   .word  DMA2_Channel2_IRQHandler
 | ||||
|   .word  DMA2_Channel3_IRQHandler
 | ||||
|   .word  DMA2_Channel4_5_IRQHandler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  BootRAM       /* @0x1E0. This is for boot in RAM mode for 
 | ||||
|                          STM32F10x XL-Density devices. */ | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler.  | ||||
| * As they are weak aliases, any function with the same name will override  | ||||
| * this definition. | ||||
| *  | ||||
| *******************************************************************************/ | ||||
|      | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
|    | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
|    | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
|    | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USB_HP_CAN1_TX_IRQHandler
 | ||||
|   .thumb_set USB_HP_CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USB_LP_CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set USB_LP_CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_BRK_TIM9_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_TIM9_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_UP_TIM10_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_TIM10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_TRG_COM_TIM11_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_TIM11_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USBWakeUp_IRQHandler
 | ||||
|   .thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM8_BRK_TIM12_IRQHandler
 | ||||
|   .thumb_set TIM8_BRK_TIM12_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM8_UP_TIM13_IRQHandler
 | ||||
|   .thumb_set TIM8_UP_TIM13_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM8_TRG_COM_TIM14_IRQHandler
 | ||||
|   .thumb_set TIM8_TRG_COM_TIM14_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM8_CC_IRQHandler
 | ||||
|   .thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC3_IRQHandler
 | ||||
|   .thumb_set ADC3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FSMC_IRQHandler
 | ||||
|   .thumb_set FSMC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SDIO_IRQHandler
 | ||||
|   .thumb_set SDIO_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel4_5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,476 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f105xc.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F105xC Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| 
 | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * @param  None
 | ||||
|  * @retval None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_2_IRQHandler
 | ||||
|   .word CAN1_TX_IRQHandler
 | ||||
|   .word CAN1_RX0_IRQHandler
 | ||||
|    .word CAN1_RX1_IRQHandler
 | ||||
|   .word CAN1_SCE_IRQHandler
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_IRQHandler
 | ||||
|   .word TIM1_UP_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word OTG_FS_WKUP_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM5_IRQHandler
 | ||||
|   .word SPI3_IRQHandler
 | ||||
|   .word UART4_IRQHandler
 | ||||
|   .word UART5_IRQHandler
 | ||||
|   .word TIM6_IRQHandler
 | ||||
|   .word TIM7_IRQHandler
 | ||||
|   .word DMA2_Channel1_IRQHandler
 | ||||
|   .word DMA2_Channel2_IRQHandler
 | ||||
|   .word DMA2_Channel3_IRQHandler
 | ||||
|   .word DMA2_Channel4_IRQHandler
 | ||||
|   .word DMA2_Channel5_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word CAN2_TX_IRQHandler
 | ||||
|   .word CAN2_RX0_IRQHandler
 | ||||
|   .word CAN2_RX1_IRQHandler
 | ||||
|   .word CAN2_SCE_IRQHandler
 | ||||
|   .word OTG_FS_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM     /* @0x1E0. This is for boot in RAM mode for
 | ||||
|                          STM32F10x Connectivity line Devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|   .weak NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_TX_IRQHandler
 | ||||
|   .thumb_set CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_BRK_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_UP_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak OTG_FS_WKUP_IRQHandler
 | ||||
|   .thumb_set OTG_FS_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak DMA2_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN2_TX_IRQHandler
 | ||||
|   .thumb_set CAN2_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN2_RX0_IRQHandler
 | ||||
|   .thumb_set CAN2_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN2_RX1_IRQHandler
 | ||||
|   .thumb_set CAN2_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak CAN2_SCE_IRQHandler
 | ||||
|   .thumb_set CAN2_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak OTG_FS_IRQHandler
 | ||||
|   .thumb_set OTG_FS_IRQHandler ,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,487 +0,0 @@ | |||
| /** | ||||
|   *************** (C) COPYRIGHT 2017 STMicroelectronics ************************ | ||||
|   * @file      startup_stm32f107xc.s
 | ||||
|   * @author    MCD Application Team
 | ||||
|   * @version   V4.2.0
 | ||||
|   * @date      31-March-2017
 | ||||
|   * @brief     STM32F107xC Devices vector table for Atollic toolchain.
 | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address | ||||
|   *                - Configure the clock system    | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M3 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m3 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global g_pfnVectors
 | ||||
| .global Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word _ebss
 | ||||
| 
 | ||||
| .equ  BootRAM, 0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
| 
 | ||||
|   .section .text.Reset_Handler | ||||
|   .weak Reset_Handler
 | ||||
|   .type Reset_Handler, %function | ||||
| Reset_Handler: | ||||
| 
 | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs r1, #0 | ||||
|   b LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr r3, =_sidata | ||||
|   ldr r3, [r3, r1] | ||||
|   str r3, [r0, r1] | ||||
|   adds r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr r0, =_sdata | ||||
|   ldr r3, =_edata | ||||
|   adds r2, r0, r1 | ||||
|   cmp r2, r3 | ||||
|   bcc CopyDataInit | ||||
|   ldr r2, =_sbss | ||||
|   b LoopFillZerobss | ||||
| 
 | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs r3, #0 | ||||
|   str r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr r3, = _ebss | ||||
|   cmp r2, r3 | ||||
|   bcc FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl main | ||||
|   bx lr | ||||
| .size Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None
 | ||||
|  * @retval : None
 | ||||
| */ | ||||
|     .section .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b Infinite_Loop | ||||
|   .size Default_Handler, .-Default_Handler | ||||
| 
 | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|   .section .isr_vector,"a",%progbits | ||||
|   .type g_pfnVectors, %object | ||||
|   .size g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
| 
 | ||||
|   .word _estack
 | ||||
|   .word Reset_Handler
 | ||||
|   .word NMI_Handler
 | ||||
|   .word HardFault_Handler
 | ||||
|   .word MemManage_Handler
 | ||||
|   .word BusFault_Handler
 | ||||
|   .word UsageFault_Handler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word SVC_Handler
 | ||||
|   .word DebugMon_Handler
 | ||||
|   .word 0
 | ||||
|   .word PendSV_Handler
 | ||||
|   .word SysTick_Handler
 | ||||
|   .word WWDG_IRQHandler
 | ||||
|   .word PVD_IRQHandler
 | ||||
|   .word TAMPER_IRQHandler
 | ||||
|   .word RTC_IRQHandler
 | ||||
|   .word FLASH_IRQHandler
 | ||||
|   .word RCC_IRQHandler
 | ||||
|   .word EXTI0_IRQHandler
 | ||||
|   .word EXTI1_IRQHandler
 | ||||
|   .word EXTI2_IRQHandler
 | ||||
|   .word EXTI3_IRQHandler
 | ||||
|   .word EXTI4_IRQHandler
 | ||||
|   .word DMA1_Channel1_IRQHandler
 | ||||
|   .word DMA1_Channel2_IRQHandler
 | ||||
|   .word DMA1_Channel3_IRQHandler
 | ||||
|   .word DMA1_Channel4_IRQHandler
 | ||||
|   .word DMA1_Channel5_IRQHandler
 | ||||
|   .word DMA1_Channel6_IRQHandler
 | ||||
|   .word DMA1_Channel7_IRQHandler
 | ||||
|   .word ADC1_2_IRQHandler
 | ||||
|   .word CAN1_TX_IRQHandler
 | ||||
|   .word CAN1_RX0_IRQHandler
 | ||||
|   .word CAN1_RX1_IRQHandler
 | ||||
|   .word CAN1_SCE_IRQHandler
 | ||||
|   .word EXTI9_5_IRQHandler
 | ||||
|   .word TIM1_BRK_IRQHandler
 | ||||
|   .word TIM1_UP_IRQHandler
 | ||||
|   .word TIM1_TRG_COM_IRQHandler
 | ||||
|   .word TIM1_CC_IRQHandler
 | ||||
|   .word TIM2_IRQHandler
 | ||||
|   .word TIM3_IRQHandler
 | ||||
|   .word TIM4_IRQHandler
 | ||||
|   .word I2C1_EV_IRQHandler
 | ||||
|   .word I2C1_ER_IRQHandler
 | ||||
|   .word I2C2_EV_IRQHandler
 | ||||
|   .word I2C2_ER_IRQHandler
 | ||||
|   .word SPI1_IRQHandler
 | ||||
|   .word SPI2_IRQHandler
 | ||||
|   .word USART1_IRQHandler
 | ||||
|   .word USART2_IRQHandler
 | ||||
|   .word USART3_IRQHandler
 | ||||
|   .word EXTI15_10_IRQHandler
 | ||||
|   .word RTC_Alarm_IRQHandler
 | ||||
|   .word OTG_FS_WKUP_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word TIM5_IRQHandler
 | ||||
|   .word SPI3_IRQHandler
 | ||||
|   .word UART4_IRQHandler
 | ||||
|   .word UART5_IRQHandler
 | ||||
|   .word TIM6_IRQHandler
 | ||||
|   .word TIM7_IRQHandler
 | ||||
|   .word DMA2_Channel1_IRQHandler
 | ||||
|   .word DMA2_Channel2_IRQHandler
 | ||||
|   .word DMA2_Channel3_IRQHandler
 | ||||
|   .word DMA2_Channel4_IRQHandler
 | ||||
|   .word DMA2_Channel5_IRQHandler
 | ||||
|   .word ETH_IRQHandler
 | ||||
|   .word ETH_WKUP_IRQHandler
 | ||||
|   .word CAN2_TX_IRQHandler
 | ||||
|   .word CAN2_RX0_IRQHandler
 | ||||
|   .word CAN2_RX1_IRQHandler
 | ||||
|   .word CAN2_SCE_IRQHandler
 | ||||
|   .word OTG_FS_IRQHandler
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word 0
 | ||||
|   .word BootRAM     /* @0x1E0. This is for boot in RAM mode for
 | ||||
|                          STM32F10x Connectivity line Devices. */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|   .weak  NMI_Handler
 | ||||
|   .thumb_set NMI_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  HardFault_Handler
 | ||||
|   .thumb_set HardFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  MemManage_Handler
 | ||||
|   .thumb_set MemManage_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  BusFault_Handler
 | ||||
|   .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  UsageFault_Handler
 | ||||
|   .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SVC_Handler
 | ||||
|   .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  DebugMon_Handler
 | ||||
|   .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  PendSV_Handler
 | ||||
|   .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  SysTick_Handler
 | ||||
|   .thumb_set SysTick_Handler,Default_Handler | ||||
| 
 | ||||
|   .weak  WWDG_IRQHandler
 | ||||
|   .thumb_set WWDG_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  PVD_IRQHandler
 | ||||
|   .thumb_set PVD_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TAMPER_IRQHandler
 | ||||
|   .thumb_set TAMPER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_IRQHandler
 | ||||
|   .thumb_set RTC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  FLASH_IRQHandler
 | ||||
|   .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RCC_IRQHandler
 | ||||
|   .thumb_set RCC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI0_IRQHandler
 | ||||
|   .thumb_set EXTI0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI1_IRQHandler
 | ||||
|   .thumb_set EXTI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI2_IRQHandler
 | ||||
|   .thumb_set EXTI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI3_IRQHandler
 | ||||
|   .thumb_set EXTI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI4_IRQHandler
 | ||||
|   .thumb_set EXTI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel6_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA1_Channel7_IRQHandler
 | ||||
|   .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ADC1_2_IRQHandler
 | ||||
|   .thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_TX_IRQHandler
 | ||||
|   .thumb_set CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_RX0_IRQHandler
 | ||||
|   .thumb_set CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_RX1_IRQHandler
 | ||||
|   .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN1_SCE_IRQHandler
 | ||||
|   .thumb_set CAN1_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI9_5_IRQHandler
 | ||||
|   .thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_BRK_IRQHandler
 | ||||
|   .thumb_set TIM1_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_UP_IRQHandler
 | ||||
|   .thumb_set TIM1_UP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_TRG_COM_IRQHandler
 | ||||
|   .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM1_CC_IRQHandler
 | ||||
|   .thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM2_IRQHandler
 | ||||
|   .thumb_set TIM2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM3_IRQHandler
 | ||||
|   .thumb_set TIM3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM4_IRQHandler
 | ||||
|   .thumb_set TIM4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_EV_IRQHandler
 | ||||
|   .thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C1_ER_IRQHandler
 | ||||
|   .thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_EV_IRQHandler
 | ||||
|   .thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  I2C2_ER_IRQHandler
 | ||||
|   .thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI1_IRQHandler
 | ||||
|   .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI2_IRQHandler
 | ||||
|   .thumb_set SPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART1_IRQHandler
 | ||||
|   .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART2_IRQHandler
 | ||||
|   .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  USART3_IRQHandler
 | ||||
|   .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  EXTI15_10_IRQHandler
 | ||||
|   .thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  RTC_Alarm_IRQHandler
 | ||||
|   .thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  OTG_FS_WKUP_IRQHandler
 | ||||
|   .thumb_set OTG_FS_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM5_IRQHandler
 | ||||
|   .thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  SPI3_IRQHandler
 | ||||
|   .thumb_set SPI3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART4_IRQHandler
 | ||||
|   .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  UART5_IRQHandler
 | ||||
|   .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM6_IRQHandler
 | ||||
|   .thumb_set TIM6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  TIM7_IRQHandler
 | ||||
|   .thumb_set TIM7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel1_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel2_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel3_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel4_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  DMA2_Channel5_IRQHandler
 | ||||
|   .thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ETH_IRQHandler
 | ||||
|   .thumb_set ETH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  ETH_WKUP_IRQHandler
 | ||||
|   .thumb_set ETH_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN2_TX_IRQHandler
 | ||||
|   .thumb_set CAN2_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN2_RX0_IRQHandler
 | ||||
|   .thumb_set CAN2_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN2_RX1_IRQHandler
 | ||||
|   .thumb_set CAN2_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  CAN2_SCE_IRQHandler
 | ||||
|   .thumb_set CAN2_SCE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|   .weak  OTG_FS_IRQHandler
 | ||||
|   .thumb_set OTG_FS_IRQHandler ,Default_Handler | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0801FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20001FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20001FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0807FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20007FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20007FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x08007FFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200017FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200017FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0801FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20003FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20003FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0807FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000BFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000BFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x080FFFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20013FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20013FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x08007FFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200017FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200017FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0801FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20003FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20003FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x08007FFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200027FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x200027FF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0801FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20004FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20004FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0807FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x080FFFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20017FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x20017FFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0803FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x08000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__     = 0x0803FFFF; | ||||
| define symbol __ICFEDIT_region_RAM_start__   = 0x20000000; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,31 +0,0 @@ | |||
| /*###ICF### Section handled by ICF editor, don't touch! ****/ | ||||
| /*-Editor annotation file-*/ | ||||
| /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ | ||||
| /*-Specials-*/ | ||||
| define symbol __ICFEDIT_intvec_start__ = 0x20000000; | ||||
| /*-Memory Regions-*/ | ||||
| define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; | ||||
| define symbol __ICFEDIT_region_ROM_end__   = 0x200013FF; | ||||
| define symbol __ICFEDIT_region_RAM_start__ = 0x20001400; | ||||
| define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF; | ||||
| /*-Sizes-*/ | ||||
| define symbol __ICFEDIT_size_cstack__   = 0x400; | ||||
| define symbol __ICFEDIT_size_heap__     = 0x200; | ||||
| /**** End of ICF editor section. ###ICF###*/ | ||||
| 
 | ||||
| 
 | ||||
| define memory mem with size = 4G; | ||||
| define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__]; | ||||
| define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__]; | ||||
| 
 | ||||
| define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { }; | ||||
| define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { }; | ||||
| 
 | ||||
| initialize by copy { readwrite }; | ||||
| do not initialize  { section .noinit }; | ||||
| 
 | ||||
| place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; | ||||
| 
 | ||||
| place in ROM_region   { readonly }; | ||||
| place in RAM_region   { readwrite, | ||||
|                         block CSTACK, block HEAP }; | ||||
|  | @ -1,413 +0,0 @@ | |||
| ;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32f100xb.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V4.2.0
 | ||||
| ;* Date               : 31-March-2017
 | ||||
| ;* Description        : STM32F100xB Value Line Devices vector table 
 | ||||
| ;*                      for EWARM toolchain.
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Configure the clock system
 | ||||
| ;*                      - Set the initial PC == __iar_program_start,
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR 
 | ||||
| ;*                        address.
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;* 
 | ||||
| ;* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
 | ||||
| ;* 
 | ||||
| ;* Redistribution and use in source and binary forms, with or without modification,
 | ||||
| ;* are permitted provided that the following conditions are met:
 | ||||
| ;*   1. Redistributions of source code must retain the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer.
 | ||||
| ;*   2. Redistributions in binary form must reproduce the above copyright notice,
 | ||||
| ;*      this list of conditions and the following disclaimer in the documentation
 | ||||
| ;*      and/or other materials provided with the distribution.
 | ||||
| ;*   3. Neither the name of STMicroelectronics nor the names of its contributors
 | ||||
| ;*      may be used to endorse or promote products derived from this software
 | ||||
| ;*      without specific prior written permission.
 | ||||
| ;* 
 | ||||
| ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||||
| ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||||
| ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | ||||
| ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 | ||||
| ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | ||||
| ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | ||||
| ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | ||||
| ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | ||||
| ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | ||||
| ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | ||||
| ;* 
 | ||||
| ;*******************************************************************************
 | ||||
| ;
 | ||||
| ;
 | ||||
| ; The modules in this file are included in the libraries, and may be replaced
 | ||||
| ; by any user-defined modules that define the PUBLIC symbol _program_start or
 | ||||
| ; a user defined start symbol.
 | ||||
| ; To override the cstartup defined in the library, simply add your modified
 | ||||
| ; version to the workbench project.
 | ||||
| ;
 | ||||
| ; The vector table is normally located at address 0.
 | ||||
| ; When debugging in RAM, it can be located in RAM, aligned to at least 2^6.
 | ||||
| ; The name "__vector_table" has special meaning for C-SPY:
 | ||||
| ; it is where the SP start value is found, and the NVIC vector
 | ||||
| ; table register (VTOR) is initialized to this address if != 0.
 | ||||
| ;
 | ||||
| ; Cortex-M version
 | ||||
| ;
 | ||||
| 
 | ||||
|         MODULE  ?cstartup | ||||
| 
 | ||||
|         ;; Forward declaration of sections.
 | ||||
|         SECTION CSTACK:DATA:NOROOT(3) | ||||
| 
 | ||||
|         SECTION .intvec:CODE:NOROOT(2) | ||||
| 
 | ||||
|         EXTERN  __iar_program_start | ||||
|         EXTERN  SystemInit         | ||||
|         PUBLIC  __vector_table | ||||
| 
 | ||||
|         DATA | ||||
| __vector_table | ||||
|         DCD     sfe(CSTACK) | ||||
|         DCD     Reset_Handler             ; Reset Handler
 | ||||
|         DCD     NMI_Handler               ; NMI Handler
 | ||||
|         DCD     HardFault_Handler         ; Hard Fault Handler
 | ||||
|         DCD     MemManage_Handler         ; MPU Fault Handler
 | ||||
|         DCD     BusFault_Handler          ; Bus Fault Handler
 | ||||
|         DCD     UsageFault_Handler        ; Usage Fault Handler
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     SVC_Handler               ; SVCall Handler
 | ||||
|         DCD     DebugMon_Handler          ; Debug Monitor Handler
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     PendSV_Handler            ; PendSV Handler
 | ||||
|         DCD     SysTick_Handler           ; SysTick Handler
 | ||||
| 
 | ||||
|          ; External Interrupts
 | ||||
|         DCD     WWDG_IRQHandler               ; Window Watchdog
 | ||||
|         DCD     PVD_IRQHandler                ; PVD through EXTI Line detect
 | ||||
|         DCD     TAMPER_IRQHandler             ; Tamper
 | ||||
|         DCD     RTC_IRQHandler                ; RTC
 | ||||
|         DCD     FLASH_IRQHandler              ; Flash
 | ||||
|         DCD     RCC_IRQHandler                ; RCC
 | ||||
|         DCD     EXTI0_IRQHandler              ; EXTI Line 0
 | ||||
|         DCD     EXTI1_IRQHandler              ; EXTI Line 1
 | ||||
|         DCD     EXTI2_IRQHandler              ; EXTI Line 2
 | ||||
|         DCD     EXTI3_IRQHandler              ; EXTI Line 3
 | ||||
|         DCD     EXTI4_IRQHandler              ; EXTI Line 4
 | ||||
|         DCD     DMA1_Channel1_IRQHandler      ; DMA1 Channel 1
 | ||||
|         DCD     DMA1_Channel2_IRQHandler      ; DMA1 Channel 2
 | ||||
|         DCD     DMA1_Channel3_IRQHandler      ; DMA1 Channel 3
 | ||||
|         DCD     DMA1_Channel4_IRQHandler      ; DMA1 Channel 4
 | ||||
|         DCD     DMA1_Channel5_IRQHandler      ; DMA1 Channel 5
 | ||||
|         DCD     DMA1_Channel6_IRQHandler      ; DMA1 Channel 6
 | ||||
|         DCD     DMA1_Channel7_IRQHandler      ; DMA1 Channel 7
 | ||||
|         DCD     ADC1_IRQHandler               ; ADC1
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     EXTI9_5_IRQHandler            ; EXTI Line 9..5
 | ||||
|         DCD     TIM1_BRK_TIM15_IRQHandler     ; TIM1 Break and TIM15
 | ||||
|         DCD     TIM1_UP_TIM16_IRQHandler      ; TIM1 Update and TIM16
 | ||||
|         DCD     TIM1_TRG_COM_TIM17_IRQHandler ; TIM1 Trigger and Commutation and TIM17
 | ||||
|         DCD     TIM1_CC_IRQHandler            ; TIM1 Capture Compare
 | ||||
|         DCD     TIM2_IRQHandler               ; TIM2
 | ||||
|         DCD     TIM3_IRQHandler               ; TIM3
 | ||||
|         DCD     TIM4_IRQHandler               ; TIM4
 | ||||
|         DCD     I2C1_EV_IRQHandler            ; I2C1 Event
 | ||||
|         DCD     I2C1_ER_IRQHandler            ; I2C1 Error
 | ||||
|         DCD     I2C2_EV_IRQHandler            ; I2C2 Event
 | ||||
|         DCD     I2C2_ER_IRQHandler            ; I2C2 Error
 | ||||
|         DCD     SPI1_IRQHandler               ; SPI1
 | ||||
|         DCD     SPI2_IRQHandler               ; SPI2
 | ||||
|         DCD     USART1_IRQHandler             ; USART1
 | ||||
|         DCD     USART2_IRQHandler             ; USART2
 | ||||
|         DCD     USART3_IRQHandler             ; USART3
 | ||||
|         DCD     EXTI15_10_IRQHandler          ; EXTI Line 15..10
 | ||||
|         DCD     RTC_Alarm_IRQHandler           ; RTC Alarm through EXTI Line
 | ||||
|         DCD     CEC_IRQHandler                ; HDMI-CEC
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved
 | ||||
|         DCD     0                             ; Reserved                        
 | ||||
|         DCD     TIM6_DAC_IRQHandler           ; TIM6 and DAC underrun
 | ||||
|         DCD     TIM7_IRQHandler               ; TIM7                
 | ||||
| 
 | ||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 | ||||
| ;;
 | ||||
| ;; Default interrupt handlers.
 | ||||
| ;;
 | ||||
|         THUMB | ||||
| 
 | ||||
|         PUBWEAK Reset_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(2) | ||||
| Reset_Handler | ||||
|         LDR     R0, =SystemInit | ||||
|         BLX     R0 | ||||
|         LDR     R0, =__iar_program_start | ||||
|         BX      R0 | ||||
|          | ||||
|         PUBWEAK NMI_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| NMI_Handler | ||||
|         B NMI_Handler | ||||
| 
 | ||||
|         PUBWEAK HardFault_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| HardFault_Handler | ||||
|         B HardFault_Handler | ||||
| 
 | ||||
|         PUBWEAK MemManage_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| MemManage_Handler | ||||
|         B MemManage_Handler | ||||
| 
 | ||||
|         PUBWEAK BusFault_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| BusFault_Handler | ||||
|         B BusFault_Handler | ||||
| 
 | ||||
|         PUBWEAK UsageFault_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| UsageFault_Handler | ||||
|         B UsageFault_Handler | ||||
| 
 | ||||
|         PUBWEAK SVC_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| SVC_Handler | ||||
|         B SVC_Handler | ||||
| 
 | ||||
|         PUBWEAK DebugMon_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DebugMon_Handler | ||||
|         B DebugMon_Handler | ||||
| 
 | ||||
|         PUBWEAK PendSV_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| PendSV_Handler | ||||
|         B PendSV_Handler | ||||
| 
 | ||||
|         PUBWEAK SysTick_Handler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| SysTick_Handler | ||||
|         B SysTick_Handler | ||||
| 
 | ||||
|         PUBWEAK WWDG_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| WWDG_IRQHandler | ||||
|         B WWDG_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK PVD_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| PVD_IRQHandler | ||||
|         B PVD_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TAMPER_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TAMPER_IRQHandler | ||||
|         B TAMPER_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK RTC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| RTC_IRQHandler | ||||
|         B RTC_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK FLASH_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| FLASH_IRQHandler | ||||
|         B FLASH_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK RCC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| RCC_IRQHandler | ||||
|         B RCC_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI0_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI0_IRQHandler | ||||
|         B EXTI0_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI1_IRQHandler | ||||
|         B EXTI1_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI2_IRQHandler | ||||
|         B EXTI2_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI3_IRQHandler | ||||
|         B EXTI3_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI4_IRQHandler | ||||
|         B EXTI4_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel1_IRQHandler | ||||
|         B DMA1_Channel1_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel2_IRQHandler | ||||
|         B DMA1_Channel2_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel3_IRQHandler | ||||
|         B DMA1_Channel3_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel4_IRQHandler | ||||
|         B DMA1_Channel4_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel5_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel5_IRQHandler | ||||
|         B DMA1_Channel5_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel6_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel6_IRQHandler | ||||
|         B DMA1_Channel6_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK DMA1_Channel7_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| DMA1_Channel7_IRQHandler | ||||
|         B DMA1_Channel7_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK ADC1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| ADC1_IRQHandler | ||||
|         B ADC1_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI9_5_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI9_5_IRQHandler | ||||
|         B EXTI9_5_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM1_BRK_TIM15_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM1_BRK_TIM15_IRQHandler | ||||
|         B TIM1_BRK_TIM15_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM1_UP_TIM16_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM1_UP_TIM16_IRQHandler | ||||
|         B TIM1_UP_TIM16_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM1_TRG_COM_TIM17_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM1_TRG_COM_TIM17_IRQHandler | ||||
|         B TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM1_CC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM1_CC_IRQHandler | ||||
|         B TIM1_CC_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM2_IRQHandler | ||||
|         B TIM2_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM3_IRQHandler | ||||
|         B TIM3_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM4_IRQHandler | ||||
|         B TIM4_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK I2C1_EV_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| I2C1_EV_IRQHandler | ||||
|         B I2C1_EV_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK I2C1_ER_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| I2C1_ER_IRQHandler | ||||
|         B I2C1_ER_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK I2C2_EV_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| I2C2_EV_IRQHandler | ||||
|         B I2C2_EV_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK I2C2_ER_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| I2C2_ER_IRQHandler | ||||
|         B I2C2_ER_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK SPI1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| SPI1_IRQHandler | ||||
|         B SPI1_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK SPI2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| SPI2_IRQHandler | ||||
|         B SPI2_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK USART1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| USART1_IRQHandler | ||||
|         B USART1_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK USART2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| USART2_IRQHandler | ||||
|         B USART2_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK USART3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| USART3_IRQHandler | ||||
|         B USART3_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK EXTI15_10_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| EXTI15_10_IRQHandler | ||||
|         B EXTI15_10_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK RTC_Alarm_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| RTC_Alarm_IRQHandler | ||||
|         B RTC_Alarm_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK CEC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| CEC_IRQHandler | ||||
|         B CEC_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM6_DAC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM6_DAC_IRQHandler | ||||
|         B TIM6_DAC_IRQHandler | ||||
| 
 | ||||
|         PUBWEAK TIM7_IRQHandler | ||||
|         SECTION .text:CODE:REORDER:NOROOT(1) | ||||
| TIM7_IRQHandler | ||||
|         B TIM7_IRQHandler                 | ||||
| 
 | ||||
|         END | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||