<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/97916>97916</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            [MLIR] [Pass] [Dialect] [New Feature]Add  PassHelper Dialect and new feature for driver that enable dynamically passes order control
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            mlir
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          mingzheTerapines
      </td>
    </tr>
</table>

<pre>
    MLIR is an AI compiler, but for pass driver tool part, it is not that "AI". Because all passes are in static order.
However, we could predict what next pass or following passes should go after analysing the features of this IR(That's what machine learning/ AI does).
So here is my proposal:
1. Add PassHelper Dialect for every IR. This dialcet gives
a. information of this IR, such as involving what kinds of dialects, hardware/software based, LLM imported or something
b. features of this IR, having side effect Ops or something
c. following pass red list/black list (hoping some kind of optimization)
d. ...
2.  Add PassHelper related class in pass driver tool:
a. Generating sevral passes order by the features of IRs involved in projects.(It may be easy just referring to name like AA2BB BB2CC or red list mentioned in DIalect, also can be imporved by some machine learning)
b. Giving warnging for some IR meeting following IR in black list.
3. Add next layer IR/Dialect verifier or something.
 I am meeting this converting: hw.struct_inject was marked Pure, which means no memory effect. But after converting, here comes a llvm.insertvalue, which seems accessing memory.
![image](https://github.com/llvm/llvm-project/assets/166383385/25d56412-d260-4fd3-8c54-28eab8563ae7)

</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyUlU2T2jgTxz-NuHSNywhs4MABhiKhKnme1GzuW22pjZXRi0uSYZ1PvyXZTN7msidsLP27-9-_ljAEdbVEe1YdWXVa4BA75_dG2ev3jr6Sx15ZCovGyXH_-dPlBVQAtHC4gHCmV5o848_QDBFa56HHEEB6dSMP0TkNPfqYFqiYNloXIXYYgXF-uDDOCziSwCEQoNZ5NwVAT6AshIhRCXBeki9YeWLl4aO7022KeCcQbtASek9SiQj3pGvpnzgl4Ty0Tmt3V_b6EA5d3nF1gG0kD2hRjyEtiB1BSxgHTwFcC7FTAS4vjG-_dhgZ34RJ36DolCXQhN4qe2X8nKyQjgLjuznLvxx0lGoIYEbovetdQM1Wh-nzsoCDlPAFQ_hIuicPJ4WaxORgqm-Ey0sBX1MOUqEWFOGqbhSm_ViAsq3zBqNy9pdsnyEMogMMoOzN6VsqLef9qqzMhckpVEhrO_Tyjp4YPwfXxvQIDQaS6eOnT59Bmd75SDKZGZyh2KWScxJN8b5fSTWHDUoSUNumuv7fh3ckRPFbh8CTBK1CZPzcaBSv-QUY33auz5rOUC4lhXR9VEZ9zyYwvps0ZQFFMbeBF_C70Z40pnqETuGU_YPXtyZhAR_IkseYA9PN4xufmUhoxj-oubw8jCeZ1b37lswuGN9eEjwjNASEYYRvQ4jgqSXvM38OLBoCrV4JDgd-PMLxyJ-fk20PV8CQTcVO2qdLbmRyHHVwINAm8dyyFL4ZJ7v-JHb31sEPaiIEvb2mh3ZuElxewBDF6b9Hi9LsW_jRmNnm1YRznjyNI_nMwfnB9I28ahX5XwCYt8IF0LxFygwJZ2_k0ztbHaC7FyH6QcS_lU1Owh0DGPSvJOHLkMh9hnunRAeG0KbzBQwZ58eZvAKOQ5yH_SflRGkaUOFMOm5A65splA3k4w318JNsIDIBUAgK-ZyY1Of0GV-y6qgMXolVp4RpjH1ICPEz4-erit3QFMIZxs8pxPzzNGPB-DnxlGbxvKzr1Xa12laMn3klq3q95E-S1-XTupWrp62o1k98S9hsq3qFtHnr4kLuV3K32uGC9ssNL1flelOXi24vxVqsd5LWZdtsWr5pSNa43a3Ldr2pZL1cqD0v-brclDXnvC7Lot3uWl5umqUQ9aZZ1WxdkkGli2yP89eFCmGg_W6zW9YLjQ3pkK8Nzo1WnnGeLhC_zzU2wzWwdZk4CT8Eooo6XzXpJmHVCVh1TOM5P87MzG__ozucp-li1Skx9t6ZiTaxd3_MYWb4MdDp5COLjSaQo0WjBGo9_jrGwtnonV4MXu__c_-yIal_kye3Pf83AAD__9o0dHk">