- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
I'm trying to measure the branch mispredict rate in Vtune for performance comparisons across different products.
I noticed that there's a branch mispredict tile on the Microarchitecture Exploration page, but it seems to be the cost of mispredictions in term of pipelines, not the mispredict rate. I also noticed there are "BR_MISP_RETIRED.ALL_BRANCHES" and "BR_INST_RETIRED.ALL_BRANCHES", their quotient may be an approximation(which I assume is bigger than the actual number), but is there an accurate way to measure branch mispredict rate?
Thanks.
Link Copied
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Just create custom VTune analysis with 2 events:
BR_INST_RETIRED.ALL_BRANCHES
BR_MISP_RETIRED.ALL_BRANCHES
You'll need to manually divide one by another to get the ration though.
In case you don't know - custom analysis in VTune can be created by selecting any pre-defined analysis and pressing 'Customize...' button in the top-right corner. E.g. you can select Microarchitecture Exploration, uncheck all check-boxes there, press 'Customize...', scroll down to the table with CPU events and uncheck all not needed/add needed events.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thanks for the reply, I am using this method for now, but there are two quesitions:
1. Using BR_INST_RETIRED.ALL_BRANCHES as denominator means that Intel processor will try to predict every single branch instruction. Is this the actual case? If not, the end result might be smaller than the actual one.
2. I heard that intel processors will try to terminate mispredicted instructions mid-execution. I don't know whether these cases will be counted as BR_MISP_RETIRED.ALL_BRANCHES events.
Thanks.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
Thank you for your response. We are checking on this from our side. We will get back to you.
Thanks and Regards
Rahul
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
Sorry for late reply. We looked into your case. If you want the branch prediction and the branch misprediction rate then you only need to focus on the conditional jumps. You can use BR_MISP_RETIRED.CONDITIONAL which are for conditional branch instructions. You can also explore the events we have in BR_INST_RETIRED.* and BR_MISP_RETIRED.* and select what is interesting.
Hope this helps.
Thanks and Regards
Rahul
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
We haven't hear back from you. Could you please confirm if the issue is resolved.
Thanks and Regards
Rahul
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
Since we haven't heard back from you. We will close this case for now. If you have any query you can post a new question.
Thanks and Regards
Rahul
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thanks, sorry for my forgetting to check on this thread. Currently I'm settling on "BR_MISP_RETIRED.ALL_BRANCHES" and "BR_INST_RETIRED.ALL_BRANCHES" because all other softwares use the same type of events for this purpose, thus the results are comparable. I'm still checking on conditional branch events to see what I can find, and how I can replicate this on other softwares. The results seems to be similiar in most cases though.
Thank you for your patience.
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page