|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | Fix toString use of getValue to use getZExtValue()
llvm-svn: 34642 | 
| | 
| 
| 
| | llvm-svn: 34634 | 
| | 
| 
| 
| | llvm-svn: 34632 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | 2. Fix countTrailingZeros to use a faster algorithm.
3. Simplify sext() slightly by using isNegative().
4. Implement ashr using word-at-a-time logic instead of bit-at-a-time
5. Rename locals named isNegative so they don't clash with method name.
6. Fix fromString to compute negated value correctly.
llvm-svn: 34629 | 
| | 
| 
| 
| 
| 
| | This makes it much more efficient.
llvm-svn: 34618 | 
| | 
| 
| 
| | llvm-svn: 34617 | 
| | 
| 
| 
| 
| 
| 
| | 2. Implement the trunc, sext, and zext operations.
3. Improve fromString to accept negative values as input.
llvm-svn: 34616 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 2. Move comments for methods to .h file, delete them in .cpp file.
3. All places that were doing manual clear of high order bits now call the
   clearUnusedBits() method in order to not depend on undefined behavior
   of the >> operator when the number of bits shifted equals the word size.
4. Reduced # of loc by using the new result of clearUnusedBits() method.
5. Simplified logic (decreased indentation) in a few places.
6. Added code comments to larger functions that needed them.
7. Added FIXME notes about weak implementations of things (e.g. bit-by-bit
   shift right is sub-optimal).
llvm-svn: 34603 | 
| | 
| 
| 
| | llvm-svn: 34581 | 
| | 
| 
| 
| | llvm-svn: 34571 | 
| | 
| 
| 
| 
| 
| | Handle the single word cases for shiftAmt == BitWidth.
llvm-svn: 34569 | 
| | 
| 
| 
| | llvm-svn: 34565 | 
| | 
| 
| 
| | llvm-svn: 34564 | 
| | 
| 
| 
| | llvm-svn: 34562 | 
| | 
| 
| 
| 
| 
| | 2. Fix shl when shiftAmount == BitWidth.
llvm-svn: 34560 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | 2. Clean up comments, style, coding standards, etc.
3. Simplify a constructor.
Extended testing revealed some additional bugs in shifting. I'll fix these
tomorrow.
llvm-svn: 34559 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to be safe.
2. Make internal functions that return a carry/borrow return bool instead
   of uint64_t because the carry/borrow can only be in range [0,1].
3. Assert that the pointers to KnuthDiv are all different so that the
   result and operands can't overlap.
4. Add debug output to KnuthDiv function.
5. Fix a problem with KnuthDiv by separating the b's complement operation
   from the subtraction borrow operation. This fixes a wide range of
   division problems, but alas, not all of them.
llvm-svn: 34554 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | memory (as done in fromString).
2. Implement Knuth divide more closely to what is recommended in his book.
3. Fix computation of the remainder for Knuth Divide (bad shifting).
4. Remove some cruft from the file
llvm-svn: 34518 | 
| | 
| 
| 
| 
| 
| 
| | extract the value, not the number of words implied by the active bits.
This fixes numerous, but not all divide bugs.
llvm-svn: 34484 | 
| | 
| 
| 
| 
| 
| 
| 
| | word size. This fixes all reads of uninitialized data (buffer over read)
and makes APInt.cpp memory clean, per valgrind. The only remaining
problem is division in a few cases.
llvm-svn: 34483 | 
| | 
| 
| 
| 
| 
| | reads, and reduce the number of temporary APInt instances we construct.
llvm-svn: 34467 | 
| | 
| 
| 
| | llvm-svn: 34465 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 2. Change 0 initialization of union to larger component so all is zeroed.
3. Fix the borrow logic in subtraction so it works for > 128 bits.
4. Rewrite fromString to use a simpler but correct algorithm and also to
   not set the bit width contrary to the user's request.
5. Optimize toString a bit by making it only do one Knuth divide per
   iteration instead of two.
With these changes, all arithmetic passes (verified by pari/GP) up to
1024 bits except for certain division cases.
llvm-svn: 34463 | 
| | 
| 
| 
| 
| 
| | Fix toString to correctly return "0" for zero valued APInts over 128 bits.
llvm-svn: 34459 | 
| | 
| 
| 
| 
| 
| | functions more.
llvm-svn: 34458 | 
| | 
| 
| 
| 
| 
| | Attempt #3 for getting a portable INFINITY value.
llvm-svn: 34454 | 
| | 
| 
| 
| 
| 
| | constants (avoids warnings).
llvm-svn: 34452 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1. Ensure pVal is set to 0 in each constructor.
2. Fix roundToDouble to make correct calculations and not read beyond the
   end of allocated memory.
3. Implement Knuth's "classical algorithm" for division from scratch and
   eliminate buffer overflows and uninitialized mememory reads. Document
   it properly too.
4. Implement a wrapper function for KnuthDiv which handles the 64-bit to
   32-bit conversion and back. It also implement short division for the
   n == 1 case that Knuth's algorithm can't handle.
5. Simplify the logic of udiv and urem a little, make them exit early, and
   have them use the "divide" wrapper function to perform the division
   or remainder operation.
6. Move the toString function to the end of the file, closer to where
   the division functions are located.
Note: division is still broken for some > 64 bit values, but at least it
      doesn't crash any more.
llvm-svn: 34449 | 
| | 
| 
| 
| 
| 
| 
| 
| | 2. Implement toString for power-of-2 radix without using divide and always
   printing full words. This allows hex/binary to look at the bit
   respresentation of the APInt as well as avoid bugs in divide.
llvm-svn: 34396 | 
| | 
| 
| 
| 
| 
| 
| | 2. Teach slt about signedness.
3. Teach roundToDouble to properly sign extend.
llvm-svn: 34391 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 2. Consolidate memory allocation into just two inline functions.
3. Convert "unsigned" to uint32_t to gaurantee its size.
4. Eliminate magic constants and replace with symbolic equivalent.
5. Improve code documentation slightly.
6. Simplify the logical operator code because bitwidths must be the same.
7. Fix indentation per coding standards.
8. Use exit-early style to reduce indentation in several functions.
llvm-svn: 34389 | 
| | 
| 
| 
| 
| 
| 
| | Fix line breaks and 80 cols violation.
Simplify operator^= since bitwidths must be the same.
llvm-svn: 34388 | 
| | 
| 
| 
| 
| 
| | Fix bugs in countLeadingZeros and countTrailingZeros.
llvm-svn: 34386 | 
| | 
| 
| 
| | llvm-svn: 34384 | 
| | 
| 
| 
| | llvm-svn: 34363 | 
| | 
| 
| 
| 
| 
| | meaningful variable names. Add comments to document the flow.
llvm-svn: 34362 | 
| | 
| 
| 
| | llvm-svn: 34357 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1. Function style changes.
2. 80-col violations.
3. Better names for things.
4. Arrange constructors so they all take bit width first.
5. Add named signed and unsigned comparison functions and remove the
   corresponding operators.
6. Remove operator&& and operator|| but provide a getBoolValue function which
   converts to bool as comparison against 0. This allows the normal && and
   || operators to be used as if (X.getBoolValue() && Y.getBoolValue())
Note: this still doesn't function 100% yet. I'm working on the bugs now.
llvm-svn: 34353 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 1. Make getMinValue() returns the right value.
2. Fix the ByteSwap() crash problem.
3. Make Postfix increment work correctly.
4. Fix some bugs in LogBase2, Hi/LoBits and UDiv.
llvm-svn: 34304 | 
| | 
| 
| 
| 
| 
| | at this point, it just needs to work so we can test things reliably.
llvm-svn: 34262 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 1. Make all the operators use uppercase
2. Rename APIntRoundToDouble method just RoundToDouble, the APInt is
   redundant.
3. Turn the class on for compilation.
llvm-svn: 34253 | 
| | 
| 
| 
| 
| 
| 
| | 2. Add functions to support the numberical conversion between APInt and
   double/float.
llvm-svn: 34201 | 
| | 
| 
| 
| 
| 
| | methods as those global function's internal implementation.
llvm-svn: 34083 | 
| | 
| 
| 
| | llvm-svn: 34054 | 
| | 
| 
| 
| 
| 
| 
| 
| | add some signed/unsigned arithmetic operation functions into APInt.h to
handle the signed/unsigned issue. These functions will be defined inside a
namespace "APIntOps" which is inside llvm namespace.
llvm-svn: 34053 | 
| | 
| 
| 
| | llvm-svn: 33989 | 
| | 
| 
| 
| | llvm-svn: 33955 | 
| | 
| 
| 
| | llvm-svn: 33953 | 
|  | It is a functional replacement for common case integer type like "unsigned",
"uint64_t", but also allows non-byte-width integer type and large integer
value types such as 3-bits, 15-bits, or more than 64-bits of precision. For
more details, see pr1043.
llvm-svn: 33951 |