Don't fold address calculations which use negative offsets into
[oota-llvm.git] / CREDITS.TXT
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
4 done!
5
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
9 (S).
10
11 N: Vikram Adve
12 E: vadve@cs.uiuc.edu
13 W: http://www.cs.uiuc.edu/~vadve/
14 D: The Sparc64 backend, provider of much wisdom, and motivator for LLVM
15
16 N: Owen Anderson
17 E: resistor@mac.com
18 D: LCSSA pass and related LoopUnswitch work
19 D: GVNPRE pass, TargetData refactoring, random improvements
20
21 N: Henrik Bach
22 D: MingW Win32 API portability layer
23
24 N: Nate Begeman
25 E: natebegeman@mac.com
26 D: PowerPC backend developer
27 D: Target-independent code generator and analysis improvements
28
29 N: Daniel Berlin
30 E: dberlin@dberlin.org
31 D: ET-Forest implementation.
32 D: Sparse bitmap
33
34 N: Neil Booth
35 E: neil@daikokuya.co.uk
36 D: APFloat implementation.
37
38 N: Misha Brukman
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
43
44 N: Cameron Buschardt
45 E: buschard@uiuc.edu
46 D: The `mem2reg' pass - promotes values stored in memory to registers
47
48 N: Chandler Carruth
49 E: chandlerc@gmail.com
50 D: LinkTimeOptimizer for Linux, via binutils integration, and C API
51
52 N: Casey Carter
53 E: ccarter@uiuc.edu
54 D: Fixes to the Reassociation pass, various improvement patches
55
56 N: Evan Cheng
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
63
64 N: Jeff Cohen
65 E: jeffc@jolt-lang.org
66 W: http://jolt-lang.org
67 D: Native Win32 API portability layer
68
69 N: John T. Criswell
70 E: criswell@uiuc.edu
71 D: Original Autoconf support, documentation improvements, bug fixes
72
73 N: Rafael Avila de Espindola
74 E: rafael.espindola@gmail.com
75 D: The ARM backend
76
77 N: Alkis Evlogimenos
78 E: alkis@evlogimenos.com
79 D: Linear scan register allocator, many codegen improvements, Java frontend
80
81 N: Brian Gaeke
82 E: gaeke@uiuc.edu
83 W: http://www.students.uiuc.edu/~gaeke/
84 D: Portions of X86 static and JIT compilers; initial SparcV8 backend
85 D: Dynamic trace optimizer
86 D: FreeBSD/X86 compatibility fixes, the llvm-nm tool
87
88 N: Nicolas Geoffray
89 E: nicolas.geoffray@lip6.fr
90 W: http://www-src.lip6.fr/homepages/Nicolas.Geoffray/
91 D: PPC backend fixes for Linux
92
93 N: Louis Gerbarg
94 D: Portions of the PowerPC backend
95
96 N: Saem Ghani
97 E: saemghani@gmail.com
98 D: Callgraph class cleanups
99
100 N: Mikhail Glushenkov
101 E: foldr@codedgers.com
102 D: Author of llvmc2
103
104 N: Dan Gohman
105 E: gohman@apple.com
106 D: Miscellaneous bug fixes
107
108 N: David Greene
109 E: greened@obbligato.org
110 D: Miscellaneous bug fixes
111 D: Register allocation refactoring
112
113 N: Gabor Greif
114 E: ggreif@gmail.com
115 D: Improvements for space efficiency
116
117 N: Lang Hames
118 E: lhames@gmail.com
119 D: PBQP-based register allocator
120
121 N: Gordon Henriksen
122 E: gordonhenriksen@mac.com
123 D: Pluggable GC support
124 D: C interface
125 D: Ocaml bindings
126
127 N: Raul Fernandes Herbster
128 E: raul@dsc.ufcg.edu.br
129 D: JIT support for ARM
130
131 N: Paolo Invernizzi
132 E: arathorn@fastwebnet.it
133 D: Visual C++ compatibility fixes
134
135 N: Patrick Jenkins
136 E: patjenk@wam.umd.edu
137 D: Nightly Tester
138
139 N: Brad Jones
140 E: kungfoomaster@nondot.org
141 D: Support for packed types
142
143 N: Dale Johannesen
144 E: dalej@apple.com
145 D: ARM constant islands improvements
146 D: Tail merging improvements
147 D: Rewrite X87 back end
148 D: Use APFloat for floating point constants widely throughout compiler
149 D: Implement X87 long double
150
151 N: Eric Kidd
152 W: http://randomhacks.net/
153 D: llvm-config script
154
155 N: Anton Korobeynikov
156 E: asl@math.spbu.ru
157 D: Mingw32 fixes, cross-compiling support, stdcall/fastcall calling conv.
158 D: x86/linux PIC codegen, aliases, regparm/visibility attributes
159 D: Switch lowering refactoring
160
161 N: Sumant Kowshik
162 E: kowshik@uiuc.edu
163 D: Author of the original C backend
164
165 N: Christopher Lamb
166 E: christopher.lamb@gmail.com
167 D: aligned load/store support, parts of noalias and restrict support
168 D: vreg subreg infrastructure, X86 codegen improvements based on subregs
169 D: address spaces
170
171 N: Jim Laskey
172 E: jlaskey@apple.com
173 D: Improvements to the PPC backend, instruction scheduling
174 D: Debug and Dwarf implementation
175 D: Auto upgrade mangler
176 D: llvm-gcc4 svn wrangler
177
178 N: Chris Lattner
179 E: sabre@nondot.org
180 W: http://nondot.org/~sabre/
181 D: Primary architect of LLVM
182
183 N: Tanya Lattner (Tanya Brethour)
184 E: tonic@nondot.org
185 W: http://nondot.org/~tonic/
186 D: The initial llvm-ar tool, converted regression testsuite to dejagnu
187 D: Modulo scheduling in the SparcV9 backend
188 D: Release manager (1.7+)
189
190 N: Andrew Lenharth
191 E: alenhar2@cs.uiuc.edu
192 W: http://www.lenharth.org/~andrewl/
193 D: Alpha backend
194 D: Sampling based profiling
195
196 N: Nick Lewycky
197 E: nicholas@mxc.ca
198 D: PredicateSimplifier pass
199
200 N: Bruno Cardoso Lopes
201 E: bruno.cardoso@gmail.com
202 W: http://www.brunocardoso.org
203 D: The Mips backend
204
205 N: Duraid Madina
206 E: duraid@octopus.com.au
207 W: http://kinoko.c.u-tokyo.ac.jp/~duraid/
208 D: IA64 backend, BigBlock register allocator
209
210 N: Michael McCracken
211 E: michael.mccracken@gmail.com
212 D: Line number support for llvmgcc
213
214 N: Vladimir Merzliakov
215 E: wanderer@rsu.ru
216 D: Test suite fixes for FreeBSD
217
218 N: Scott Michel
219 E: scottm@aero.org
220 D: Added STI Cell SPU backend.
221
222 N: Morten Ofstad
223 E: morten@hue.no
224 D: Visual C++ compatibility fixes
225
226 N: Richard Osborne
227 E: richard@xmos.com
228 D: XCore backend
229
230 N: Devang Patel
231 E: dpatel@apple.com
232 D: LTO tool, PassManager rewrite, Loop Pass Manager, Loop Rotate
233 D: GCC PCH Integration (llvm-gcc), llvm-gcc improvements
234 D: Optimizer improvements, Loop Index Split
235
236 N: Vladimir Prus
237 W: http://vladimir_prus.blogspot.com
238 E: ghost@cs.msu.su
239 D: Made inst_iterator behave like a proper iterator, LowerConstantExprs pass
240
241 N: Roman Samoilov
242 E: roman@codedgers.com
243 D: MSIL backend
244
245 N: Duncan Sands
246 E: baldrick@free.fr
247 D: Ada front-end, exception handling improvements
248
249 N: Ruchira Sasanka
250 E: sasanka@uiuc.edu
251 D: Graph coloring register allocator for the Sparc64 backend
252
253 N: Arnold Schwaighofer
254 E: arnold.schwaighofer@gmail.com
255 D: Tail call optimization for the x86 backend
256
257 N: Anand Shukla
258 E: ashukla@cs.uiuc.edu
259 D: The `paths' pass
260
261 N: Reid Spencer
262 E: rspencer@reidspencer.com
263 W: http://reidspencer.com/
264 D: Lots of stuff, see: http://wiki.llvm.org/index.php/User:Reid
265
266 N: Adam Treat
267 E: manyoso@yahoo.com
268 D: C++ bugs filed, and C++ front-end bug fixes.
269
270 N: Lauro Ramos Venancio
271 E: lauro.venancio@indt.org.br
272 D: ARM backend improvements
273 D: Thread Local Storage implementation
274
275 N: Bill Wendling
276 E: isanbard@gmail.com
277 D: Machine LICM
278 D: Darwin exception handling
279 D: MMX & SSSE3 instructions
280 D: SPEC2006 support