|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Eventually we can make some of these pass the error along to the caller.
Reports a fatal error if:
We find an invalid abbrev record
We try to get an invalid abbrev number
We can't fill the current word due to an EOF
Fixed an invalid bitcode test to check for output with FileCheck
Bugs found with afl-fuzz
llvm-svn: 226986 | 
| | 
| 
| 
| | llvm-svn: 221943 | 
| | 
| 
| 
| 
| 
| 
| | These functions always return a single value and not all callers want to
push them into a SmallVector.
llvm-svn: 221934 | 
| | 
| 
| 
| | llvm-svn: 221930 | 
| | 
| 
| 
| | llvm-svn: 221490 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This doesn't change the interface or gives additional safety but removes
a ton of retain/release boilerplate.
No functionality change.
llvm-svn: 217778 | 
| | 
| 
| 
| | llvm-svn: 211141 | 
| | 
| 
| 
| 
| 
| | instead of comparing to nullptr.
llvm-svn: 206252 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Previously, BitstreamCursor read an abbreviated record by splatting the
whole thing into a data vector, then extracting and removing the /first/
element. Now, it reads the first element--the record code--separately from
the actual field values.
No (intended) functionality change.
llvm-svn: 181639 | 
| | 
| 
| 
| | llvm-svn: 178454 | 
| | 
| 
| 
| | llvm-svn: 175501 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | bitcode writer would generate abbrev records saying that the abbrev should be
filled with fixed zero-bit bitfields (this happens in the .bc writer when 
the number of types used in a module is exactly one, since log2(1) == 0).
In this case, just handle it as a literal zero.  We can't "just fix" the writer
without breaking compatibility with existing bc files, so have the abbrev reader
do the substitution.
Strengthen the assert in read to reject reads of zero bits so we catch such 
crimes in the future, and remove the special case designed to handle this.
llvm-svn: 174801 | 
| | 
| 
| 
| | llvm-svn: 174550 | 
| | 
| 
| 
| 
| 
| 
| 
| | BLOB (i.e., large, performance intensive data) in a bitcode file was switched to
invoking one virtual method call per byte read.  Now we do one virtual call per
BLOB.
llvm-svn: 173065 | 
| | 
| 
| 
| 
| 
| 
| | it reason about the current bit position, which is always independent of the
underlying cursors word size.
llvm-svn: 173063 | 
| | 
| 
| 
| 
| 
| | bytes.
llvm-svn: 173062 | 
| | 
| 
| 
| 
| 
| 
| 
| | new advance() APIs,
simplifying things and making a bunch of details more private to BitstreamCursor.
llvm-svn: 172947 | 
| | 
| 
| 
| 
| 
| 
| 
| | method to easy
the transition.
llvm-svn: 172940 | 
| | 
| 
| 
| | llvm-svn: 172931 | 
| | 
| 
| 
| 
| 
| 
| 
| | through a BitstreamCursor that produce it: advance() and 
advanceSkippingSubblocks(), representing the two most common ways clients
want to walk through bitcode.
llvm-svn: 172919 | 
|  | has past the point of making sense.  Lets tidy things up: first step, moving
a ton of big functions out of line.
llvm-svn: 172904 |