From 36a134798be67a09ba02cdb78f2a82be6d49f46a Mon Sep 17 00:00:00 2001 From: Nekotekina Date: Tue, 20 Jan 2015 00:30:33 +0300 Subject: [PATCH] Small vm fix --- rpcs3/Emu/Memory/vm_ptr.h | 106 ++++++++++++++------------------------ rpcs3/Emu/Memory/vm_ref.h | 4 +- rpcs3/Emu/Memory/vm_var.h | 4 +- 3 files changed, 43 insertions(+), 71 deletions(-) diff --git a/rpcs3/Emu/Memory/vm_ptr.h b/rpcs3/Emu/Memory/vm_ptr.h index c628a4b8a0..5915a52a05 100644 --- a/rpcs3/Emu/Memory/vm_ptr.h +++ b/rpcs3/Emu/Memory/vm_ptr.h @@ -11,7 +11,7 @@ namespace vm public: typedef typename std::remove_cv::type type; - static const u32 address_size = (u32)sizeof(AT); + static const u32 address_size = sizeof(AT); _ptr_base operator++ (int) { @@ -76,13 +76,11 @@ namespace vm return vm::get_ref<_ptr_base::value, typename to_be_t::type, AT>>>(vm::cast(m_addr + sizeof(AT)* index)); } - //typedef typename invert_be_t::type AT2; - template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } AT addr() const @@ -95,9 +93,9 @@ namespace vm m_addr = value; } - static _ptr_base make(AT addr) + static const _ptr_base make(const AT& addr) { - return (_ptr_base&)addr; + return reinterpret_cast(addr); } _ptr_base& operator = (const _ptr_base& right) = default; @@ -110,7 +108,7 @@ namespace vm public: typedef typename std::remove_cv::type type; - static const u32 data_size = (u32)sizeof(T); + static const u32 data_size = sizeof(T); __forceinline T* const operator -> () const { @@ -185,18 +183,6 @@ namespace vm __forceinline bool operator !=(const nullptr_t& right) const { return m_addr != 0; } explicit operator bool() const { return m_addr != 0; } explicit operator T*() const { return get_ptr(); } - - /* - operator _ref_base() - { - return _ref_base::make(m_addr); - } - - operator const _ref_base() const - { - return _ref_base::make(m_addr); - } - */ AT addr() const { @@ -209,19 +195,11 @@ namespace vm m_addr = convert_le_be(value); } - /* - operator T*() const - { - return get_ptr(); - } - */ - //typedef typename invert_be_t::type AT2; - template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } T* get_ptr() const @@ -229,9 +207,9 @@ namespace vm return vm::get_ptr(vm::cast(m_addr)); } - static _ptr_base make(AT addr) + static const _ptr_base make(const AT& addr) { - return (_ptr_base&)addr; + return reinterpret_cast(addr); } _ptr_base& operator = (const _ptr_base& right) = default; @@ -273,25 +251,23 @@ namespace vm __forceinline bool operator !=(const nullptr_t& right) const { return m_addr != 0; } explicit operator bool() const { return m_addr != 0; } - //typedef typename invert_be_t::type AT2; - template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } - static _ptr_base make(AT addr) + static const _ptr_base make(const AT& addr) { - return (_ptr_base&)addr; + return reinterpret_cast(addr); } _ptr_base& operator = (const _ptr_base& right) = default; @@ -333,18 +309,16 @@ namespace vm __forceinline bool operator !=(const nullptr_t& right) const { return m_addr != 0; } explicit operator bool() const { return m_addr != 0; } - //typedef typename invert_be_t::type AT2; - template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } - static _ptr_base make(AT addr) + static const _ptr_base make(const AT& addr) { - return (_ptr_base&)addr; + return reinterpret_cast(addr); } _ptr_base& operator = (const _ptr_base& right) = default; @@ -382,23 +356,21 @@ namespace vm __forceinline bool operator !=(const nullptr_t& right) const { return m_addr != 0; } explicit operator bool() const { return m_addr != 0; } - //typedef typename invert_be_t::type AT2; - template operator const _ptr_base() const { - typename std::remove_const::type addr = convert_le_be(m_addr); - return (_ptr_base&)addr; + const AT2 addr = convert_le_be(m_addr); + return reinterpret_cast&>(addr); } - static _ptr_base make(AT addr) + static const _ptr_base make(const AT& addr) { - return (_ptr_base&)addr; + return reinterpret_cast(addr); } operator const std::function() const { - typename std::remove_const::type addr = convert_le_be(m_addr); + const AT addr = convert_le_be(m_addr); return [addr](T... args) -> RT { return make(addr)(args...); }; } @@ -408,10 +380,10 @@ namespace vm //BE pointer to LE data template struct bptrl : public _ptr_base::type> { - static bptrl make(AT addr) + static const bptrl make(AT addr) { auto res = _ptr_base::type>::make(convert_le_be::type>(addr)); - return (bptrl&)res; + return static_cast(res); } using _ptr_base::type>::operator=; @@ -420,10 +392,10 @@ namespace vm //BE pointer to BE data template struct bptrb : public _ptr_base::type, lvl, typename to_be_t::type> { - static bptrb make(AT addr) + static const bptrb make(AT addr) { auto res = _ptr_base::type, lvl, typename to_be_t::type>::make(convert_le_be::type>(addr)); - return (bptrb&)res; + return static_cast(res); } using _ptr_base::type, lvl, typename to_be_t::type>::operator=; @@ -432,10 +404,10 @@ namespace vm //LE pointer to BE data template struct lptrb : public _ptr_base::type, lvl, AT> { - static lptrb make(AT addr) + static const lptrb make(AT addr) { auto res = _ptr_base::type, lvl, AT>::make(addr); - return (lptrb&)res; + return static_cast(res); } using _ptr_base::type, lvl, AT>::operator=; @@ -444,10 +416,10 @@ namespace vm //LE pointer to LE data template struct lptrl : public _ptr_base { - static lptrl make(AT addr) + static const lptrl make(AT addr) { auto res = _ptr_base::make(addr); - return (lptrl&)res; + return static_cast(res); } using _ptr_base::operator=; @@ -461,10 +433,10 @@ namespace vm //default pointer for HLE functions (LE pointer to BE data) template struct ptr : public lptrb { - static ptr make(AT addr) + static const ptr make(AT addr) { auto res = lptrb::make(addr); - return (ptr&)res; + return static_cast(res); } vm::ps3::bptr to_be() const @@ -478,10 +450,10 @@ namespace vm //default pointer for HLE structures (BE pointer to BE data) template struct bptr : public bptrb { - static bptr make(AT addr) + static const bptr make(AT addr) { auto res = bptrb::make(addr); - return (bptr&)res; + return static_cast(res); } vm::ps3::ptr to_le() const @@ -498,10 +470,10 @@ namespace vm //default pointer for HLE functions & structures (LE pointer to LE data) template struct ptr : public lptrl { - static ptr make(AT addr) + static const ptr make(AT addr) { auto res = lptrl::make(addr); - return (ptr&)res; + return static_cast(res); } using lptrl::operator=; diff --git a/rpcs3/Emu/Memory/vm_ref.h b/rpcs3/Emu/Memory/vm_ref.h index d8e6092540..5788457c3b 100644 --- a/rpcs3/Emu/Memory/vm_ref.h +++ b/rpcs3/Emu/Memory/vm_ref.h @@ -28,9 +28,9 @@ namespace vm return m_addr; } - static _ref_base make(AT addr) + static _ref_base make(const AT& addr) { - return (_ref_base&)addr; + return reinterpret_cast<_ref_base&>(addr); } _ref_base& operator = (le_type right) diff --git a/rpcs3/Emu/Memory/vm_var.h b/rpcs3/Emu/Memory/vm_var.h index 0975a00913..95ea373f9e 100644 --- a/rpcs3/Emu/Memory/vm_var.h +++ b/rpcs3/Emu/Memory/vm_var.h @@ -35,7 +35,7 @@ namespace vm void alloc() { - m_addr = (u32)Memory.Alloc(size(), m_align); + m_addr = vm::cast(Memory.Alloc(size(), m_align)); m_ptr = vm::get_ptr(m_addr); } @@ -162,7 +162,7 @@ namespace vm void alloc() { - m_addr = (u32)Memory.Alloc(size(), m_align); + m_addr = vm::cast(Memory.Alloc(size(), m_align)); m_ptr = vm::get_ptr(m_addr); }