annotate llvm/lib/Target/Hexagon/HexagonDepArch.h @ 266:00f31e85ec16 default tip

Added tag current for changeset 31d058e83c98
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:55 +0900
parents 1f2b6ac9f198
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #ifndef LLVM_LIB_TARGET_HEXAGON_HEXAGONDEPARCH_H
anatofuz
parents:
diff changeset
10 #define LLVM_LIB_TARGET_HEXAGON_HEXAGONDEPARCH_H
anatofuz
parents:
diff changeset
11
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
12 #include "llvm/ADT/StringSwitch.h"
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
13 #include <optional>
150
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 namespace llvm {
anatofuz
parents:
diff changeset
16 namespace Hexagon {
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
17 enum class ArchEnum {
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
18 NoArch,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
19 Generic,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
20 V5,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
21 V55,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
22 V60,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
23 V62,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
24 V65,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
25 V66,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
26 V67,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
27 V68,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
28 V69,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
29 V71,
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
30 V73
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
31 };
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
32
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
33 inline std::optional<Hexagon::ArchEnum> getCpu(StringRef CPU) {
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
34 return StringSwitch<std::optional<Hexagon::ArchEnum>>(CPU)
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
35 .Case("generic", Hexagon::ArchEnum::V5)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
36 .Case("hexagonv5", Hexagon::ArchEnum::V5)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
37 .Case("hexagonv55", Hexagon::ArchEnum::V55)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
38 .Case("hexagonv60", Hexagon::ArchEnum::V60)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
39 .Case("hexagonv62", Hexagon::ArchEnum::V62)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
40 .Case("hexagonv65", Hexagon::ArchEnum::V65)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
41 .Case("hexagonv66", Hexagon::ArchEnum::V66)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
42 .Case("hexagonv67", Hexagon::ArchEnum::V67)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
43 .Case("hexagonv67t", Hexagon::ArchEnum::V67)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
44 .Case("hexagonv68", Hexagon::ArchEnum::V68)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
45 .Case("hexagonv69", Hexagon::ArchEnum::V69)
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
46 .Case("hexagonv71", Hexagon::ArchEnum::V71)
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
47 .Case("hexagonv71t", Hexagon::ArchEnum::V71)
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
48 .Case("hexagonv73", Hexagon::ArchEnum::V73)
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
49 .Default(std::nullopt);
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
50 }
150
anatofuz
parents:
diff changeset
51 } // namespace Hexagon
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
52 } // namespace llvm
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
53
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
54 #endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONDEPARCH_H