1 | //===-- Execute.cpp -- generate command line runtime API calls ------------===// |
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 | |
9 | #include "flang/Optimizer/Builder/Runtime/Execute.h" |
10 | #include "flang/Optimizer/Builder/FIRBuilder.h" |
11 | #include "flang/Optimizer/Builder/Runtime/RTBuilder.h" |
12 | #include "flang/Runtime/execute.h" |
13 | |
14 | using namespace Fortran::runtime; |
15 | |
16 | // Certain runtime intrinsics should only be run when select parameters of the |
17 | // intrisic are supplied. In certain cases one of these parameters may not be |
18 | // given, however the intrinsic needs to be run due to another required |
19 | // parameter being supplied. In this case the missing parameter is assigned to |
20 | // have an "absent" value. This typically happens in IntrinsicCall.cpp. For this |
21 | // reason the extra indirection with `isAbsent` is needed for testing whether a |
22 | // given parameter is actually present (so that parameters with "value" absent |
23 | // are not considered as present). |
24 | inline bool isAbsent(mlir::Value val) { |
25 | return mlir::isa_and_nonnull<fir::AbsentOp>(val.getDefiningOp()); |
26 | } |
27 | |
28 | void fir::runtime::genExecuteCommandLine(fir::FirOpBuilder &builder, |
29 | mlir::Location loc, |
30 | mlir::Value command, mlir::Value wait, |
31 | mlir::Value exitstat, |
32 | mlir::Value cmdstat, |
33 | mlir::Value cmdmsg) { |
34 | auto runtimeFunc = |
35 | fir::runtime::getRuntimeFunc<mkRTKey(ExecuteCommandLine)>(loc, builder); |
36 | mlir::FunctionType runtimeFuncTy = runtimeFunc.getFunctionType(); |
37 | mlir::Value sourceFile = fir::factory::locationToFilename(builder, loc); |
38 | mlir::Value sourceLine = |
39 | fir::factory::locationToLineNo(builder, loc, runtimeFuncTy.getInput(6)); |
40 | llvm::SmallVector<mlir::Value> args = fir::runtime::createArguments( |
41 | builder, loc, runtimeFuncTy, command, wait, exitstat, cmdstat, cmdmsg, |
42 | sourceFile, sourceLine); |
43 | builder.create<fir::CallOp>(loc, runtimeFunc, args); |
44 | } |
45 | |