[llvm] [MIPS] Add Scheduling model for MIPS i6400 and i6500 CPUs (PR #132704)
Mallikarjuna Gouda via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 26 22:19:04 PDT 2025
================
@@ -0,0 +1,447 @@
+//==- MipsScheduleI6400.td - I6400 Scheduling Definitions --*- tablegen -*-===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+def MipsI6400Model : SchedMachineModel {
+ int IssueWidth = 2; // 2x dispatched per cycle
+ int MicroOpBufferSize = 0;
+ int LoadLatency = 3;
+ int MispredictPenalty = 8;
+
+ let CompleteModel = 1;
+ let FullInstRWOverlapCheck = 1;
+
+ list<Predicate> UnsupportedFeatures = [HasMips64r5, HasMips32r5,
+ InMicroMips, InMips16Mode, HasCnMips,
+ HasCnMipsP, HasDSP, HasDSPR2,
+ HasMips3D, HasMT, HasCRC,
+ NotMips32r6, NotMips64r6, HasEVA];
+}
+
+let SchedModel = MipsI6400Model in {
+
+ // AGEN Pipelines
+ // ==============
+ def I6400AGEN : ProcResource<1> { let BufferSize = 0; }
----------------
mgoudar wrote:
done. defined BufferSize to 0 for all resources
https://github.com/llvm/llvm-project/pull/132704
More information about the llvm-commits
mailing list