Go to the documentation of this file.
29 #ifndef __SIM_PROXY_PTR_HH__
30 #define __SIM_PROXY_PTR_HH__
34 #include <type_traits>
43 template <
typename Proxy>
51 std::unique_ptr<uint8_t[]>
data;
68 assert(
sizeof(T) <=
size);
70 return *
reinterpret_cast<T *
>(
data.get());
77 assert(
sizeof(T) <=
size);
78 return *
reinterpret_cast<T *
>(
data.get());
108 template <
typename T,
typename Proxy>
113 std::shared_ptr<ProxyPtrBuffer<Proxy>>
buffer;
115 template <
typename O,
typename P>
139 template <
typename ...Args,
140 typename std::enable_if_t<std::is_constructible<
141 Proxy, Args&&...>::value,
int> = 0>
143 proxy(
std::make_shared<Proxy>(args...))
147 template <
typename ...Args,
148 typename std::enable_if_t<std::is_constructible<
149 Proxy, Args&&...>::value,
int> = 0>
151 proxy(
std::make_shared<Proxy>(args...))
156 template <
typename O,
typename Enabled=
157 typename std::enable_if_t<std::is_assignable<T *, O *>::value>>
174 operator bool()
const {
return (
bool)
buffer; }
176 template <
typename A>
177 typename std::enable_if_t<std::is_integral<A>::value,
CPP>
183 template <
typename A>
184 typename std::enable_if_t<std::is_integral<A>::value,
CPP>
193 return (
addr() - other.
addr()) /
sizeof(T);
211 operator const T *()
const
213 return buffer ? &
buffer->template asConst<T>() :
nullptr;
220 return buffer->template asConst<T>();
226 return &
buffer->template asConst<T>();
230 template <
typename T,
typename Proxy,
typename A>
231 typename std::enable_if_t<std::is_integral<A>::value, ConstProxyPtr<T, Proxy>>
237 template <
typename T,
typename Proxy>
247 template <
typename ...Args,
248 typename std::enable_if_t<std::is_constructible<
249 Proxy, Args&&...>::value,
int> = 0>
251 template <
typename ...Args,
252 typename std::enable_if_t<std::is_constructible<
253 Proxy, Args&&...>::value,
int> = 0>
256 template <
typename O,
typename Enabled=
257 typename std::enable_if_t<std::is_assignable<T *, O *>::value &&
258 !std::is_same<O, void>::value>>
262 operator bool()
const {
return (
bool)this->
buffer; }
268 this->
buffer->flush(force);
271 template <
typename A>
272 typename std::enable_if_t<std::is_integral<A>::value,
PP>
275 return PP(this->
addr() + a *
sizeof(T), this->
proxy);
278 template <
typename A>
279 typename std::enable_if_t<std::is_integral<A>::value,
PP>
282 return PP(this->
addr() - a *
sizeof(T), this->
proxy);
288 return (this->
addr() - other.
addr()) /
sizeof(T);
306 using CPP::operator
const T *;
309 return this->
buffer ? &this->
buffer->template as<T>() :
nullptr;
312 using CPP::operator *;
317 return this->
buffer->template as<T>();
320 using CPP::operator ->;
325 return &this->
buffer->template as<T>();
329 template <
typename Proxy>
338 template <
typename T>
348 operator Addr()
const {
return _addr; }
353 template <
typename T,
typename Proxy,
typename A>
354 typename std::enable_if_t<std::is_integral<A>::value, ProxyPtr<T, Proxy>>
364 template <
typename ABI,
typename T,
typename Proxy>
375 template <
typename ABI,
typename T,
typename Proxy>
388 template <
typename T,
typename Proxy>
396 class SETranslatingPortProxy;
398 template <
typename T>
400 template <
typename T=
void>
405 #endif // __SIM_PROXY_PTR_HH__
std::ostream & operator<<(std::ostream &os, const ArmSemihosting::InPlaceArg &ipa)
ConstProxyPtr(const ConstProxyPtr< O, Proxy > &other)
ProxyPtr(const ProxyPtr< O, Proxy > &other)
std::shared_ptr< Proxy > getProxy() const
ProxyPtr(Args &&... args)
ProxyPtr(const ProxyPtr< T, Proxy > &other)
const T & operator*() const
std::unique_ptr< uint8_t[]> data
ProxyPtr(Addr _ptr, Args &&... args)
std::enable_if_t< std::is_integral< A >::value, PP > operator+(A a) const
PP & operator=(const PP &other)
void ccprintf(cp::Print &print)
std::enable_if_t< std::is_integral< A >::value, CPP > operator-(A a) const
CPP & operator=(const CPP &other)
std::shared_ptr< Proxy > proxy
void flush(bool force=false)
std::shared_ptr< Proxy > proxy
ThreadContext is the external interface to all thread state for anything outside of the CPU.
ConstProxyPtr< T, Proxy > CPP
Time operator+(const Time &l, const Time &r)
const T & asConst() const
ProxyPtrBuffer(std::shared_ptr< Proxy > _proxy, Addr _ptr, size_t _size)
ConstProxyPtr(const CPP &other)
ProxyPtr(const PP &other)
ProxyPtr(Addr _ptr, std::shared_ptr< Proxy > _proxy)
ProxyPtr(Addr new_addr,...)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
const T * operator->() const
void flush(bool force=false)
ConstProxyPtr(Addr _ptr, std::shared_ptr< Proxy > _proxy)
std::enable_if_t< std::is_integral< A >::value, PP > operator-(A a) const
ConstProxyPtr(Addr _ptr, Args &&... args)
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Overload hash function for BasicBlockRange type.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::enable_if_t< std::is_integral< A >::value, CPP > operator+(A a) const
static ProxyPtr< T, Proxy > get(ThreadContext *tc, typename ABI::State &state)
ConstProxyPtr(Args &&... args)
static ConstProxyPtr< T, Proxy > get(ThreadContext *tc, typename ABI::State &state)
std::shared_ptr< ProxyPtrBuffer< Proxy > > buffer
Generated on Tue Sep 7 2021 14:53:49 for gem5 by doxygen 1.8.17