|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| | r259192 post commit comment.
clang part in r259232, this is the LLVM part of the patch.
llvm-svn: 259240 | 
| | 
| 
| 
| 
| 
| | Apparently, the style needs to be agreed upon first.
llvm-svn: 240390 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The patch is generated using this command:
tools/clang/tools/extra/clang-tidy/tool/run-clang-tidy.py -fix \
  -checks=-*,llvm-namespace-comment -header-filter='llvm/.*|clang/.*' \
  llvm/lib/
Thanks to Eugene Kosov for the original patch!
llvm-svn: 240137 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: This patch fixes step D4 of Knuth's division algorithm implementation. Negative sign of the step result was not always detected due to incorrect "borrow" handling.
Test Plan: Unit test that reveals the bug included.
Reviewers: chandlerc, yaron.keren
Reviewed By: yaron.keren
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D9196
llvm-svn: 235699 | 
| | 
| 
| 
| | llvm-svn: 234158 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | APInt uses Knuth's D algorithm for long division. In rare cases the
implementation applied a transformation that was not needed.
Added unit tests for long division. KnuthDiv() procedure is fully covered.
There is a case in APInt::divide() that I believe is never used (marked with
a comment) as all users of divide() handle trivial cases earlier.
Patch by Pawel Bylica!
  http://reviews.llvm.org/D8448
llvm-svn: 233312 | 
| | 
| 
| 
| 
| 
| 
| | To complement getSplat. This is more general than the binary
decomposition method as it also handles non-pow2 splat sizes.
llvm-svn: 233195 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Now that SmallString is a first-class citizen, most SmallString::str()
calls are not required. This patch removes a whole bunch of them, yet
there are lots more.
There are two use cases where str() is really needed:
1) To use one of StringRef member functions which is not available in
SmallString.
2) To convert to std::string, as StringRef implicitly converts while 
SmallString do not. We may wish to change this, but it may introduce
ambiguity.
llvm-svn: 232622 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Saves adding .str() call to any raw_ostream << SmallString usage
and a small step towards making .str() consistent in the ADTs by
removing one of the SmallString::str() use cases, discussion at
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20141013/240026.html
I'll update the Phabricator patch http://reviews.llvm.org/D6372
for review of the Twine SmallString support, it's more complex
than this one.
llvm-svn: 231763 | 
| | 
| 
| 
| 
| 
| | All supported platforms have half-way decent C99 support.
llvm-svn: 231679 | 
| | 
| 
| 
| 
| 
| 
| 
| | with countTrailingZeros
Update all callers.
llvm-svn: 228930 | 
| | 
| 
| 
| 
| 
| 
| 
| | This mirrors the behavior of APInt::udiv and APInt::urem.  Some
architectures, like X86, have a single instruction which can compute
both division and remainder.
llvm-svn: 224217 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We have a transform that changes:
  (x lshr C1) udiv C2
into:
  x udiv (C2 << C1)
However, it is unsafe to do so if C2 << C1 discards any of C2's bits.
This fixes PR21255.
llvm-svn: 219634 | 
| | 
| 
| 
| | llvm-svn: 219588 | 
| | 
| 
| 
| 
| 
| | Saves a couple of expensive deep copies. NFC.
llvm-svn: 219487 | 
| | 
| 
| 
| | llvm-svn: 217597 | 
| | 
| 
| 
| 
| 
| | definition below all of the header #include lines, lib/Support edition.
llvm-svn: 206847 | 
| | 
| 
| 
| | llvm-svn: 205697 | 
| | 
| 
| 
| 
| 
| 
| | Sweep the codebase for common typos. Includes some changes to visible function
names that were misspelt.
llvm-svn: 200018 | 
| | 
| 
| 
| 
| 
| | Change tests for extractBit to test operator[].
llvm-svn: 197277 | 
| | 
| 
| 
| | llvm-svn: 197271 | 
| | 
| 
| 
| | llvm-svn: 183073 | 
| | 
| 
| 
| 
| 
| 
| 
| | use in APFloat IEEE-754R 2008 nextUp/nextDown function.
rdar://13852078
llvm-svn: 182801 | 
| | 
| 
| 
| | llvm-svn: 182680 | 
| | 
| 
| 
| 
| 
| | They are generally faster (at least not slower) than post-inc, post-dec.
llvm-svn: 177608 | 
| | 
| 
| 
| 
| 
| 
| | require call cpp file anyway, so we wouldn't gain anything by keeping them
inline.
llvm-svn: 175579 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| 
| 
| | See: http://en.wikipedia.org/wiki/If_and_only_if Commit 164767
llvm-svn: 164768 | 
| | 
| 
| 
| | llvm-svn: 164767 | 
| | 
| 
| 
| 
| 
| | This caused 6 of 65k possible 8 bit udivs to be wrong.
llvm-svn: 160058 | 
| | 
| 
| 
| 
| 
| | Patch by James Benton <jbenton@vmware.com>.
llvm-svn: 158213 | 
| | 
| 
| 
| | llvm-svn: 152692 | 
| | 
| 
| 
| 
| 
| | code when inlined.
llvm-svn: 152688 | 
| | 
| 
| 
| | llvm-svn: 152577 | 
| | 
| 
| 
| | llvm-svn: 152545 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | new hash_value infrastructure, and replace their implementations using
hash_combine. This removes a complete copy of Jenkin's lookup3 hash
function (which is both significantly slower and lower quality than the
one implemented in hash_combine) along with a somewhat scary xor-only
hash function.
Now that APInt and APFloat can be passed directly to hash_combine,
simplify the rest of the LLVMContextImpl hashing to use the new
infrastructure.
llvm-svn: 152004 | 
| | 
| 
| 
| | llvm-svn: 151385 | 
| | 
| 
| 
| 
| 
| | width.
llvm-svn: 149151 | 
| | 
| 
| 
| 
| 
| | writing some code that tried to use them.
llvm-svn: 147134 | 
| | 
| 
| 
| 
| 
| 
| 
| | Hexatridecimal was added in r139695.
And fix the unittest that now triggers the assert.
llvm-svn: 146754 | 
| | 
| 
| 
| | llvm-svn: 145627 | 
| | 
| 
| 
| | llvm-svn: 145111 | 
| | 
| 
| 
| 
| 
| | integers where there is unsigned overflow.  Fix APFloat::toString so that it doesn't depend on the incorrect behavior in common cases (and computes the correct result in some rare cases).  Fixes PR11086.
llvm-svn: 141441 | 
| | 
| 
| 
| | llvm-svn: 140166 | 
| | 
| 
| 
| | llvm-svn: 140158 | 
| | 
| 
| 
| | llvm-svn: 140043 | 
| | 
| 
| 
| | llvm-svn: 139695 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | ambiguity
errors like the one corrected by r135261.  Migrate all LLVM callers of the old
constructor to the new one.
llvm-svn: 135431 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | toString() now takes an optional bool argument that,
depending on the radix, adds the appropriate prefix
to the integer's string representation that makes it into a
meaningful C literal, e.g.:
hexademical: '-f' becomes '-0xf'
octal: '77' becomes '077'
binary: '110' becomes '0b110'
Patch by nobled@dreamwidth.org!
llvm-svn: 133032 | 
| | 
| 
| 
| | llvm-svn: 131842 |