blob: 755424bfa4203d969abb95ff439da316f78911cf [file] [log] [blame]
%% Licensed to the Apache Software Foundation (ASF) under one
%% or more contributor license agreements. See the NOTICE file
%% distributed with this work for additional information
%% regarding copyright ownership. The ASF licenses this file
%% to you under the Apache License, Version 2.0 (the
%% "License"); you may not use this file except in compliance
%% with the License. You may obtain a copy of the License at
%%
%% http://www.apache.org/licenses/LICENSE-2.0
%%
%% Unless required by applicable law or agreed to in writing,
%% software distributed under the License is distributed on an
%% "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
%% KIND, either express or implied. See the License for the
%% specific language governing permissions and limitations
%% under the License.
graph TD
Rust(Rust) --> CFunction(C function)
Cpp(C++) --> CFunction
OtherLangs(Other langs) --> CFunction
C(C) --clang--> LLVMIR(LLVM IR)
Cpp1(C++) --clang--> LLVMIR
OtherLangs1(Other langs) --rustc/etc--> LLVMIR
LLVMIR --LLVM toolchain--> LLVMBitcode(LLVM bitcode)
CFunction --> Application(application)
LLVMBitcode --> Application
Application --Register--> FunctionRegistry
subgraph Gandiva
BuiltInIRFunctions(built-in IR functions) --> LLVMGenerator(LLVMGenerator)
BuiltInCFunctions(built-in C functions) --> LLVMGenerator
FunctionRegistry(FunctionRegistry) --> LLVMGenerator
LLVMGenerator --> LLVMJITEngine(LLVM JIT engine)
LLVMJITEngine --codegen--> MachineCode(machine code)
end
classDef node stroke-width:0px;
class Rust,Cpp,OtherLangs,C,Cpp1,OtherLangs1,LLVMIR,LLVMBitcode,CFunction,Application,BuiltInIRFunctions,BuiltInCFunctions,FunctionRegistry,LLVMGenerator,LLVMJITEngine,MachineCode node;
classDef subGraph fill:#f5f5f5,stroke:#5a5a5a,stroke-width:2px,rx:10,ry:10;
class Gandiva subGraph;