2012-07-26 16:04:09 +08:00
|
|
|
This file is a list of the people responsible for ensuring that patches for a
|
|
|
|
particular part of LLVM are reviewed, either by themself or by someone else.
|
|
|
|
They are also the gatekeepers for their part of LLVM, with the final word on
|
|
|
|
what goes in or not.
|
|
|
|
|
|
|
|
The list is sorted by surname and formatted to allow easy grepping and
|
2016-08-03 03:25:17 +08:00
|
|
|
beautification by scripts. The fields are: name (N), email (E), web-address
|
2017-03-11 02:34:37 +08:00
|
|
|
(W), PGP key ID and fingerprint (P), description (D), snail-mail address
|
|
|
|
(S) and (I) IRC handle. Each entry should contain at least the (N), (E) and
|
|
|
|
(D) fields.
|
2012-07-26 16:04:09 +08:00
|
|
|
|
2018-06-21 17:59:44 +08:00
|
|
|
N: Simon Atanasyan
|
|
|
|
E: simon@atanasyan.com
|
|
|
|
D: MIPS Backend (lib/Target/Mips/*)
|
|
|
|
|
2014-12-11 08:41:15 +08:00
|
|
|
N: Justin Bogner
|
|
|
|
E: mail@justinbogner.com
|
|
|
|
D: InstrProfiling and related parts of ProfileData
|
2016-05-21 03:14:04 +08:00
|
|
|
D: SelectionDAG (lib/CodeGen/SelectionDAG/*)
|
2014-12-11 08:41:15 +08:00
|
|
|
|
2016-11-02 01:27:54 +08:00
|
|
|
N: Alex Bradbury
|
|
|
|
E: asb@lowrisc.org
|
|
|
|
D: RISC-V backend (lib/Target/RISCV/*)
|
|
|
|
|
2017-03-11 02:34:37 +08:00
|
|
|
N: Matthias Braun
|
|
|
|
E: matze@braunis.de
|
|
|
|
I: MatzeB
|
|
|
|
D: Instruction Scheduling
|
|
|
|
|
2012-11-16 19:43:01 +08:00
|
|
|
N: Chandler Carruth
|
|
|
|
E: chandlerc@gmail.com
|
|
|
|
E: chandlerc@google.com
|
2013-04-17 11:18:49 +08:00
|
|
|
D: Config, ADT, Support, inlining & related passes, SROA/mem2reg & related passes, CMake, library layering
|
2012-11-16 19:43:01 +08:00
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Evan Cheng
|
|
|
|
E: evan.cheng@apple.com
|
2015-10-27 07:33:13 +08:00
|
|
|
D: parts of code generator not covered by someone else
|
2012-07-26 16:04:09 +08:00
|
|
|
|
2012-11-15 02:17:45 +08:00
|
|
|
N: Eric Christopher
|
|
|
|
E: echristo@gmail.com
|
2016-01-30 09:10:15 +08:00
|
|
|
D: Debug Information, inline assembly
|
2012-11-15 02:17:45 +08:00
|
|
|
|
2017-03-11 02:34:33 +08:00
|
|
|
N: Andrey Churbanov
|
|
|
|
E: andrey.churbanov@intel.com
|
|
|
|
D: OpenMP runtime library
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Greg Clayton
|
2017-08-24 02:00:07 +08:00
|
|
|
E: clayborg@gmail.com
|
2012-07-26 16:04:09 +08:00
|
|
|
D: LLDB
|
|
|
|
|
2017-08-24 23:40:33 +08:00
|
|
|
N: Pete Couperus
|
|
|
|
E: petecoup@synopsys.com
|
|
|
|
D: ARC backend (lib/Target/ARC/*)
|
|
|
|
|
2016-05-27 05:12:44 +08:00
|
|
|
N: Sanjoy Das
|
|
|
|
E: sanjoy@playingwithpointers.com
|
|
|
|
D: IndVar Simplify, Scalar Evolution
|
|
|
|
|
2014-12-11 08:41:15 +08:00
|
|
|
N: Marshall Clow
|
|
|
|
E: mclow.lists@gmail.com
|
|
|
|
D: libc++
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Peter Collingbourne
|
2014-08-05 03:33:25 +08:00
|
|
|
E: peter@pcc.me.uk
|
2017-02-09 05:16:27 +08:00
|
|
|
D: llgo, libLTO (lib/LTO/* tools/lto/*), LLVM Bitcode (lib/Bitcode/* include/llvm/Bitcode/*)
|
2012-07-26 16:04:09 +08:00
|
|
|
|
2015-03-06 06:15:17 +08:00
|
|
|
N: Quentin Colombet
|
2018-04-24 03:09:49 +08:00
|
|
|
E: quentin.colombet@gmail.com
|
2016-12-01 03:55:49 +08:00
|
|
|
D: Loop Strength Reduction, Register allocators
|
2015-03-06 06:15:17 +08:00
|
|
|
|
2018-04-20 18:16:31 +08:00
|
|
|
N: Andrea Di Biagio
|
|
|
|
E: andrea.dibiagio@sony.com
|
|
|
|
E: andrea.dibiagio@gmail.com
|
|
|
|
D: llvm-mca
|
|
|
|
|
2014-12-11 08:52:59 +08:00
|
|
|
N: Duncan P. N. Exon Smith
|
|
|
|
E: dexonsmith@apple.com
|
|
|
|
D: Branch weights and BlockFrequencyInfo
|
|
|
|
|
2012-11-14 15:59:10 +08:00
|
|
|
N: Hal Finkel
|
|
|
|
E: hfinkel@anl.gov
|
2017-06-30 15:09:08 +08:00
|
|
|
D: The loop reroller, alias analysis and the PowerPC target
|
2012-11-14 15:59:10 +08:00
|
|
|
|
2015-06-30 07:51:55 +08:00
|
|
|
N: Dan Gohman
|
|
|
|
E: sunfish@mozilla.com
|
|
|
|
D: WebAssembly Backend (lib/Target/WebAssembly/*)
|
|
|
|
|
2014-12-11 08:52:59 +08:00
|
|
|
N: Renato Golin
|
|
|
|
E: renato.golin@linaro.org
|
|
|
|
D: ARM Linux support
|
|
|
|
|
2012-11-23 06:14:48 +08:00
|
|
|
N: Venkatraman Govindaraju
|
|
|
|
E: venkatra@cs.wisc.edu
|
|
|
|
D: Sparc Backend (lib/Target/Sparc/*)
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Tobias Grosser
|
2014-08-05 03:33:25 +08:00
|
|
|
E: tobias@grosser.es
|
2012-07-26 16:04:09 +08:00
|
|
|
D: Polly
|
|
|
|
|
2012-11-15 02:17:45 +08:00
|
|
|
N: James Grosbach
|
|
|
|
E: grosbach@apple.com
|
|
|
|
D: MC layer
|
|
|
|
|
2012-11-15 03:36:27 +08:00
|
|
|
N: Justin Holewinski
|
|
|
|
E: jholewinski@nvidia.com
|
|
|
|
D: NVPTX Target (lib/Target/NVPTX/*)
|
|
|
|
|
2014-07-18 04:23:31 +08:00
|
|
|
N: Lang Hames
|
|
|
|
E: lhames@gmail.com
|
2016-04-02 04:40:49 +08:00
|
|
|
D: MCJIT, RuntimeDyld and JIT event listeners, Orcish Warchief
|
2012-11-17 07:56:48 +08:00
|
|
|
|
2016-07-06 04:49:50 +08:00
|
|
|
N: Teresa Johnson
|
|
|
|
E: tejohnson@google.com
|
2017-02-16 07:45:21 +08:00
|
|
|
D: Gold plugin (tools/gold/*) and IR Linker
|
2016-07-06 04:49:50 +08:00
|
|
|
|
2012-11-16 07:16:47 +08:00
|
|
|
N: Galina Kistanova
|
|
|
|
E: gkistanova@gmail.com
|
|
|
|
D: LLVM Buildbot
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Anton Korobeynikov
|
2012-11-16 03:10:23 +08:00
|
|
|
E: anton@korobeynikov.info
|
|
|
|
D: Exception handling, Windows codegen, ARM EABI
|
2012-07-26 16:04:09 +08:00
|
|
|
|
2012-11-15 02:17:45 +08:00
|
|
|
N: Benjamin Kramer
|
|
|
|
E: benny.kra@gmail.com
|
|
|
|
D: DWARF Parser
|
|
|
|
|
2016-11-09 02:44:40 +08:00
|
|
|
N: Michael Kuperstein
|
|
|
|
E: mkuper@google.com
|
|
|
|
D: Loop Vectorizer
|
|
|
|
|
2012-11-16 03:24:19 +08:00
|
|
|
N: Sergei Larin
|
|
|
|
E: slarin@codeaurora.org
|
|
|
|
D: VLIW Instruction Scheduling, Packetization
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Chris Lattner
|
|
|
|
E: sabre@nondot.org
|
|
|
|
W: http://nondot.org/~sabre/
|
|
|
|
D: Everything not covered by someone else
|
|
|
|
|
2016-07-22 03:20:57 +08:00
|
|
|
N: Robert Lytton
|
|
|
|
E: robert@xmos.com
|
|
|
|
D: XCore Backend
|
|
|
|
|
2015-09-07 08:41:40 +08:00
|
|
|
N: David Majnemer
|
|
|
|
E: david.majnemer@gmail.com
|
|
|
|
D: IR Constant Folder, InstCombine
|
|
|
|
|
2015-10-28 08:24:54 +08:00
|
|
|
N: Dylan McKay
|
2017-02-08 18:38:06 +08:00
|
|
|
E: me@dylanmckay.io
|
2015-10-28 08:24:54 +08:00
|
|
|
D: AVR Backend
|
|
|
|
|
2013-01-31 20:51:16 +08:00
|
|
|
N: Tim Northover
|
2014-03-14 02:04:41 +08:00
|
|
|
E: t.p.northover@gmail.com
|
2015-10-27 07:33:13 +08:00
|
|
|
D: AArch64 backend, misc ARM backend
|
2013-01-31 20:51:16 +08:00
|
|
|
|
2014-12-11 08:41:15 +08:00
|
|
|
N: Diego Novillo
|
|
|
|
E: dnovillo@google.com
|
|
|
|
D: SampleProfile and related parts of ProfileData
|
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Jakob Olesen
|
2014-08-05 03:33:25 +08:00
|
|
|
E: stoklund@2pi.dk
|
2015-03-06 06:15:17 +08:00
|
|
|
D: TableGen
|
2012-07-26 16:04:09 +08:00
|
|
|
|
2015-12-04 01:07:12 +08:00
|
|
|
N: Krzysztof Parzyszek
|
|
|
|
E: kparzysz@codeaurora.org
|
|
|
|
D: Hexagon Backend
|
|
|
|
|
2016-03-28 21:09:54 +08:00
|
|
|
N: Jacques Pienaar
|
|
|
|
E: jpienaar@google.com
|
|
|
|
D: Lanai Backend
|
|
|
|
|
2015-12-20 04:04:03 +08:00
|
|
|
N: Paul Robinson
|
|
|
|
E: paul_robinson@playstation.sony.com
|
|
|
|
D: Sony PlayStation®4 support
|
|
|
|
|
2012-11-15 02:43:21 +08:00
|
|
|
N: Chad Rosier
|
2013-11-16 01:35:29 +08:00
|
|
|
E: mcrosier@codeaurora.org
|
2012-11-27 08:48:36 +08:00
|
|
|
D: Fast-Isel
|
2012-11-15 02:43:21 +08:00
|
|
|
|
2012-07-26 16:04:09 +08:00
|
|
|
N: Duncan Sands
|
|
|
|
E: baldrick@free.fr
|
|
|
|
D: DragonEgg
|
2012-11-14 06:32:15 +08:00
|
|
|
|
2013-06-27 16:47:12 +08:00
|
|
|
N: Kostya Serebryany
|
|
|
|
E: kcc@google.com
|
|
|
|
D: AddressSanitizer, ThreadSanitizer (LLVM parts)
|
|
|
|
|
2013-01-15 17:37:45 +08:00
|
|
|
N: Michael Spencer
|
|
|
|
E: bigcheesegs@gmail.com
|
|
|
|
D: Windows parts of Support, Object, ar, nm, objdump, ranlib, size
|
|
|
|
|
BPF backend
Summary:
V8->V9:
- cleanup tests
V7->V8:
- addressed feedback from David:
- switched to range-based 'for' loops
- fixed formatting of tests
V6->V7:
- rebased and adjusted AsmPrinter args
- CamelCased .td, fixed formatting, cleaned up names, removed unused patterns
- diffstat: 3 files changed, 203 insertions(+), 227 deletions(-)
V5->V6:
- addressed feedback from Chandler:
- reinstated full verbose standard banner in all files
- fixed variables that were not in CamelCase
- fixed names of #ifdef in header files
- removed redundant braces in if/else chains with single statements
- fixed comments
- removed trailing empty line
- dropped debug annotations from tests
- diffstat of these changes:
46 files changed, 456 insertions(+), 469 deletions(-)
V4->V5:
- fix setLoadExtAction() interface
- clang-formated all where it made sense
V3->V4:
- added CODE_OWNERS entry for BPF backend
V2->V3:
- fix metadata in tests
V1->V2:
- addressed feedback from Tom and Matt
- removed top level change to configure (now everything via 'experimental-backend')
- reworked error reporting via DiagnosticInfo (similar to R600)
- added few more tests
- added cmake build
- added Triple::bpf
- tested on linux and darwin
V1 cover letter:
---------------------
recently linux gained "universal in-kernel virtual machine" which is called
eBPF or extended BPF. The name comes from "Berkeley Packet Filter", since
new instruction set is based on it.
This patch adds a new backend that emits extended BPF instruction set.
The concept and development are covered by the following articles:
http://lwn.net/Articles/599755/
http://lwn.net/Articles/575531/
http://lwn.net/Articles/603983/
http://lwn.net/Articles/606089/
http://lwn.net/Articles/612878/
One of use cases: dtrace/systemtap alternative.
bpf syscall manpage:
https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=b4fc1a460f3017e958e6a8ea560ea0afd91bf6fe
instruction set description and differences vs classic BPF:
http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/networking/filter.txt
Short summary of instruction set:
- 64-bit registers
R0 - return value from in-kernel function, and exit value for BPF program
R1 - R5 - arguments from BPF program to in-kernel function
R6 - R9 - callee saved registers that in-kernel function will preserve
R10 - read-only frame pointer to access stack
- two-operand instructions like +, -, *, mov, load/store
- implicit prologue/epilogue (invisible stack pointer)
- no floating point, no simd
Short history of extended BPF in kernel:
interpreter in 3.15, x64 JIT in 3.16, arm64 JIT, verifier, bpf syscall in 3.18, more to come in the future.
It's a very small and simple backend.
There is no support for global variables, arbitrary function calls, floating point, varargs,
exceptions, indirect jumps, arbitrary pointer arithmetic, alloca, etc.
From C front-end point of view it's very restricted. It's done on purpose, since kernel
rejects all programs that it cannot prove safe. It rejects programs with loops
and with memory accesses via arbitrary pointers. When kernel accepts the program it is
guaranteed that program will terminate and will not crash the kernel.
This patch implements all 'must have' bits. There are several things on TODO list,
so this is not the end of development.
Most of the code is a boiler plate code, copy-pasted from other backends.
Only odd things are lack or < and <= instructions, specialized load_byte intrinsics
and 'compare and goto' as single instruction.
Current instruction set is fixed, but more instructions can be added in the future.
Signed-off-by: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Subscribers: majnemer, chandlerc, echristo, joerg, pete, rengolin, kristof.beyls, arsenm, t.p.northover, tstellarAMD, aemerson, llvm-commits
Differential Revision: http://reviews.llvm.org/D6494
llvm-svn: 227008
2015-01-25 01:51:26 +08:00
|
|
|
N: Alexei Starovoitov
|
|
|
|
E: alexei.starovoitov@gmail.com
|
|
|
|
D: BPF backend
|
|
|
|
|
2012-12-20 06:10:35 +08:00
|
|
|
N: Tom Stellard
|
2017-02-10 05:29:12 +08:00
|
|
|
E: tstellar@redhat.com
|
|
|
|
D: Stable release management (x.y.[1-9] releases), AMDGPU Backend, libclc
|
2012-12-20 06:10:35 +08:00
|
|
|
|
2013-06-27 16:47:12 +08:00
|
|
|
N: Evgeniy Stepanov
|
|
|
|
E: eugenis@google.com
|
|
|
|
D: MemorySanitizer (LLVM part)
|
|
|
|
|
2016-11-12 13:16:06 +08:00
|
|
|
N: Craig Topper
|
|
|
|
E: craig.topper@gmail.com
|
2017-06-24 11:26:01 +08:00
|
|
|
E: craig.topper@intel.com
|
2016-11-12 13:16:06 +08:00
|
|
|
D: X86 Backend
|
|
|
|
|
2014-12-19 03:27:50 +08:00
|
|
|
N: Ulrich Weigand
|
|
|
|
E: uweigand@de.ibm.com
|
|
|
|
D: SystemZ Backend
|
|
|
|
|
2016-05-27 07:10:37 +08:00
|
|
|
N: Hans Wennborg
|
|
|
|
E: hans@chromium.org
|
|
|
|
D: Release management (x.y.0 releases)
|
|
|
|
|
2016-09-06 01:42:46 +08:00
|
|
|
N: whitequark
|
2013-11-13 12:24:13 +08:00
|
|
|
E: whitequark@whitequark.org
|
2018-04-17 09:09:12 +08:00
|
|
|
D: C API, OCaml bindings
|
2018-08-10 06:05:19 +08:00
|
|
|
|
|
|
|
N: Jake Ehrlich
|
|
|
|
E: jakehehrlich@google.com
|
|
|
|
D: llvm-objcopy (tools/llvm-objcopy)
|
2018-11-29 18:58:15 +08:00
|
|
|
|
|
|
|
N: Martin Storsjö
|
|
|
|
E: martin@martin.st
|
|
|
|
D: MinGW
|