File: external_func.mmd

package info (click to toggle)
apache-arrow 23.0.1-1
  • links: PTS
  • area: main
  • in suites: sid
  • size: 76,220 kB
  • sloc: cpp: 654,608; python: 70,522; ruby: 45,964; ansic: 18,742; sh: 7,365; makefile: 669; javascript: 125; xml: 41
file content (49 lines) | stat: -rw-r--r-- 1,909 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
%% 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;