8200113: Make Access load proxys smarter

Reviewed-by: stefank, pliden
This commit is contained in:
Erik Österlund 2018-03-23 12:55:39 +01:00
parent 124c5f4f52
commit 4c21e9bc68

View File

@ -306,19 +306,28 @@ namespace AccessInternal {
// Infer the type that should be returned from a load. // Infer the type that should be returned from a load.
template <typename P, DecoratorSet decorators> template <typename P, DecoratorSet decorators>
class LoadProxy: public StackObj { class OopLoadProxy: public StackObj {
private: private:
P *const _addr; P *const _addr;
public: public:
LoadProxy(P* addr) : _addr(addr) {} OopLoadProxy(P* addr) : _addr(addr) {}
template <typename T> inline operator oop() {
inline operator T() { return load<decorators | INTERNAL_VALUE_IS_OOP, P, oop>(_addr);
return load<decorators, P, T>(_addr);
} }
inline operator P() { inline operator narrowOop() {
return load<decorators, P, P>(_addr); return load<decorators | INTERNAL_VALUE_IS_OOP, P, narrowOop>(_addr);
}
template <typename T>
inline bool operator ==(const T& other) const {
return load<decorators | INTERNAL_VALUE_IS_OOP, P, T>(_addr) == other;
}
template <typename T>
inline bool operator !=(const T& other) const {
return load<decorators | INTERNAL_VALUE_IS_OOP, P, T>(_addr) != other;
} }
}; };
@ -335,6 +344,39 @@ namespace AccessInternal {
inline operator T() const { inline operator T() const {
return load_at<decorators, T>(_base, _offset); return load_at<decorators, T>(_base, _offset);
} }
template <typename T>
inline bool operator ==(const T& other) const { return load_at<decorators, T>(_base, _offset) == other; }
template <typename T>
inline bool operator !=(const T& other) const { return load_at<decorators, T>(_base, _offset) != other; }
};
template <DecoratorSet decorators>
class OopLoadAtProxy: public StackObj {
private:
const oop _base;
const ptrdiff_t _offset;
public:
OopLoadAtProxy(oop base, ptrdiff_t offset) : _base(base), _offset(offset) {}
inline operator oop() const {
return load_at<decorators | INTERNAL_VALUE_IS_OOP, oop>(_base, _offset);
}
inline operator narrowOop() const {
return load_at<decorators | INTERNAL_VALUE_IS_OOP, narrowOop>(_base, _offset);
}
template <typename T>
inline bool operator ==(const T& other) const {
return load_at<decorators | INTERNAL_VALUE_IS_OOP, T>(_base, _offset) == other;
}
template <typename T>
inline bool operator !=(const T& other) const {
return load_at<decorators | INTERNAL_VALUE_IS_OOP, T>(_base, _offset) != other;
}
}; };
} }
@ -409,9 +451,9 @@ public:
} }
// Oop heap accesses // Oop heap accesses
static inline AccessInternal::LoadAtProxy<decorators | INTERNAL_VALUE_IS_OOP> oop_load_at(oop base, ptrdiff_t offset) { static inline AccessInternal::OopLoadAtProxy<decorators> oop_load_at(oop base, ptrdiff_t offset) {
verify_heap_oop_decorators<load_mo_decorators>(); verify_heap_oop_decorators<load_mo_decorators>();
return AccessInternal::LoadAtProxy<decorators | INTERNAL_VALUE_IS_OOP>(base, offset); return AccessInternal::OopLoadAtProxy<decorators>(base, offset);
} }
template <typename T> template <typename T>
@ -478,9 +520,9 @@ public:
// Oop accesses // Oop accesses
template <typename P> template <typename P>
static inline AccessInternal::LoadProxy<P, decorators | INTERNAL_VALUE_IS_OOP> oop_load(P* addr) { static inline AccessInternal::OopLoadProxy<P, decorators> oop_load(P* addr) {
verify_oop_decorators<load_mo_decorators>(); verify_oop_decorators<load_mo_decorators>();
return AccessInternal::LoadProxy<P, decorators | INTERNAL_VALUE_IS_OOP>(addr); return AccessInternal::OopLoadProxy<P, decorators>(addr);
} }
template <typename P, typename T> template <typename P, typename T>