1 This file is a partial list of people who have contributed to the LLVM
2 project. If you have contributed a patch or made some other contribution to
3 LLVM, please submit a patch to this file to add yourself, and it will be
6 The list is sorted by name and formatted to allow easy grepping and
7 beautification by scripts. The fields are: name (N), email (E), web-address
8 (W), PGP key ID and fingerprint (P), description (D), and snail-mail address
13 W: http://www.cs.uiuc.edu/~vadve/
14 D: The Sparc64 backend, provider of much wisdom, and motivator for LLVM
18 D: LCSSA pass and related LoopUnswitch work
19 D: GVNPRE pass, TargetData refactoring, random improvements
22 D: MingW Win32 API portability layer
25 E: natebegeman@mac.com
26 D: PowerPC backend developer
27 D: Target-independent code generator and analysis improvements
30 E: dberlin@dberlin.org
31 D: ET-Forest implementation.
35 E: neil@daikokuya.co.uk
36 D: APFloat implementation.
39 E: brukman+llvm@uiuc.edu
40 W: http://misha.brukman.net
41 D: Portions of X86 and Sparc JIT compilers, PowerPC backend
42 D: Incremental bytecode loader
46 D: The `mem2reg' pass - promotes values stored in memory to registers
49 E: chandlerc@gmail.com
50 D: LinkTimeOptimizer for Linux, via binutils integration, and C API
54 D: Fixes to the Reassociation pass, various improvement patches
57 E: evan.cheng@apple.com
58 D: ARM and X86 backends
59 D: Instruction scheduler improvements
60 D: Register allocator improvements
61 D: Loop optimizer improvements
62 D: Target-independent code generator improvements
64 N: Dan Villiom Podlaski Christiansen
68 D: LLVM Makefile improvements
69 D: Clang diagnostic & driver tweaks
73 E: jeffc@jolt-lang.org
74 W: http://jolt-lang.org
75 D: Native Win32 API portability layer
79 D: Original Autoconf support, documentation improvements, bug fixes
81 N: Rafael Avila de Espindola
82 E: rafael.espindola@gmail.com
86 E: alkis@evlogimenos.com
87 D: Linear scan register allocator, many codegen improvements, Java frontend
91 W: http://www.students.uiuc.edu/~gaeke/
92 D: Portions of X86 static and JIT compilers; initial SparcV8 backend
93 D: Dynamic trace optimizer
94 D: FreeBSD/X86 compatibility fixes, the llvm-nm tool
97 E: nicolas.geoffray@lip6.fr
98 W: http://www-src.lip6.fr/homepages/Nicolas.Geoffray/
99 D: PPC backend fixes for Linux
102 D: Portions of the PowerPC backend
105 E: saemghani@gmail.com
106 D: Callgraph class cleanups
108 N: Mikhail Glushenkov
109 E: foldr@codedgers.com
114 D: Miscellaneous bug fixes
117 E: greened@obbligato.org
118 D: Miscellaneous bug fixes
119 D: Register allocation refactoring
123 D: Improvements for space efficiency
127 D: PBQP-based register allocator
130 E: gordonhenriksen@mac.com
131 D: Pluggable GC support
135 N: Raul Fernandes Herbster
136 E: raul@dsc.ufcg.edu.br
137 D: JIT support for ARM
140 E: arathorn@fastwebnet.it
141 D: Visual C++ compatibility fixes
144 E: patjenk@wam.umd.edu
148 E: kungfoomaster@nondot.org
149 D: Support for packed types
153 D: ARM constant islands improvements
154 D: Tail merging improvements
155 D: Rewrite X87 back end
156 D: Use APFloat for floating point constants widely throughout compiler
157 D: Implement X87 long double
160 W: http://randomhacks.net/
161 D: llvm-config script
163 N: Anton Korobeynikov
165 D: Mingw32 fixes, cross-compiling support, stdcall/fastcall calling conv.
166 D: x86/linux PIC codegen, aliases, regparm/visibility attributes
167 D: Switch lowering refactoring
171 D: Author of the original C backend
174 E: christopher.lamb@gmail.com
175 D: aligned load/store support, parts of noalias and restrict support
176 D: vreg subreg infrastructure, X86 codegen improvements based on subregs
181 D: Improvements to the PPC backend, instruction scheduling
182 D: Debug and Dwarf implementation
183 D: Auto upgrade mangler
184 D: llvm-gcc4 svn wrangler
188 W: http://nondot.org/~sabre/
189 D: Primary architect of LLVM
191 N: Tanya Lattner (Tanya Brethour)
193 W: http://nondot.org/~tonic/
194 D: The initial llvm-ar tool, converted regression testsuite to dejagnu
195 D: Modulo scheduling in the SparcV9 backend
196 D: Release manager (1.7+)
199 E: alenhar2@cs.uiuc.edu
200 W: http://www.lenharth.org/~andrewl/
202 D: Sampling based profiling
206 D: PredicateSimplifier pass
208 N: Bruno Cardoso Lopes
209 E: bruno.cardoso@gmail.com
210 W: http://www.brunocardoso.org
214 E: duraid@octopus.com.au
215 W: http://kinoko.c.u-tokyo.ac.jp/~duraid/
216 D: IA64 backend, BigBlock register allocator
219 E: michael.mccracken@gmail.com
220 D: Line number support for llvmgcc
222 N: Vladimir Merzliakov
224 D: Test suite fixes for FreeBSD
228 D: Added STI Cell SPU backend.
232 D: Visual C++ compatibility fixes
240 D: LTO tool, PassManager rewrite, Loop Pass Manager, Loop Rotate
241 D: GCC PCH Integration (llvm-gcc), llvm-gcc improvements
242 D: Optimizer improvements, Loop Index Split
245 W: http://vladimir_prus.blogspot.com
247 D: Made inst_iterator behave like a proper iterator, LowerConstantExprs pass
250 E: roman@codedgers.com
255 D: Ada front-end, exception handling improvements
259 D: Graph coloring register allocator for the Sparc64 backend
261 N: Arnold Schwaighofer
262 E: arnold.schwaighofer@gmail.com
263 D: Tail call optimization for the x86 backend
266 E: ashukla@cs.uiuc.edu
270 E: rspencer@reidspencer.com
271 W: http://reidspencer.com/
272 D: Lots of stuff, see: http://wiki.llvm.org/index.php/User:Reid
276 D: C++ bugs filed, and C++ front-end bug fixes.
278 N: Lauro Ramos Venancio
279 E: lauro.venancio@indt.org.br
280 D: ARM backend improvements
281 D: Thread Local Storage implementation
284 E: isanbard@gmail.com
286 D: Darwin exception handling
287 D: MMX & SSSE3 instructions