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_v<
141 Proxy, Args&&...>,
int> = 0>
143 proxy(
std::make_shared<Proxy>(args...))
147 template <
typename ...Args,
148 typename std::enable_if_t<std::is_constructible_v<
149 Proxy, Args&&...>,
int> = 0>
151 proxy(
std::make_shared<Proxy>(args...))
156 template <
typename O,
typename Enabled=
157 typename std::enable_if_t<std::is_assignable_v<T *, O *>>>
174 operator bool()
const {
return (
bool)
buffer; }
176 template <
typename A>
177 typename std::enable_if_t<std::is_integral_v<A>,
CPP>
183 template <
typename A>
184 typename std::enable_if_t<std::is_integral_v<A>,
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_v<A>, ConstProxyPtr<T, Proxy>>
237 template <
typename T,
typename Proxy>
247 template <
typename ...Args,
248 typename std::enable_if_t<std::is_constructible_v<
249 Proxy, Args&&...>,
int> = 0>
251 template <
typename ...Args,
252 typename std::enable_if_t<std::is_constructible_v<
253 Proxy, Args&&...>,
int> = 0>
256 template <
typename O,
typename Enabled=
257 typename std::enable_if_t<std::is_assignable_v<T *, O *> &&
258 !std::is_same_v<O, void>>>
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_v<A>,
PP>
275 return PP(this->
addr() + a *
sizeof(T), this->
proxy);
278 template <
typename A>
279 typename std::enable_if_t<std::is_integral_v<A>,
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_v<A>, 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)
std::enable_if_t< std::is_integral_v< A >, PP > operator+(A a) const
ProxyPtr(const ProxyPtr< T, Proxy > &other)
const T & operator*() const
std::unique_ptr< uint8_t[]> data
ProxyPtr(Addr _ptr, Args &&... args)
PP & operator=(const PP &other)
void ccprintf(cp::Print &print)
std::enable_if_t< std::is_integral_v< A >, 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)
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...
std::enable_if_t< std::is_integral_v< A >, PP > operator-(A a) const
Overload hash function for BasicBlockRange type.
std::enable_if_t< std::is_integral_v< A >, CPP > operator+(A a) const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
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 Wed May 4 2022 12:14:03 for gem5 by doxygen 1.8.17