Keil accurately measures code execution time

Publisher:LeishanLatest update time:2017-10-24 Source: eefocusKeywords:Keil Reading articles on mobile phones Scan QR code
Read articles on your mobile phone anytime, anywhere

In the project settings, under "Debug", select Hardware Simulation on the right, click the drop-down box to select "J-LINK/J-TRACE", and then click "Setting"


In the pop-up window, under "Debug", select "JTAG" or "SW", and then select the download rate.


Click on the Trace tab, if you select SW

Check the "Enable" option, enter the actual working clock frequency of the MCU in the "Core" box (that is, the frequency at which the microcontroller executes instructions, which MDK will use to calculate the time), and then check "Autodetect max SW0 Clock"


If you select "JTAG",

First check "Enable", set the clock frequency in "Core", and finally remove the "Enable" just checked.


Because the "JTAG" mode does not support the "Trace" function, the simulation will report an error if "Enable" is not removed.

Next, click to enter the simulation, and there will be a time window in the lower right corner of the interface


If you right-click the mouse on it, you will see:


The top two are for resetting "t1" and "t2", and the bottom three are for selecting which time to display on the status bar.

"t0" indicates the time from the start of the program to the present, and cannot be reset. The other two can be reset at will, and can be used to measure the running time of a specific function or a line of program.

The specific operation is: add a breakpoint before the code to be tested. When the program runs to the target line, it will stop, then reset "t1" or "t2", and add a breakpoint before the next line of code. Then continue running the program. The program will stop before the next line of code. At this time, the value of "t1" is the running time of the target line program.


Keywords:Keil Reference address:Keil accurately measures code execution time

Previous article:Pitfalls of using st-link to download programs to stm8 through stvp
Next article:The meaning of RO-data, RW-data, and ZI-data in Keil

Latest Microcontroller Articles
  • Download from the Internet--ARM Getting Started Notes
    A brief introduction: From today on, the ARM notebook of the rookie is open, and it can be regarded as a place to store these notes. Why publish it? Maybe you are interested in it. In fact, the reason for these notes is ...
  • Learn ARM development(22)
    Turning off and on interrupts Interrupts are an efficient dialogue mechanism, but sometimes you don't want to interrupt the program while it is running. For example, when you are printing something, the program suddenly interrupts and another ...
  • Learn ARM development(21)
    First, declare the task pointer, because it will be used later. Task pointer volatile TASK_TCB* volatile g_pCurrentTask = NULL;volatile TASK_TCB* vol ...
  • Learn ARM development(20)
    With the previous Tick interrupt, the basic task switching conditions are ready. However, this "easterly" is also difficult to understand. Only through continuous practice can we understand it. ...
  • Learn ARM development(19)
    After many days of hard work, I finally got the interrupt working. But in order to allow RTOS to use timer interrupts, what kind of interrupts can be implemented in S3C44B0? There are two methods in S3C44B0. ...
  • Learn ARM development(14)
  • Learn ARM development(15)
  • Learn ARM development(16)
  • Learn ARM development(17)
Change More Related Popular Components

EEWorld
subscription
account

EEWorld
service
account

Automotive
development
circle

About Us Customer Service Contact Information Datasheet Sitemap LatestNews


Room 1530, 15th Floor, Building B, No.18 Zhongguancun Street, Haidian District, Beijing, Postal Code: 100190 China Telephone: 008610 8235 0740

Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号