-
Notifications
You must be signed in to change notification settings - Fork 61
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Branch Prediction API #139
Conversation
- Mostly intended to be pseduocode at this stage; compilation not attempted
@bdutro you might have some input... |
Hi Arup, following up on our discussion last night. Could you help me understand how the API will provide configurability, and support speculative state updates? For configurability, how do we pass in runtime parameters. Furthermore how can we enable reuse of predictor components. Like the Cache model allows users to change the address decoder, do we need similar methods for changing the components within the branch predictor i.e. the conditional branch predictor, the indirect target predictor, BTB and return address stack. The other point is about supporting predictors which have internal speculative state. For example a global history predictor has the global history register which needs to be recovered following a flush. Similarly some predictors require meta data about the prediction to be available for the update, TAGE requires the provider table, and alternate prediction for example. Finally we did speak about how to fit a block based BTB, like you've implemented, into a trace execution model. Branch predictors work in addresses, using trace is difficult because we have to pair instructions with their predictions based on their address. How do we handle malformed trace, or trace that has unexpected change of flow (i.e. interrupt/exception). EDIT: I think we also need to consider how to collect statistics from the predictor. |
Knute mentioned looking at other simulators. I've used gem5, but I'm also aware of champsim. gem5 o3 model
As for the API you can read the documentation here for details but I'll summarize. The interface with Fetch is just 3 methods: predict, squash(flush) and update. The BTB/RAS/Indirect predictor objects can be swapped out in the build configuration as long as they're a subclass of the original implementation. The conditional predictor on the other hand, must be a subclass of the branch predictor unit itself. Many leave the base predict, squash and update implementations, and instead override the methods referenced in those. Mainly the lookup*, updateHistories*, update (internal one), and squash. *Both referenced by predict. ChampSim Both the BTB and BranchPredictor take the PC to produce a prediction. The update methods take the PC, target, direction and branch type. Olympia It might be better to have separate objects for the conditional predictor, indirect target, BTB and RAS. With another API defined for each of them, and then a BranchPredict implementation which orchestrates predictions, updates, flushes across those objects. That single implementation will most likely provide enough flexibility for many use cases. We also need to determine how it fits into the pipeline. My thoughts are that allow the predictor to maintain it's own state for history/pending updates, and like gem5, an ID is used to tag updates to instructions.
|
Addressing this part of question/comment: We can do this using ResourceFactories, which are used to configure the tree nodes. As an example, please see files Extending that idea, we can do the following:
|
IMO, the API should be generic enough to support simplest of the predictors, which may not have different sub-predictors as as long as API does not prevent or create undue burden on implementing more complicated predictors with sub-predictors.
Can we not use the updatePredictor method with appropriate input (sub-classed from DefaultUpdate or defined separately) to restore/change predictor states, as needed?
We do have to add proper mechanism to handle traces. I plan to address this later. Also, similar to Sparta's cache API, the user of the API can maintain stats, as needed. |
I agree and issue #143 will give us the opportunity to work on these aspects.
I am happy to build on top of the currently proposed API, once reviewed and finalized, to create sub-predictor-specific APIs, if that's needed. My suggestion would be that we work towards implementing #143 using the proposed branch prediction API and Sparta subunits to create, parameterize sub-predictors and combine them. As we work through it, we can discuss how can we keep interfaces generic enough to be APIs |
On a different note do we need to discuss the directory structure going forward for when others implement their own predictors? Do we need a separate branchpred directory under core? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please put everything in separate namespace
core/BranchPred.hpp
Outdated
class BranchPredictorIF | ||
{ | ||
public: | ||
virtual PredictionT getPrediction(const InputT &) = 0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should be a const return type, to allow compiler to do move optimization
use: virtual const PredictionT getPrediction(const InputT &) = 0;
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you please explain further why this is needed / recommended ?
This https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#f49-dont-return-const-t , seem to suggest that const return type would suppress use of move semantics and is not advisable.
Have added branch prediction IF and SimplePredictor in the Olympia namespace, for now, in line with what we have currently for LSU, Dispatch etc. I will capture this request in a separate issue to create separate namespaces for different units of Olympia |
Let us address this in a new PR when we add other branch predictors. |
Addressed review comments. Please take a look and approve, if looks good. I need at least one approval for merge. |
bool actually_taken = false; | ||
}; | ||
|
||
class DefaultInput |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It doesn't feel right to pollute the olympia namespace with a fairly generically named class "DefaultInput". It's not obvious that this is related to branch predictors, let alone that it's used for the SimpleBranchPredictor.
Goes for the others DefaultUpdate/DefaultPrediction as well?
Can't we place them under SimpleBranchPredictor? Or name them SimpleBranchPredictorUpdate
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added a separate namespace for BranchPredictor within olympia.
As a reminder, if there is no further comment, please approve so that we can merge this. |
A code introducing branch prediction API. Still a draft PR as I am working through a compilation issue.
Please feel free to review and provide feedback.