<div dir="ltr"><div>Hi Matt.</div><div><br></div><div>Next time, could you please create a code review for changes to the documentation?</div><div>
I think the priority should be on decribing what the tool does, and what information is provided by each view. Internal details on the implementation are not very useful at this stage, and - as you wrote - that documentation should probably live in a separate document.<br></div><div>That being said, thanks for contributing this documentation change. <br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Jul 16, 2018 at 10:42 PM, Matt Davis via llvm-commits <span dir="ltr"><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: mattd<br>
Date: Mon Jul 16 14:42:58 2018<br>
New Revision: 337219<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=337219&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=337219&view=rev</a><br>
Log:<br>
[llvm-mca][docs] Initial description of mca internals. NFC<br>
<br>
This patch introduces a brief description of the components of MCA.  The main<br>
focus is on Views.   This is a work in progress, and more descriptions will be<br>
introduced later.  I want to flesh-out the Views section more and provide a<br>
detailed description of eventing in MCA.  Eventually a brief code example of a<br>
View should accompany the description.<br>
<br>
Also, we should consider moving the MCA internals guide elsewhere at some point.<br>
<br>
<br>
Modified:<br>
    llvm/trunk/docs/CommandGuide/<wbr>llvm-mca.rst<br>
<br>
Modified: llvm/trunk/docs/CommandGuide/<wbr>llvm-mca.rst<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/docs/CommandGuide/llvm-mca.rst?rev=337219&r1=337218&r2=337219&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/llvm/trunk/docs/<wbr>CommandGuide/llvm-mca.rst?rev=<wbr>337219&r1=337218&r2=337219&<wbr>view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- llvm/trunk/docs/CommandGuide/<wbr>llvm-mca.rst (original)<br>
+++ llvm/trunk/docs/CommandGuide/<wbr>llvm-mca.rst Mon Jul 16 14:42:58 2018<br>
@@ -43,7 +43,7 @@ instruction in the input file.  Every re<br>
 final performance report is the union of all the reports generated for every<br>
 code region.<br>
<br>
-Inline assembly directives may be used from source code to annotate the <br>
+Inline assembly directives may be used from source code to annotate the<br>
 assembly text:<br>
<br>
 .. code-block:: c++<br>
@@ -132,7 +132,7 @@ option specifies "``-``", then the outpu<br>
   Specify the size of the load queue in the load/store unit emulated by the tool.<br>
   By default, the tool assumes an unbound number of entries in the load queue.<br>
   A value of zero for this flag is ignored, and the default load queue size is<br>
-  used instead. <br>
+  used instead.<br>
<br>
 .. option:: -squeue=<store queue size><br>
<br>
@@ -200,10 +200,97 @@ option specifies "``-``", then the outpu<br>
   the theoretical uniform distribution of resource pressure for every<br>
   instruction in sequence.<br>
<br>
-<br>
 EXIT STATUS<br>
 -----------<br>
<br>
 :program:`llvm-mca` returns 0 on success. Otherwise, an error message is printed<br>
 to standard error, and the tool returns 1.<br>
<br>
+INTERNALS<br>
+---------<br>
+Why MCA?  For many analysis scenarios :program:`llvm-mca` (MCA) should work<br>
+just fine out of the box; however, the tools MCA provides allows for the<br>
+curious to create their own pipelines, and explore the finer details of<br>
+instruction processing.<br>
+<br>
+MCA is designed to be a flexible framework allowing users to easily create<br>
+custom instruction pipeline simulations.  The following section describes the<br>
+primary components necessary for creating a pipeline, namely the classes<br>
+``Pipeline``, ``Stage``, ``HardwareUnit``, and ``View``.<br>
+<br>
+In most cases, creating a custom pipeline is not necessary, and using the<br>
+default ``mca::Context::<wbr>createDefaultPipeline`` will work just fine.  Instead,<br>
+a user will probably find it easier, and faster, to implement a custom<br>
+``View``, allowing them to specifically handle the processing and presenting of<br>
+data.  Views are discussed towards the end of this document, as it can be<br>
+helpful to first understand how the rest of MCA is structured and where the<br>
+views sit in the bigger picture.<br>
+<br>
+Primary Components of MCA<br>
+^^^^^^^^^^^^^^^^^^^^^^^^^<br>
+A pipeline is a collection of stages.  Stages are the real workhorse of<br>
+MCA, since all of the instruction processing occurs within them.  A stage<br>
+operates on instructions (``InstRef``) and utilizes the simulated hardware<br>
+units (``HardwareUnit``).  We draw a strong distinction between a ``Stage`` and<br>
+a ``HardwareUnit``.  Stages make use of HardwareUnits to accomplish their<br>
+primary action, which is defined in ``mca::Stage::execute``.  HardwareUnits<br>
+maintain state and act as a mechanism for inter-stage communication.  For<br>
+instance, both ``DispatchStage`` and ``RetireStage`` stages make use of the<br>
+simulated ``RegisterFile`` hardware unit for updating the state of particular<br>
+registers.<br>
+<br>
+The pipeline's role is to simply execute the stages in order.  During<br>
+execution, a stage can return ``false`` from ``mca::Stage:execute``, indicating<br>
+to the pipeline that no more executions are to continue for the current cycle.<br>
+This mechanism allows for a stage to short-circuit the rest of execution for<br>
+any cycle.<br>
+<br>
+Views<br>
+^^^^^<br>
+Of course simulating a pipeline is great, but it's not very useful if a user<br>
+cannot extract data from it!  This is where views come into play. The goal of a<br>
+``View`` is to collect events from the pipeline's stages.  The view can<br>
+analyze and present this collected information in a more comprehensible manner.<br>
+<br>
+If the default views provided by MCA are not sufficient, then a user might<br>
+consider implementing a custom data collection and presentation mechanism (a<br>
+``View``).  Views receive callback notifications from the pipeline simulation,<br>
+specifically from the stages.  To accomplish this communication, stages contain<br>
+a list of listeners.  A view is a listener (``HWEventListener``) and can be<br>
+added to a single stage's list of listeners, or to all stages lists, by<br>
+expressing interest to be notified when particular hardware events occur (e.g.,<br>
+a hardware stall).<br>
+<br>
+Notifications are generated within the stages.  When an event occurs, the stage<br>
+will iterate through its list of listeners (presumably a View) and will send<br>
+an event object describing the situation to the Listener.<br>
+<br>
+What Data does a View Collect?<br>
+"""""""""""""""""""""""""""""<wbr>"<br>
+The two primary event types sent to views are instruction events<br>
+(``HWInstructionEvent``) and stall events (``HWStallEvent``).  The former<br>
+describes the state of an instruction (e.g., Ready, Dispatched, Executed,<br>
+etc.).  The latter describes a stall hazard (e.g., load stall, store stall,<br>
+scheduler stall, etc.).<br>
+<br>
+Creating a Custom View<br>
+""""""""""""""""""""""<br>
+To create a  custom view, the user must first inherit from the ``View`` class<br>
+and then decide which events are of interest.  The ``HWEventListener`` class<br>
+declares the callback functions for the particular event types.  A custom view<br>
+should define the callbacks for the events of interest.<br>
+<br>
+Next, the view should define a ``mca::View::printView`` method.  This is called<br>
+once the pipeline has completed executing all of the desired cycles.  A<br>
+user can choose to perform analysis in the aforementioned routine, or do the<br>
+analysis incrementally as the event callbacks are triggered.  All presentation<br>
+of the data should be performed in ``printView``.<br>
+<br>
+With a view created, the next step is to tell the pipeline's stages about it.<br>
+The simplest way to accomplish this is to create a ``PipelinePrinter`` object<br>
+and call ``mca::PipelinePrinter::<wbr>addView``.  We have not discussed the<br>
+PipelinePrinter before, but it is simply a helper class containing a collection<br>
+of views and a pointer to the pipeline instance.  When ``addView`` is called,<br>
+the printer will take the liberty of registering the view as a listener to all<br>
+of the stages in the pipeline.  The printer provides a ``printReport`` routine<br>
+that iterates across all views and calls each view's ``printView`` method.<br>
<br>
<br>
______________________________<wbr>_________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br>
</blockquote></div><br></div>