MLIR  19.0.0git
Chipset.cpp
Go to the documentation of this file.
1 //===- Chipset.cpp - AMDGPU Chipset version struct parsing -----------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
10 #include "mlir/Support/LLVM.h"
11 #include "llvm/ADT/StringRef.h"
12 
13 using namespace mlir;
14 using namespace mlir::amdgpu;
15 
17  if (!name.starts_with("gfx"))
18  return failure();
19  unsigned major = 0;
20  unsigned minor = 0;
21  StringRef majorRef = name.drop_front(3).drop_back(2);
22  StringRef minorRef = name.take_back(2);
23  if (majorRef.getAsInteger(10, major))
24  return failure();
25  if (minorRef.getAsInteger(16, minor))
26  return failure();
27  return Chipset(major, minor);
28 }
This class provides support for representing a failure result, or a valid value of type T.
Definition: LogicalResult.h:78
Include the generated interface declarations.
LogicalResult failure(bool isFailure=true)
Utility function to generate a LogicalResult.
Definition: LogicalResult.h:62
static FailureOr< Chipset > parse(StringRef name)
Definition: Chipset.cpp:16