| // Copyright 2020 The IREE Authors |
| // |
| // Licensed 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 |
| |
| #include "iree/base/api.h" |
| #include "iree/base/internal/flags.h" |
| #include "iree/tooling/context_util.h" |
| #include "iree/tooling/run_module.h" |
| #include "iree/vm/api.h" |
| |
| int main(int argc, char** argv) { |
| IREE_TRACE_APP_ENTER(); |
| IREE_TRACE_ZONE_BEGIN(z0); |
| |
| // Parse command line flags. |
| iree_flags_set_usage( |
| "iree-run-module", |
| "Runs a function within a compiled IREE module and handles I/O parsing\n" |
| "and optional expected value verification/output processing. Modules\n" |
| "can be provided by file path (`--module=file.vmfb`) or read from stdin\n" |
| "(`--module=-`) and the function to execute matches the original name\n" |
| "provided to the compiler (`--function=foo` for `func.func @foo`).\n"); |
| iree_flags_parse_checked(IREE_FLAGS_PARSE_MODE_DEFAULT, &argc, &argv); |
| |
| // Hosting applications can provide their own allocators to pool resources or |
| // track allocation statistics related to IREE code. |
| iree_allocator_t host_allocator = iree_allocator_system(); |
| // Hosting applications should reuse instances across multiple contexts that |
| // have similar composition (similar types/modules/etc). Most applications can |
| // get by with a single shared instance. |
| iree_vm_instance_t* instance = NULL; |
| iree_status_t status = |
| iree_tooling_create_instance(host_allocator, &instance); |
| |
| // Utility to run the module with the command line flags. This particular |
| // method is only useful in these IREE tools that want consistent flags - |
| // a real application will need to do what this is doing with its own setup |
| // and I/O handling. |
| int exit_code = EXIT_SUCCESS; |
| if (iree_status_is_ok(status)) { |
| status = iree_tooling_run_module_from_flags(instance, host_allocator, |
| &exit_code); |
| } |
| |
| iree_vm_instance_release(instance); |
| |
| if (!iree_status_is_ok(status)) { |
| iree_status_fprint(stderr, status); |
| iree_status_free(status); |
| exit_code = EXIT_FAILURE; |
| } |
| |
| IREE_TRACE_ZONE_END(z0); |
| IREE_TRACE_APP_EXIT(exit_code); |
| return exit_code; |
| } |