[Codegen] Alter the default promotion for saturating adds and subs
[llvm-complete.git] / CREDITS.TXT
blobe998fa6bb257ded0def32205b76ba656b1e3bf2c
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!
6 The list is sorted by surname 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), snail-mail address
9 (S), and (I) IRC handle.
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
16 N: Owen Anderson
17 E: resistor@mac.com
18 D: LCSSA pass and related LoopUnswitch work
19 D: GVNPRE pass, DataLayout refactoring, random improvements
21 N: Henrik Bach
22 D: MingW Win32 API portability layer
24 N: Aaron Ballman
25 E: aaron@aaronballman.com
26 D: Clang frontend, frontend attributes, Windows support, general bug fixing
27 I: AaronBallman
29 N: Nate Begeman
30 E: natebegeman@mac.com
31 D: PowerPC backend developer
32 D: Target-independent code generator and analysis improvements
34 N: Daniel Berlin
35 E: dberlin@dberlin.org
36 D: ET-Forest implementation.
37 D: Sparse bitmap
39 N: Geoff Berry
40 E: gberry@codeaurora.org
41 E: gcb@acm.org
42 D: AArch64 backend improvements
43 D: Added EarlyCSE MemorySSA support
44 D: CodeGen improvements
46 N: David Blaikie
47 E: dblaikie@gmail.com
48 D: General bug fixing/fit & finish, mostly in Clang
50 N: Neil Booth
51 E: neil@daikokuya.co.uk
52 D: APFloat implementation.
54 N: Alex Bradbury
55 E: asb@lowrisc.org
56 D: RISC-V backend
58 N: Misha Brukman
59 E: brukman+llvm@uiuc.edu
60 W: http://misha.brukman.net
61 D: Portions of X86 and Sparc JIT compilers, PowerPC backend
62 D: Incremental bitcode loader
64 N: Cameron Buschardt
65 E: buschard@uiuc.edu
66 D: The `mem2reg' pass - promotes values stored in memory to registers
68 N: Brendon Cahoon
69 E: bcahoon@codeaurora.org
70 D: Loop unrolling with run-time trip counts.
72 N: Chandler Carruth
73 E: chandlerc@gmail.com
74 E: chandlerc@google.com
75 D: Hashing algorithms and interfaces
76 D: Inline cost analysis
77 D: Machine block placement pass
78 D: SROA
80 N: Casey Carter
81 E: ccarter@uiuc.edu
82 D: Fixes to the Reassociation pass, various improvement patches
84 N: Evan Cheng
85 E: evan.cheng@apple.com
86 D: ARM and X86 backends
87 D: Instruction scheduler improvements
88 D: Register allocator improvements
89 D: Loop optimizer improvements
90 D: Target-independent code generator improvements
92 N: Dan Villiom Podlaski Christiansen
93 E: danchr@gmail.com
94 E: danchr@cs.au.dk
95 W: http://villiom.dk
96 D: LLVM Makefile improvements
97 D: Clang diagnostic & driver tweaks
98 S: Aarhus, Denmark
100 N: Jeff Cohen
101 E: jeffc@jolt-lang.org
102 W: http://jolt-lang.org
103 D: Native Win32 API portability layer
105 N: John T. Criswell
106 E: criswell@uiuc.edu
107 D: Original Autoconf support, documentation improvements, bug fixes
109 N: Anshuman Dasgupta
110 E: adasgupt@codeaurora.org
111 D: Deterministic finite automaton based infrastructure for VLIW packetization
113 N: Stefanus Du Toit
114 E: stefanus.du.toit@intel.com
115 D: Bug fixes and minor improvements
117 N: Rafael Avila de Espindola
118 E: rafael@espindo.la
119 D: MC and LLD work
121 N: Dave Estes
122 E: cestes@codeaurora.org
123 D: AArch64 machine description for Cortex-A53
125 N: Alkis Evlogimenos
126 E: alkis@evlogimenos.com
127 D: Linear scan register allocator, many codegen improvements, Java frontend
129 N: Hal Finkel
130 E: hfinkel@anl.gov
131 D: Basic-block autovectorization, PowerPC backend improvements
133 N: Eric Fiselier
134 E: eric@efcs.ca
135 D: LIT patches and documentation
137 N: Ryan Flynn
138 E: pizza@parseerror.com
139 D: Miscellaneous bug fixes
141 N: Brian Gaeke
142 E: gaeke@uiuc.edu
143 W: http://www.students.uiuc.edu/~gaeke/
144 D: Portions of X86 static and JIT compilers; initial SparcV8 backend
145 D: Dynamic trace optimizer
146 D: FreeBSD/X86 compatibility fixes, the llvm-nm tool
148 N: Nicolas Geoffray
149 E: nicolas.geoffray@lip6.fr
150 W: http://www-src.lip6.fr/homepages/Nicolas.Geoffray/
151 D: PPC backend fixes for Linux
153 N: Louis Gerbarg
154 E: lgg@apple.com
155 D: Portions of the PowerPC backend
157 N: Saem Ghani
158 E: saemghani@gmail.com
159 D: Callgraph class cleanups
161 N: Mikhail Glushenkov
162 E: foldr@codedgers.com
163 D: Author of llvmc2
165 N: Dan Gohman
166 E: sunfish@mozilla.com
167 D: Miscellaneous bug fixes
168 D: WebAssembly Backend
170 N: Renato Golin
171 E: rengolin@systemcall.eu
172 E: renato.golin@linaro.org
173 E: rengolin@gmail.com
174 D: ARM/AArch64 back-end improvements
175 D: Loop Vectorizer improvements
176 D: Regression and Test Suite improvements
177 D: Linux compatibility (GNU, musl, etc)
178 D: Initial Linux kernel / Android support effort
179 I: rengolin
181 N: David Goodwin
182 E: david@goodwinz.net
183 D: Thumb-2 code generator
185 N: David Greene
186 E: greened@obbligato.org
187 D: Miscellaneous bug fixes
188 D: Register allocation refactoring
190 N: Gabor Greif
191 E: ggreif@gmail.com
192 D: Improvements for space efficiency
194 N: James Grosbach
195 E: grosbach@apple.com
196 I: grosbach
197 D: SjLj exception handling support
198 D: General fixes and improvements for the ARM back-end
199 D: MCJIT
200 D: ARM integrated assembler and assembly parser
201 D: Led effort for the backend formerly known as ARM64
203 N: Lang Hames
204 E: lhames@gmail.com
205 D: PBQP-based register allocator
207 N: Gordon Henriksen
208 E: gordonhenriksen@mac.com
209 D: Pluggable GC support
210 D: C interface
211 D: Ocaml bindings
213 N: Raul Fernandes Herbster
214 E: raul@dsc.ufcg.edu.br
215 D: JIT support for ARM
217 N: Paolo Invernizzi
218 E: arathorn@fastwebnet.it
219 D: Visual C++ compatibility fixes
221 N: Patrick Jenkins
222 E: patjenk@wam.umd.edu
223 D: Nightly Tester
225 N: Tony(Yanjun) Jiang
226 E: jtony@ca.ibm.com
227 D: PowerPC Backend Developer
228 D: Improvements to the PPC backend and miscellaneous bug fixes
230 N: Dale Johannesen
231 E: dalej@apple.com
232 D: ARM constant islands improvements
233 D: Tail merging improvements
234 D: Rewrite X87 back end
235 D: Use APFloat for floating point constants widely throughout compiler
236 D: Implement X87 long double
238 N: Brad Jones
239 E: kungfoomaster@nondot.org
240 D: Support for packed types
242 N: Rod Kay
243 E: rkay@auroraux.org
244 D: Author of LLVM Ada bindings
246 N: Erich Keane
247 E: erich.keane@intel.com
248 D: A variety of Clang contributions including function multiversioning, regcall/vectorcall.
249 I: ErichKeane
251 N: Eric Kidd
252 W: http://randomhacks.net/
253 D: llvm-config script
255 N: Anton Korobeynikov
256 E: anton at korobeynikov dot info
257 D: Mingw32 fixes, cross-compiling support, stdcall/fastcall calling conv.
258 D: x86/linux PIC codegen, aliases, regparm/visibility attributes
259 D: Switch lowering refactoring
261 N: Sumant Kowshik
262 E: kowshik@uiuc.edu
263 D: Author of the original C backend
265 N: Benjamin Kramer
266 E: benny.kra@gmail.com
267 D: Miscellaneous bug fixes
269 N: Sundeep Kushwaha
270 E: sundeepk@codeaurora.org
271 D: Implemented DFA-based target independent VLIW packetizer
273 N: Christopher Lamb
274 E: christopher.lamb@gmail.com
275 D: aligned load/store support, parts of noalias and restrict support
276 D: vreg subreg infrastructure, X86 codegen improvements based on subregs
277 D: address spaces
279 N: Jim Laskey
280 E: jlaskey@apple.com
281 D: Improvements to the PPC backend, instruction scheduling
282 D: Debug and Dwarf implementation
283 D: Auto upgrade mangler
284 D: llvm-gcc4 svn wrangler
286 N: Chris Lattner
287 E: sabre@nondot.org
288 W: http://nondot.org/~sabre/
289 D: Primary architect of LLVM
291 N: Tanya Lattner (Tanya Brethour)
292 E: tonic@nondot.org
293 W: http://nondot.org/~tonic/
294 D: The initial llvm-ar tool, converted regression testsuite to dejagnu
295 D: Modulo scheduling in the SparcV9 backend
296 D: Release manager (1.7+)
298 N: Sylvestre Ledru
299 E: sylvestre@debian.org
300 W: http://sylvestre.ledru.info/
301 W: https://apt.llvm.org/
302 D: Debian and Ubuntu packaging
303 D: Continuous integration with jenkins
305 N: Andrew Lenharth
306 E: alenhar2@cs.uiuc.edu
307 W: http://www.lenharth.org/~andrewl/
308 D: Alpha backend
309 D: Sampling based profiling
311 N: Nick Lewycky
312 E: nicholas@mxc.ca
313 D: PredicateSimplifier pass
315 N: Tony Linthicum, et. al.
316 E: tlinth@codeaurora.org
317 D: Backend for Qualcomm's Hexagon VLIW processor.
319 N: Bruno Cardoso Lopes
320 E: bruno.cardoso@gmail.com
321 I: bruno
322 W: http://brunocardoso.cc
323 D: Mips backend
324 D: Random ARM integrated assembler and assembly parser improvements
325 D: General X86 AVX1 support
327 N: Duraid Madina
328 E: duraid@octopus.com.au
329 W: http://kinoko.c.u-tokyo.ac.jp/~duraid/
330 D: IA64 backend, BigBlock register allocator
332 N: John McCall
333 E: rjmccall@apple.com
334 D: Clang semantic analysis and IR generation
336 N: Michael McCracken
337 E: michael.mccracken@gmail.com
338 D: Line number support for llvmgcc
340 N: Vladimir Merzliakov
341 E: wanderer@rsu.ru
342 D: Test suite fixes for FreeBSD
344 N: Scott Michel
345 E: scottm@aero.org
346 D: Added STI Cell SPU backend.
348 N: Kai Nacke
349 E: kai@redstar.de
350 D: Support for implicit TLS model used with MS VC runtime
351 D: Dumping of Win64 EH structures
353 N: Takumi Nakamura
354 I: chapuni
355 E: geek4civic@gmail.com
356 E: chapuni@hf.rim.or.jp
357 D: Maintaining the Git monorepo
358 W: https://github.com/llvm-project/
359 S: Ebina, Japan
361 N: Edward O'Callaghan
362 E: eocallaghan@auroraux.org
363 W: http://www.auroraux.org
364 D: Add Clang support with various other improvements to utils/NewNightlyTest.pl
365 D: Fix and maintain Solaris & AuroraUX support for llvm, various build warnings
366 D: and error clean ups.
368 N: Morten Ofstad
369 E: morten@hue.no
370 D: Visual C++ compatibility fixes
372 N: Jakob Stoklund Olesen
373 E: stoklund@2pi.dk
374 D: Machine code verifier
375 D: Blackfin backend
376 D: Fast register allocator
377 D: Greedy register allocator
379 N: Richard Osborne
380 E: richard@xmos.com
381 D: XCore backend
383 N: Piotr Padlewski
384 E: piotr.padlewski@gmail.com
385 D: !invariant.group metadata and other intrinsics for devirtualization in clang
387 N: Devang Patel
388 E: dpatel@apple.com
389 D: LTO tool, PassManager rewrite, Loop Pass Manager, Loop Rotate
390 D: GCC PCH Integration (llvm-gcc), llvm-gcc improvements
391 D: Optimizer improvements, Loop Index Split
393 N: Ana Pazos
394 E: apazos@codeaurora.org
395 D: Fixes and improvements to the AArch64 backend
397 N: Wesley Peck
398 E: peckw@wesleypeck.com
399 W: http://wesleypeck.com/
400 D: MicroBlaze backend
402 N: Francois Pichet
403 E: pichet2000@gmail.com
404 D: MSVC support
406 N: Adrian Prantl
407 E: aprantl@apple.com
408 D: Debug Information
410 N: Vladimir Prus
411 W: http://vladimir_prus.blogspot.com
412 E: ghost@cs.msu.su
413 D: Made inst_iterator behave like a proper iterator, LowerConstantExprs pass
415 N: QIU Chaofan
416 E: qiucofan@cn.ibm.com
417 D: PowerPC Backend Developer
419 N: Kalle Raiskila
420 E: kalle.rasikila@nokia.com
421 D: Some bugfixes to CellSPU
423 N: Xerxes Ranby
424 E: xerxes@zafena.se
425 D: Cmake dependency chain and various bug fixes
427 N: Alex Rosenberg
428 E: alexr@leftfield.org
429 I: arosenberg
430 D: ARM calling conventions rewrite, hard float support
432 N: Chad Rosier
433 E: mcrosier@codeaurora.org
434 I: mcrosier
435 D: AArch64 fast instruction selection pass
436 D: Fixes and improvements to the ARM fast-isel pass
437 D: Fixes and improvements to the AArch64 backend
439 N: Nadav Rotem
440 E: nadav.rotem@me.com
441 D: X86 code generation improvements, Loop Vectorizer, SLP Vectorizer
443 N: Roman Samoilov
444 E: roman@codedgers.com
445 D: MSIL backend
447 N: Duncan Sands
448 E: baldrick@free.fr
449 I: baldrick
450 D: Ada support in llvm-gcc
451 D: Dragonegg plugin
452 D: Exception handling improvements
453 D: Type legalizer rewrite
455 N: Ruchira Sasanka
456 E: sasanka@uiuc.edu
457 D: Graph coloring register allocator for the Sparc64 backend
459 N: Arnold Schwaighofer
460 E: arnold.schwaighofer@gmail.com
461 D: Tail call optimization for the x86 backend
463 N: Shantonu Sen
464 E: ssen@apple.com
465 D: Miscellaneous bug fixes
467 N: Anand Shukla
468 E: ashukla@cs.uiuc.edu
469 D: The `paths' pass
471 N: Michael J. Spencer
472 E: bigcheesegs@gmail.com
473 D: Shepherding Windows COFF support into MC.
474 D: Lots of Windows stuff.
476 N: Reid Spencer
477 E: rspencer@reidspencer.com
478 W: http://reidspencer.com/
479 D: Lots of stuff, see: http://wiki.llvm.org/index.php/User:Reid
481 N: Alp Toker
482 E: alp@nuanti.com
483 W: http://atoker.com/
484 D: C++ frontend next generation standards implementation
486 N: Craig Topper
487 E: craig.topper@gmail.com
488 D: X86 codegen and disassembler improvements. AVX2 support.
490 N: Edwin Torok
491 E: edwintorok@gmail.com
492 D: Miscellaneous bug fixes
494 N: Adam Treat
495 E: manyoso@yahoo.com
496 D: C++ bugs filed, and C++ front-end bug fixes.
498 N: Andrew Trick
499 E: atrick@apple.com
500 D: Instruction Scheduling, ...
502 N: Lauro Ramos Venancio
503 E: lauro.venancio@indt.org.br
504 D: ARM backend improvements
505 D: Thread Local Storage implementation
507 N: Bill Wendling
508 I: wendling
509 E: isanbard@gmail.com
510 D: Release manager, IR Linker, LTO.
511 D: Bunches of stuff.
513 N: Bob Wilson
514 E: bob.wilson@acm.org
515 D: Advanced SIMD (NEON) support in the ARM backend.
517 N: QingShan Zhang
518 E: qshanz@cn.ibm.com
519 D: PowerPC Backend Developer
521 N: Li Jia He
522 E: hljhehlj@cn.ibm.com
523 D: PowerPC Backend Developer
525 N: Zixuan Wu
526 E: wuzish@cn.ibm.com
527 D: PowerPC Backend Developer
529 N: Kang Zhang
530 E: shkzhang@cn.ibm.com
531 D: PowerPC Backend Developer
533 N: Zheng Chen
534 E: czhengsz@cn.ibm.com
535 D: PowerPC Backend Developer
537 N: Djordje Todorovic
538 E: djordje.todorovic@rt-rk.com
539 D: Debug Information