mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
Change getSlotIndex to return unsigned.
The actual storage was already using unsigned, but the interface was using uint64_t. This is wasteful on 32 bits and looks to be the root causes of a miscompilation on Windows where a value was being sign extended to 64bits to compare with the result of getSlotIndex. Patch by Pasi Parviainen! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@180791 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e87dadc44b
commit
76f103e021
@ -346,7 +346,7 @@ public:
|
||||
unsigned getNumSlots() const;
|
||||
|
||||
/// \brief Return the index for the given slot.
|
||||
uint64_t getSlotIndex(unsigned Slot) const;
|
||||
unsigned getSlotIndex(unsigned Slot) const;
|
||||
|
||||
/// \brief Return the attributes at the given slot.
|
||||
AttributeSet getSlotAttributes(unsigned Slot) const;
|
||||
|
@ -228,7 +228,7 @@ public:
|
||||
/// is the index of the return, parameter, or function object that the
|
||||
/// attributes are applied to, not the index into the AttrNodes list where the
|
||||
/// attributes reside.
|
||||
uint64_t getSlotIndex(unsigned Slot) const {
|
||||
unsigned getSlotIndex(unsigned Slot) const {
|
||||
return AttrNodes[Slot].first;
|
||||
}
|
||||
|
||||
@ -270,7 +270,7 @@ public:
|
||||
}
|
||||
|
||||
// FIXME: This atrocity is temporary.
|
||||
uint64_t Raw(uint64_t Index) const;
|
||||
uint64_t Raw(unsigned Index) const;
|
||||
};
|
||||
|
||||
} // end llvm namespace
|
||||
|
@ -501,7 +501,7 @@ std::string AttributeSetNode::getAsString(bool TargetIndependent,
|
||||
// AttributeSetImpl Definition
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
uint64_t AttributeSetImpl::Raw(uint64_t Index) const {
|
||||
uint64_t AttributeSetImpl::Raw(unsigned Index) const {
|
||||
for (unsigned I = 0, E = getNumAttributes(); I != E; ++I) {
|
||||
if (getSlotIndex(I) != Index) continue;
|
||||
const AttributeSetNode *ASN = AttrNodes[I].second;
|
||||
@ -889,7 +889,7 @@ unsigned AttributeSet::getNumSlots() const {
|
||||
return pImpl ? pImpl->getNumAttributes() : 0;
|
||||
}
|
||||
|
||||
uint64_t AttributeSet::getSlotIndex(unsigned Slot) const {
|
||||
unsigned AttributeSet::getSlotIndex(unsigned Slot) const {
|
||||
assert(pImpl && Slot < pImpl->getNumAttributes() &&
|
||||
"Slot # out of range!");
|
||||
return pImpl->getSlotIndex(Slot);
|
||||
|
Loading…
x
Reference in New Issue
Block a user