mirror of
https://github.com/RPCS3/rpcs3.git
synced 2024-11-22 02:32:36 +01:00
rsx: Fix exceptions
This commit is contained in:
parent
f54da22f6f
commit
8980fc5524
@ -100,23 +100,17 @@ extern thread_local std::string(*g_tls_log_prefix)();
|
|||||||
|
|
||||||
std::string dump_useful_thread_info()
|
std::string dump_useful_thread_info()
|
||||||
{
|
{
|
||||||
thread_local volatile bool guard = false;
|
|
||||||
|
|
||||||
std::string result;
|
std::string result;
|
||||||
|
|
||||||
// In case the dumping function was the cause for the exception/access violation
|
|
||||||
// Avoid recursion
|
|
||||||
if (std::exchange(guard, true))
|
|
||||||
{
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (auto cpu = get_current_cpu_thread())
|
if (auto cpu = get_current_cpu_thread())
|
||||||
{
|
{
|
||||||
cpu->dump_all(result);
|
// Wrap it to disable some internal exceptions when printing (not thrown on main thread)
|
||||||
|
Emu.BlockingCallFromMainThread([&]()
|
||||||
|
{
|
||||||
|
cpu->dump_all(result);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
guard = false;
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,11 +48,11 @@ namespace gl
|
|||||||
case rsx::blend_equation::add: return GL_FUNC_ADD;
|
case rsx::blend_equation::add: return GL_FUNC_ADD;
|
||||||
case rsx::blend_equation::min: return GL_MIN;
|
case rsx::blend_equation::min: return GL_MIN;
|
||||||
case rsx::blend_equation::max: return GL_MAX;
|
case rsx::blend_equation::max: return GL_MAX;
|
||||||
case rsx::blend_equation::substract: return GL_FUNC_SUBTRACT;
|
case rsx::blend_equation::subtract: return GL_FUNC_SUBTRACT;
|
||||||
case rsx::blend_equation::reverse_substract_signed:
|
case rsx::blend_equation::reverse_subtract_signed:
|
||||||
rsx_log.trace("blend equation reverse_subtract_signed used. Emulating using FUNC_REVERSE_SUBTRACT");
|
rsx_log.trace("blend equation reverse_subtract_signed used. Emulating using FUNC_REVERSE_SUBTRACT");
|
||||||
[[fallthrough]];
|
[[fallthrough]];
|
||||||
case rsx::blend_equation::reverse_substract: return GL_FUNC_REVERSE_SUBTRACT;
|
case rsx::blend_equation::reverse_subtract: return GL_FUNC_REVERSE_SUBTRACT;
|
||||||
case rsx::blend_equation::reverse_add_signed:
|
case rsx::blend_equation::reverse_add_signed:
|
||||||
default:
|
default:
|
||||||
rsx_log.error("Blend equation 0x%X is unimplemented!", static_cast<u32>(op));
|
rsx_log.error("Blend equation 0x%X is unimplemented!", static_cast<u32>(op));
|
||||||
|
@ -158,11 +158,11 @@ namespace vk
|
|||||||
[[fallthrough]];
|
[[fallthrough]];
|
||||||
case rsx::blend_equation::add:
|
case rsx::blend_equation::add:
|
||||||
return VK_BLEND_OP_ADD;
|
return VK_BLEND_OP_ADD;
|
||||||
case rsx::blend_equation::substract: return VK_BLEND_OP_SUBTRACT;
|
case rsx::blend_equation::subtract: return VK_BLEND_OP_SUBTRACT;
|
||||||
case rsx::blend_equation::reverse_substract_signed:
|
case rsx::blend_equation::reverse_subtract_signed:
|
||||||
rsx_log.trace("blend equation reverse_subtract_signed used. Emulating using FUNC_REVERSE_SUBTRACT");
|
rsx_log.trace("blend equation reverse_subtract_signed used. Emulating using FUNC_REVERSE_SUBTRACT");
|
||||||
[[fallthrough]];
|
[[fallthrough]];
|
||||||
case rsx::blend_equation::reverse_substract: return VK_BLEND_OP_REVERSE_SUBTRACT;
|
case rsx::blend_equation::reverse_subtract: return VK_BLEND_OP_REVERSE_SUBTRACT;
|
||||||
case rsx::blend_equation::min: return VK_BLEND_OP_MIN;
|
case rsx::blend_equation::min: return VK_BLEND_OP_MIN;
|
||||||
case rsx::blend_equation::max: return VK_BLEND_OP_MAX;
|
case rsx::blend_equation::max: return VK_BLEND_OP_MAX;
|
||||||
default:
|
default:
|
||||||
|
@ -1,8 +1,32 @@
|
|||||||
#include "gcm_enums.h"
|
#include "gcm_enums.h"
|
||||||
#include "Utilities/StrFmt.h"
|
#include "Utilities/StrFmt.h"
|
||||||
|
|
||||||
|
#include "Utilities/Thread.h"
|
||||||
|
|
||||||
using namespace rsx;
|
using namespace rsx;
|
||||||
|
|
||||||
|
struct convertible_to_invalid
|
||||||
|
{
|
||||||
|
convertible_to_invalid() noexcept = default;
|
||||||
|
|
||||||
|
template <typename T> requires (std::is_enum_v<T>)
|
||||||
|
constexpr operator T() const
|
||||||
|
{
|
||||||
|
return T::invalid;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <usz Size, typename... Args>
|
||||||
|
convertible_to_invalid throw_exception_if_emulating(const char(&fmt)[Size], Args&&... args)
|
||||||
|
{
|
||||||
|
if (thread_ctrl::get_current())
|
||||||
|
{
|
||||||
|
fmt::throw_exception(fmt, std::forward<Args>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
vertex_base_type rsx::to_vertex_base_type(u8 in)
|
vertex_base_type rsx::to_vertex_base_type(u8 in)
|
||||||
{
|
{
|
||||||
switch (in)
|
switch (in)
|
||||||
@ -16,7 +40,7 @@ vertex_base_type rsx::to_vertex_base_type(u8 in)
|
|||||||
case 6: return vertex_base_type::cmp;
|
case 6: return vertex_base_type::cmp;
|
||||||
case 7: return vertex_base_type::ub256;
|
case 7: return vertex_base_type::ub256;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown vertex base type %d", in);
|
return throw_exception_if_emulating("Unknown vertex base type %d", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
primitive_type rsx::to_primitive_type(u8 in)
|
primitive_type rsx::to_primitive_type(u8 in)
|
||||||
@ -52,7 +76,7 @@ window_origin rsx::to_window_origin(u8 in)
|
|||||||
case CELL_GCM_WINDOW_ORIGIN_TOP: return window_origin::top;
|
case CELL_GCM_WINDOW_ORIGIN_TOP: return window_origin::top;
|
||||||
case CELL_GCM_WINDOW_ORIGIN_BOTTOM: return window_origin::bottom;
|
case CELL_GCM_WINDOW_ORIGIN_BOTTOM: return window_origin::bottom;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown window origin modifier 0x%x", in);
|
return throw_exception_if_emulating("Unknown window origin modifier 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
window_pixel_center rsx::to_window_pixel_center(u8 in)
|
window_pixel_center rsx::to_window_pixel_center(u8 in)
|
||||||
@ -62,7 +86,7 @@ window_pixel_center rsx::to_window_pixel_center(u8 in)
|
|||||||
case CELL_GCM_WINDOW_PIXEL_CENTER_HALF: return window_pixel_center::half;
|
case CELL_GCM_WINDOW_PIXEL_CENTER_HALF: return window_pixel_center::half;
|
||||||
case CELL_GCM_WINDOW_PIXEL_CENTER_INTEGER: return window_pixel_center::integer;
|
case CELL_GCM_WINDOW_PIXEL_CENTER_INTEGER: return window_pixel_center::integer;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown window pixel center 0x%x", in);
|
return throw_exception_if_emulating("Unknown window pixel center 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
comparison_function rsx::to_comparison_function(u16 in)
|
comparison_function rsx::to_comparison_function(u16 in)
|
||||||
@ -101,7 +125,7 @@ comparison_function rsx::to_comparison_function(u16 in)
|
|||||||
case CELL_GCM_ALWAYS:
|
case CELL_GCM_ALWAYS:
|
||||||
return comparison_function::always;
|
return comparison_function::always;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown comparison function 0x%x", in);
|
return throw_exception_if_emulating("Unknown comparison function 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
fog_mode rsx::to_fog_mode(u32 in)
|
fog_mode rsx::to_fog_mode(u32 in)
|
||||||
@ -115,7 +139,7 @@ fog_mode rsx::to_fog_mode(u32 in)
|
|||||||
case CELL_GCM_FOG_MODE_EXP2_ABS: return fog_mode::exponential2_abs;
|
case CELL_GCM_FOG_MODE_EXP2_ABS: return fog_mode::exponential2_abs;
|
||||||
case CELL_GCM_FOG_MODE_LINEAR_ABS: return fog_mode::linear_abs;
|
case CELL_GCM_FOG_MODE_LINEAR_ABS: return fog_mode::linear_abs;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown fog mode 0x%x", in);
|
return throw_exception_if_emulating("Unknown fog mode 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
texture_dimension rsx::to_texture_dimension(u8 in)
|
texture_dimension rsx::to_texture_dimension(u8 in)
|
||||||
@ -126,7 +150,7 @@ texture_dimension rsx::to_texture_dimension(u8 in)
|
|||||||
case 2: return texture_dimension::dimension2d;
|
case 2: return texture_dimension::dimension2d;
|
||||||
case 3: return texture_dimension::dimension3d;
|
case 3: return texture_dimension::dimension3d;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown texture dimension %d", in);
|
return throw_exception_if_emulating("Unknown texture dimension %d", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
@ -228,6 +252,7 @@ void fmt_class_string<comparison_function>::format(std::string& out, u64 arg)
|
|||||||
case comparison_function::not_equal: return "Not_equal";
|
case comparison_function::not_equal: return "Not_equal";
|
||||||
case comparison_function::greater_or_equal: return "Greater_equal";
|
case comparison_function::greater_or_equal: return "Greater_equal";
|
||||||
case comparison_function::always: return "Always";
|
case comparison_function::always: return "Always";
|
||||||
|
case comparison_function::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -249,6 +274,7 @@ void fmt_class_string<stencil_op>::format(std::string& out, u64 arg)
|
|||||||
case stencil_op::incr_wrap: return "Incr_wrap";
|
case stencil_op::incr_wrap: return "Incr_wrap";
|
||||||
case stencil_op::decr_wrap: return "Decr_wrap";
|
case stencil_op::decr_wrap: return "Decr_wrap";
|
||||||
case stencil_op::invert: return "Invert";
|
case stencil_op::invert: return "Invert";
|
||||||
|
case stencil_op::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -268,6 +294,7 @@ void fmt_class_string<fog_mode>::format(std::string& out, u64 arg)
|
|||||||
case fog_mode::exponential_abs: return "exponential(abs)";
|
case fog_mode::exponential_abs: return "exponential(abs)";
|
||||||
case fog_mode::linear: return "linear";
|
case fog_mode::linear: return "linear";
|
||||||
case fog_mode::linear_abs: return "linear(abs)";
|
case fog_mode::linear_abs: return "linear(abs)";
|
||||||
|
case fog_mode::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -297,6 +324,7 @@ void fmt_class_string<logic_op>::format(std::string& out, u64 arg)
|
|||||||
case logic_op::logic_copy_inverted: return "Copy_inverted";
|
case logic_op::logic_copy_inverted: return "Copy_inverted";
|
||||||
case logic_op::logic_or_inverted: return "Or_inverted";
|
case logic_op::logic_or_inverted: return "Or_inverted";
|
||||||
case logic_op::logic_nand: return "Nand";
|
case logic_op::logic_nand: return "Nand";
|
||||||
|
case logic_op::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -312,6 +340,7 @@ void fmt_class_string<front_face>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case front_face::ccw: return "counter clock wise";
|
case front_face::ccw: return "counter clock wise";
|
||||||
case front_face::cw: return "clock wise";
|
case front_face::cw: return "clock wise";
|
||||||
|
case front_face::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -328,6 +357,7 @@ void fmt_class_string<cull_face>::format(std::string& out, u64 arg)
|
|||||||
case cull_face::back: return "back";
|
case cull_face::back: return "back";
|
||||||
case cull_face::front: return "front";
|
case cull_face::front: return "front";
|
||||||
case cull_face::front_and_back: return "front and back";
|
case cull_face::front_and_back: return "front and back";
|
||||||
|
case cull_face::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -347,6 +377,7 @@ void fmt_class_string<surface_target>::format(std::string& out, u64 arg)
|
|||||||
case surface_target::surfaces_a_b: return "surfaces A and B";
|
case surface_target::surfaces_a_b: return "surfaces A and B";
|
||||||
case surface_target::surfaces_a_b_c: return "surfaces A, B and C";
|
case surface_target::surfaces_a_b_c: return "surfaces A, B and C";
|
||||||
case surface_target::surfaces_a_b_c_d: return "surfaces A,B, C and D";
|
case surface_target::surfaces_a_b_c_d: return "surfaces A,B, C and D";
|
||||||
|
case surface_target::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -390,6 +421,7 @@ void fmt_class_string<blit_engine::transfer_operation>::format(std::string& out,
|
|||||||
case blit_engine::transfer_operation::srccopy: return "srccopy";
|
case blit_engine::transfer_operation::srccopy: return "srccopy";
|
||||||
case blit_engine::transfer_operation::srccopy_and: return "srccopy_and";
|
case blit_engine::transfer_operation::srccopy_and: return "srccopy_and";
|
||||||
case blit_engine::transfer_operation::srccopy_premult: return "srccopy_premult";
|
case blit_engine::transfer_operation::srccopy_premult: return "srccopy_premult";
|
||||||
|
case blit_engine::transfer_operation::invalid: return "Invalid";
|
||||||
default: return unknown;
|
default: return unknown;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -415,6 +447,7 @@ void fmt_class_string<blit_engine::transfer_source_format>::format(std::string&
|
|||||||
case blit_engine::transfer_source_format::x8r8g8b8: return "x8r8g8b8";
|
case blit_engine::transfer_source_format::x8r8g8b8: return "x8r8g8b8";
|
||||||
case blit_engine::transfer_source_format::y8: return "y8";
|
case blit_engine::transfer_source_format::y8: return "y8";
|
||||||
case blit_engine::transfer_source_format::yb8cr8ya8cb8: return "yb8cr8ya8cb8";
|
case blit_engine::transfer_source_format::yb8cr8ya8cb8: return "yb8cr8ya8cb8";
|
||||||
|
case blit_engine::transfer_source_format::invalid: return "Invalid";
|
||||||
default: return unknown;
|
default: return unknown;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -429,6 +462,7 @@ void fmt_class_string<blit_engine::context_surface>::format(std::string& out, u6
|
|||||||
{
|
{
|
||||||
case blit_engine::context_surface::surface2d: return "surface 2d";
|
case blit_engine::context_surface::surface2d: return "surface 2d";
|
||||||
case blit_engine::context_surface::swizzle2d: return "swizzle 2d";
|
case blit_engine::context_surface::swizzle2d: return "swizzle 2d";
|
||||||
|
case blit_engine::context_surface::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -445,6 +479,7 @@ void fmt_class_string<blit_engine::transfer_destination_format>::format(std::str
|
|||||||
case blit_engine::transfer_destination_format::a8r8g8b8: return "a8r8g8b8";
|
case blit_engine::transfer_destination_format::a8r8g8b8: return "a8r8g8b8";
|
||||||
case blit_engine::transfer_destination_format::r5g6b5: return "r5g6b5";
|
case blit_engine::transfer_destination_format::r5g6b5: return "r5g6b5";
|
||||||
case blit_engine::transfer_destination_format::y32: return "y32";
|
case blit_engine::transfer_destination_format::y32: return "y32";
|
||||||
|
case blit_engine::transfer_destination_format::invalid: return "Invalid";
|
||||||
default: return unknown;
|
default: return unknown;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -459,6 +494,7 @@ void fmt_class_string<index_array_type>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case index_array_type::u16: return "u16";
|
case index_array_type::u16: return "u16";
|
||||||
case index_array_type::u32: return "u32";
|
case index_array_type::u32: return "u32";
|
||||||
|
case index_array_type::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -475,6 +511,7 @@ void fmt_class_string<polygon_mode>::format(std::string& out, u64 arg)
|
|||||||
case polygon_mode::fill: return "fill";
|
case polygon_mode::fill: return "fill";
|
||||||
case polygon_mode::line: return "line";
|
case polygon_mode::line: return "line";
|
||||||
case polygon_mode::point: return "point";
|
case polygon_mode::point: return "point";
|
||||||
|
case polygon_mode::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -502,6 +539,7 @@ void fmt_class_string<surface_color_format>::format(std::string& out, u64 arg)
|
|||||||
case surface_color_format::x8b8g8r8_z8b8g8r8: return "X8B8G8R8_Z8B8G8R8";
|
case surface_color_format::x8b8g8r8_z8b8g8r8: return "X8B8G8R8_Z8B8G8R8";
|
||||||
case surface_color_format::x8b8g8r8_o8b8g8r8: return "X8B8G8R8_O8B8G8R8";
|
case surface_color_format::x8b8g8r8_o8b8g8r8: return "X8B8G8R8_O8B8G8R8";
|
||||||
case surface_color_format::a8b8g8r8: return "A8B8G8R8";
|
case surface_color_format::a8b8g8r8: return "A8B8G8R8";
|
||||||
|
case surface_color_format::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -519,6 +557,7 @@ void fmt_class_string<surface_antialiasing>::format(std::string& out, u64 arg)
|
|||||||
case surface_antialiasing::diagonal_centered_2_samples: return "2 samples diagonal centered";
|
case surface_antialiasing::diagonal_centered_2_samples: return "2 samples diagonal centered";
|
||||||
case surface_antialiasing::square_centered_4_samples: return "4 samples square centered";
|
case surface_antialiasing::square_centered_4_samples: return "4 samples square centered";
|
||||||
case surface_antialiasing::square_rotated_4_samples: return "4 samples diagonal rotated";
|
case surface_antialiasing::square_rotated_4_samples: return "4 samples diagonal rotated";
|
||||||
|
case surface_antialiasing::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -533,13 +572,14 @@ void fmt_class_string<blend_equation>::format(std::string& out, u64 arg)
|
|||||||
switch (value)
|
switch (value)
|
||||||
{
|
{
|
||||||
case blend_equation::add: return "Add";
|
case blend_equation::add: return "Add";
|
||||||
case blend_equation::substract: return "Substract";
|
case blend_equation::subtract: return "Subtract";
|
||||||
case blend_equation::reverse_substract: return "Reverse_substract";
|
case blend_equation::reverse_subtract: return "Reverse_subtract";
|
||||||
case blend_equation::min: return "Min";
|
case blend_equation::min: return "Min";
|
||||||
case blend_equation::max: return "Max";
|
case blend_equation::max: return "Max";
|
||||||
case blend_equation::add_signed: return "Add_signed";
|
case blend_equation::add_signed: return "Add_signed";
|
||||||
case blend_equation::reverse_add_signed: return "Reverse_add_signed";
|
case blend_equation::reverse_add_signed: return "Reverse_add_signed";
|
||||||
case blend_equation::reverse_substract_signed: return "Reverse_substract_signed";
|
case blend_equation::reverse_subtract_signed: return "Reverse_subtract_signed";
|
||||||
|
case blend_equation::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -568,6 +608,7 @@ void fmt_class_string<blend_factor>::format(std::string& out, u64 arg)
|
|||||||
case blend_factor::one_minus_constant_color: return "(1 - const.rgb)";
|
case blend_factor::one_minus_constant_color: return "(1 - const.rgb)";
|
||||||
case blend_factor::constant_alpha: return "const.a";
|
case blend_factor::constant_alpha: return "const.a";
|
||||||
case blend_factor::one_minus_constant_alpha: return "(1 - const.a)";
|
case blend_factor::one_minus_constant_alpha: return "(1 - const.a)";
|
||||||
|
case blend_factor::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -583,6 +624,7 @@ void fmt_class_string<window_origin>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case window_origin::bottom: return "bottom";
|
case window_origin::bottom: return "bottom";
|
||||||
case window_origin::top: return "top";
|
case window_origin::top: return "top";
|
||||||
|
case window_origin::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -598,6 +640,7 @@ void fmt_class_string<window_pixel_center>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case window_pixel_center::half: return "half";
|
case window_pixel_center::half: return "half";
|
||||||
case window_pixel_center::integer: return "integer";
|
case window_pixel_center::integer: return "integer";
|
||||||
|
case window_pixel_center::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -614,6 +657,7 @@ void fmt_class_string<user_clip_plane_op>::format(std::string& out, u64 arg)
|
|||||||
case user_clip_plane_op::disable: return "disabled";
|
case user_clip_plane_op::disable: return "disabled";
|
||||||
case user_clip_plane_op::greater_or_equal: return "greater or equal";
|
case user_clip_plane_op::greater_or_equal: return "greater or equal";
|
||||||
case user_clip_plane_op::less_than: return "less than";
|
case user_clip_plane_op::less_than: return "less than";
|
||||||
|
case user_clip_plane_op::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -630,6 +674,7 @@ void fmt_class_string<blit_engine::context_dma>::format(std::string& out, u64 ar
|
|||||||
case blit_engine::context_dma::report_location_main: return "report location main";
|
case blit_engine::context_dma::report_location_main: return "report location main";
|
||||||
case blit_engine::context_dma::to_memory_get_report: return "to memory get report";
|
case blit_engine::context_dma::to_memory_get_report: return "to memory get report";
|
||||||
case blit_engine::context_dma::memory_host_buffer: return "memory host buffer";
|
case blit_engine::context_dma::memory_host_buffer: return "memory host buffer";
|
||||||
|
case blit_engine::context_dma::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -645,6 +690,7 @@ void fmt_class_string<blit_engine::transfer_origin>::format(std::string& out, u6
|
|||||||
{
|
{
|
||||||
case blit_engine::transfer_origin::center: return "center";
|
case blit_engine::transfer_origin::center: return "center";
|
||||||
case blit_engine::transfer_origin::corner: return "corner";
|
case blit_engine::transfer_origin::corner: return "corner";
|
||||||
|
case blit_engine::transfer_origin::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -660,6 +706,7 @@ void fmt_class_string<shading_mode>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case shading_mode::flat: return "flat";
|
case shading_mode::flat: return "flat";
|
||||||
case shading_mode::smooth: return "smooth";
|
case shading_mode::smooth: return "smooth";
|
||||||
|
case shading_mode::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -675,6 +722,7 @@ void fmt_class_string<surface_depth_format>::format(std::string& out, u64 arg)
|
|||||||
{
|
{
|
||||||
case surface_depth_format::z16: return "Z16";
|
case surface_depth_format::z16: return "Z16";
|
||||||
case surface_depth_format::z24s8: return "Z24S8";
|
case surface_depth_format::z24s8: return "Z24S8";
|
||||||
|
case surface_depth_format::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -691,6 +739,7 @@ void fmt_class_string<blit_engine::transfer_interpolator>::format(std::string& o
|
|||||||
{
|
{
|
||||||
case blit_engine::transfer_interpolator::foh: return "foh";
|
case blit_engine::transfer_interpolator::foh: return "foh";
|
||||||
case blit_engine::transfer_interpolator::zoh: return "zoh";
|
case blit_engine::transfer_interpolator::zoh: return "zoh";
|
||||||
|
case blit_engine::transfer_interpolator::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -708,6 +757,7 @@ void fmt_class_string<texture_dimension>::format(std::string& out, u64 arg)
|
|||||||
case texture_dimension::dimension1d: return "1D";
|
case texture_dimension::dimension1d: return "1D";
|
||||||
case texture_dimension::dimension2d: return "2D";
|
case texture_dimension::dimension2d: return "2D";
|
||||||
case texture_dimension::dimension3d: return "3D";
|
case texture_dimension::dimension3d: return "3D";
|
||||||
|
case texture_dimension::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -729,6 +779,7 @@ void fmt_class_string<texture_max_anisotropy>::format(std::string& out, u64 arg)
|
|||||||
case texture_max_anisotropy::x10: return "10";
|
case texture_max_anisotropy::x10: return "10";
|
||||||
case texture_max_anisotropy::x12: return "12";
|
case texture_max_anisotropy::x12: return "12";
|
||||||
case texture_max_anisotropy::x16: return "16";
|
case texture_max_anisotropy::x16: return "16";
|
||||||
|
case texture_max_anisotropy::invalid: return "Invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
return unknown;
|
return unknown;
|
||||||
@ -823,7 +874,7 @@ texture_wrap_mode rsx::to_texture_wrap_mode(u8 in)
|
|||||||
case CELL_GCM_TEXTURE_MIRROR_ONCE_BORDER: return texture_wrap_mode::mirror_once_border;
|
case CELL_GCM_TEXTURE_MIRROR_ONCE_BORDER: return texture_wrap_mode::mirror_once_border;
|
||||||
case CELL_GCM_TEXTURE_MIRROR_ONCE_CLAMP: return texture_wrap_mode::mirror_once_clamp;
|
case CELL_GCM_TEXTURE_MIRROR_ONCE_CLAMP: return texture_wrap_mode::mirror_once_clamp;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown wrap mode 0x%x", in);
|
return throw_exception_if_emulating("Unknown wrap mode 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
texture_max_anisotropy rsx::to_texture_max_anisotropy(u8 in)
|
texture_max_anisotropy rsx::to_texture_max_anisotropy(u8 in)
|
||||||
@ -839,7 +890,7 @@ texture_max_anisotropy rsx::to_texture_max_anisotropy(u8 in)
|
|||||||
case CELL_GCM_TEXTURE_MAX_ANISO_12: return texture_max_anisotropy::x12;
|
case CELL_GCM_TEXTURE_MAX_ANISO_12: return texture_max_anisotropy::x12;
|
||||||
case CELL_GCM_TEXTURE_MAX_ANISO_16: return texture_max_anisotropy::x16;
|
case CELL_GCM_TEXTURE_MAX_ANISO_16: return texture_max_anisotropy::x16;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown anisotropy max mode 0x%x", in);
|
return throw_exception_if_emulating("Unknown anisotropy max mode 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
texture_minify_filter rsx::to_texture_minify_filter(u8 in)
|
texture_minify_filter rsx::to_texture_minify_filter(u8 in)
|
||||||
@ -854,7 +905,7 @@ texture_minify_filter rsx::to_texture_minify_filter(u8 in)
|
|||||||
case CELL_GCM_TEXTURE_LINEAR_LINEAR: return texture_minify_filter::linear_linear;
|
case CELL_GCM_TEXTURE_LINEAR_LINEAR: return texture_minify_filter::linear_linear;
|
||||||
case CELL_GCM_TEXTURE_CONVOLUTION_MIN: return texture_minify_filter::linear_linear;
|
case CELL_GCM_TEXTURE_CONVOLUTION_MIN: return texture_minify_filter::linear_linear;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown minify filter 0x%x", in);
|
return throw_exception_if_emulating("Unknown minify filter 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -866,7 +917,7 @@ texture_magnify_filter rsx::to_texture_magnify_filter(u8 in)
|
|||||||
case CELL_GCM_TEXTURE_LINEAR: return texture_magnify_filter::linear;
|
case CELL_GCM_TEXTURE_LINEAR: return texture_magnify_filter::linear;
|
||||||
case CELL_GCM_TEXTURE_CONVOLUTION_MAG: return texture_magnify_filter::convolution_mag;
|
case CELL_GCM_TEXTURE_CONVOLUTION_MAG: return texture_magnify_filter::convolution_mag;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown magnify filter 0x%x", in);
|
return throw_exception_if_emulating("Unknown magnify filter 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
surface_target rsx::to_surface_target(u8 in)
|
surface_target rsx::to_surface_target(u8 in)
|
||||||
@ -880,7 +931,7 @@ surface_target rsx::to_surface_target(u8 in)
|
|||||||
case CELL_GCM_SURFACE_TARGET_MRT2: return surface_target::surfaces_a_b_c;
|
case CELL_GCM_SURFACE_TARGET_MRT2: return surface_target::surfaces_a_b_c;
|
||||||
case CELL_GCM_SURFACE_TARGET_MRT3: return surface_target::surfaces_a_b_c_d;
|
case CELL_GCM_SURFACE_TARGET_MRT3: return surface_target::surfaces_a_b_c_d;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown surface target 0x%x", in);
|
return throw_exception_if_emulating("Unknown surface target 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
surface_depth_format rsx::to_surface_depth_format(u8 in)
|
surface_depth_format rsx::to_surface_depth_format(u8 in)
|
||||||
@ -890,7 +941,7 @@ surface_depth_format rsx::to_surface_depth_format(u8 in)
|
|||||||
case CELL_GCM_SURFACE_Z16: return surface_depth_format::z16;
|
case CELL_GCM_SURFACE_Z16: return surface_depth_format::z16;
|
||||||
case CELL_GCM_SURFACE_Z24S8: return surface_depth_format::z24s8;
|
case CELL_GCM_SURFACE_Z24S8: return surface_depth_format::z24s8;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown surface depth format 0x%x", in);
|
return throw_exception_if_emulating("Unknown surface depth format 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
surface_antialiasing rsx::to_surface_antialiasing(u8 in)
|
surface_antialiasing rsx::to_surface_antialiasing(u8 in)
|
||||||
@ -902,7 +953,7 @@ surface_antialiasing rsx::to_surface_antialiasing(u8 in)
|
|||||||
case CELL_GCM_SURFACE_SQUARE_CENTERED_4: return surface_antialiasing::square_centered_4_samples;
|
case CELL_GCM_SURFACE_SQUARE_CENTERED_4: return surface_antialiasing::square_centered_4_samples;
|
||||||
case CELL_GCM_SURFACE_SQUARE_ROTATED_4: return surface_antialiasing::square_rotated_4_samples;
|
case CELL_GCM_SURFACE_SQUARE_ROTATED_4: return surface_antialiasing::square_rotated_4_samples;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown surface antialiasing format 0x%x", in);
|
return throw_exception_if_emulating("Unknown surface antialiasing format 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
surface_color_format rsx::to_surface_color_format(u8 in)
|
surface_color_format rsx::to_surface_color_format(u8 in)
|
||||||
@ -924,7 +975,7 @@ surface_color_format rsx::to_surface_color_format(u8 in)
|
|||||||
case CELL_GCM_SURFACE_X8B8G8R8_O8B8G8R8: return surface_color_format::x8b8g8r8_o8b8g8r8;
|
case CELL_GCM_SURFACE_X8B8G8R8_O8B8G8R8: return surface_color_format::x8b8g8r8_o8b8g8r8;
|
||||||
case CELL_GCM_SURFACE_A8B8G8R8: return surface_color_format::a8b8g8r8;
|
case CELL_GCM_SURFACE_A8B8G8R8: return surface_color_format::a8b8g8r8;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown surface color format 0x%x", in);
|
return throw_exception_if_emulating("Unknown surface color format 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
stencil_op rsx::to_stencil_op(u16 in)
|
stencil_op rsx::to_stencil_op(u16 in)
|
||||||
@ -940,7 +991,7 @@ stencil_op rsx::to_stencil_op(u16 in)
|
|||||||
case CELL_GCM_DECR_WRAP: return stencil_op::decr_wrap;
|
case CELL_GCM_DECR_WRAP: return stencil_op::decr_wrap;
|
||||||
case CELL_GCM_ZERO: return stencil_op::zero;
|
case CELL_GCM_ZERO: return stencil_op::zero;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown stencil op 0x%x", in);
|
return throw_exception_if_emulating("Unknown stencil op 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
blend_equation rsx::to_blend_equation(u16 in)
|
blend_equation rsx::to_blend_equation(u16 in)
|
||||||
@ -950,13 +1001,13 @@ blend_equation rsx::to_blend_equation(u16 in)
|
|||||||
case CELL_GCM_FUNC_ADD: return blend_equation::add;
|
case CELL_GCM_FUNC_ADD: return blend_equation::add;
|
||||||
case CELL_GCM_MIN: return blend_equation::min;
|
case CELL_GCM_MIN: return blend_equation::min;
|
||||||
case CELL_GCM_MAX: return blend_equation::max;
|
case CELL_GCM_MAX: return blend_equation::max;
|
||||||
case CELL_GCM_FUNC_SUBTRACT: return blend_equation::substract;
|
case CELL_GCM_FUNC_SUBTRACT: return blend_equation::subtract;
|
||||||
case CELL_GCM_FUNC_REVERSE_SUBTRACT: return blend_equation::reverse_substract;
|
case CELL_GCM_FUNC_REVERSE_SUBTRACT: return blend_equation::reverse_subtract;
|
||||||
case CELL_GCM_FUNC_REVERSE_SUBTRACT_SIGNED: return blend_equation::reverse_substract_signed;
|
case CELL_GCM_FUNC_REVERSE_SUBTRACT_SIGNED: return blend_equation::reverse_subtract_signed;
|
||||||
case CELL_GCM_FUNC_ADD_SIGNED: return blend_equation::add_signed;
|
case CELL_GCM_FUNC_ADD_SIGNED: return blend_equation::add_signed;
|
||||||
case CELL_GCM_FUNC_REVERSE_ADD_SIGNED: return blend_equation::reverse_add_signed;
|
case CELL_GCM_FUNC_REVERSE_ADD_SIGNED: return blend_equation::reverse_add_signed;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown blend eq 0x%x", in);
|
return throw_exception_if_emulating("Unknown blend eq 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
blend_factor rsx::to_blend_factor(u16 in)
|
blend_factor rsx::to_blend_factor(u16 in)
|
||||||
@ -979,7 +1030,7 @@ blend_factor rsx::to_blend_factor(u16 in)
|
|||||||
case CELL_GCM_CONSTANT_ALPHA: return blend_factor::constant_alpha;
|
case CELL_GCM_CONSTANT_ALPHA: return blend_factor::constant_alpha;
|
||||||
case CELL_GCM_ONE_MINUS_CONSTANT_ALPHA: return blend_factor::one_minus_constant_alpha;
|
case CELL_GCM_ONE_MINUS_CONSTANT_ALPHA: return blend_factor::one_minus_constant_alpha;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown blend factor 0x%x", in);
|
return throw_exception_if_emulating("Unknown blend factor 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1022,7 +1073,7 @@ logic_op rsx::to_logic_op(u16 in)
|
|||||||
case CELL_GCM_NAND: return logic_op::logic_nand;
|
case CELL_GCM_NAND: return logic_op::logic_nand;
|
||||||
case CELL_GCM_SET: return logic_op::logic_set;
|
case CELL_GCM_SET: return logic_op::logic_set;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown logic op 0x%x", in);
|
return throw_exception_if_emulating("Unknown logic op 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
front_face rsx::to_front_face(u16 in)
|
front_face rsx::to_front_face(u16 in)
|
||||||
@ -1033,7 +1084,7 @@ front_face rsx::to_front_face(u16 in)
|
|||||||
case CELL_GCM_CW: return front_face::cw;
|
case CELL_GCM_CW: return front_face::cw;
|
||||||
case CELL_GCM_CCW: return front_face::ccw;
|
case CELL_GCM_CCW: return front_face::ccw;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown front face 0x%x", in);
|
return throw_exception_if_emulating("Unknown front face 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1052,7 +1103,7 @@ blit_engine::transfer_origin blit_engine::to_transfer_origin(u8 in)
|
|||||||
case CELL_GCM_TRANSFER_ORIGIN_CENTER: return blit_engine::transfer_origin::center;
|
case CELL_GCM_TRANSFER_ORIGIN_CENTER: return blit_engine::transfer_origin::center;
|
||||||
case CELL_GCM_TRANSFER_ORIGIN_CORNER: return blit_engine::transfer_origin::corner;
|
case CELL_GCM_TRANSFER_ORIGIN_CORNER: return blit_engine::transfer_origin::corner;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown transfer origin 0x%x", in);
|
return throw_exception_if_emulating("Unknown transfer origin 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
blit_engine::transfer_interpolator blit_engine::to_transfer_interpolator(u8 in)
|
blit_engine::transfer_interpolator blit_engine::to_transfer_interpolator(u8 in)
|
||||||
@ -1062,7 +1113,7 @@ blit_engine::transfer_interpolator blit_engine::to_transfer_interpolator(u8 in)
|
|||||||
case CELL_GCM_TRANSFER_INTERPOLATOR_ZOH: return blit_engine::transfer_interpolator::zoh;
|
case CELL_GCM_TRANSFER_INTERPOLATOR_ZOH: return blit_engine::transfer_interpolator::zoh;
|
||||||
case CELL_GCM_TRANSFER_INTERPOLATOR_FOH: return blit_engine::transfer_interpolator::foh;
|
case CELL_GCM_TRANSFER_INTERPOLATOR_FOH: return blit_engine::transfer_interpolator::foh;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown transfer interpolator 0x%x", in);
|
return throw_exception_if_emulating("Unknown transfer interpolator 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1159,7 +1210,7 @@ blit_engine::context_surface blit_engine::to_context_surface(u32 in)
|
|||||||
case CELL_GCM_CONTEXT_SURFACE2D: return blit_engine::context_surface::surface2d;
|
case CELL_GCM_CONTEXT_SURFACE2D: return blit_engine::context_surface::surface2d;
|
||||||
case CELL_GCM_CONTEXT_SWIZZLE2D: return blit_engine::context_surface::swizzle2d;
|
case CELL_GCM_CONTEXT_SWIZZLE2D: return blit_engine::context_surface::swizzle2d;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown context surface 0x%x", in);
|
return throw_exception_if_emulating("Unknown context surface 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
blit_engine::context_dma blit_engine::to_context_dma(u32 in)
|
blit_engine::context_dma blit_engine::to_context_dma(u32 in)
|
||||||
@ -1170,7 +1221,7 @@ blit_engine::context_dma blit_engine::to_context_dma(u32 in)
|
|||||||
case CELL_GCM_CONTEXT_DMA_REPORT_LOCATION_MAIN: return blit_engine::context_dma::report_location_main;
|
case CELL_GCM_CONTEXT_DMA_REPORT_LOCATION_MAIN: return blit_engine::context_dma::report_location_main;
|
||||||
case CELL_GCM_CONTEXT_DMA_MEMORY_HOST_BUFFER: return blit_engine::context_dma::memory_host_buffer;
|
case CELL_GCM_CONTEXT_DMA_MEMORY_HOST_BUFFER: return blit_engine::context_dma::memory_host_buffer;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown context dma 0x%x", in);
|
return throw_exception_if_emulating("Unknown context dma 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1188,7 +1239,7 @@ user_clip_plane_op rsx::to_user_clip_plane_op(u8 in)
|
|||||||
case CELL_GCM_USER_CLIP_PLANE_ENABLE_LT: return user_clip_plane_op::less_than;
|
case CELL_GCM_USER_CLIP_PLANE_ENABLE_LT: return user_clip_plane_op::less_than;
|
||||||
case CELL_GCM_USER_CLIP_PLANE_ENABLE_GE: return user_clip_plane_op::greater_or_equal;
|
case CELL_GCM_USER_CLIP_PLANE_ENABLE_GE: return user_clip_plane_op::greater_or_equal;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown user clip plane 0x%x", in);
|
return throw_exception_if_emulating("Unknown user clip plane 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1204,7 +1255,7 @@ shading_mode rsx::to_shading_mode(u32 in)
|
|||||||
case CELL_GCM_FLAT: return shading_mode::flat;
|
case CELL_GCM_FLAT: return shading_mode::flat;
|
||||||
case CELL_GCM_SMOOTH: return shading_mode::smooth;
|
case CELL_GCM_SMOOTH: return shading_mode::smooth;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown shading mode 0x%x", in);
|
return throw_exception_if_emulating("Unknown shading mode 0x%x", in);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1222,5 +1273,5 @@ polygon_mode rsx::to_polygon_mode(u32 in)
|
|||||||
case CELL_GCM_POLYGON_MODE_LINE: return polygon_mode::line;
|
case CELL_GCM_POLYGON_MODE_LINE: return polygon_mode::line;
|
||||||
case CELL_GCM_POLYGON_MODE_FILL: return polygon_mode::fill;
|
case CELL_GCM_POLYGON_MODE_FILL: return polygon_mode::fill;
|
||||||
}
|
}
|
||||||
fmt::throw_exception("Unknown polygon mode 0x%x", in);
|
return throw_exception_if_emulating("Unknown polygon mode 0x%x", in);
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@ namespace rsx
|
|||||||
s32k, ///< signed 16bits int
|
s32k, ///< signed 16bits int
|
||||||
cmp, ///< compressed aka X11G11Z10 and always 1. W.
|
cmp, ///< compressed aka X11G11Z10 and always 1. W.
|
||||||
ub256, ///< unsigned byte interpreted as between 0 and 255.
|
ub256, ///< unsigned byte interpreted as between 0 and 255.
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
vertex_base_type to_vertex_base_type(u8 in);
|
vertex_base_type to_vertex_base_type(u8 in);
|
||||||
@ -21,6 +22,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
u32 = 0, // CELL_GCM_DRAW_INDEX_ARRAY_TYPE_32
|
u32 = 0, // CELL_GCM_DRAW_INDEX_ARRAY_TYPE_32
|
||||||
u16 = 1, // CELL_GCM_DRAW_INDEX_ARRAY_TYPE_16
|
u16 = 1, // CELL_GCM_DRAW_INDEX_ARRAY_TYPE_16
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class primitive_type : u8
|
enum class primitive_type : u8
|
||||||
@ -48,6 +50,7 @@ namespace rsx
|
|||||||
surfaces_a_b,
|
surfaces_a_b,
|
||||||
surfaces_a_b_c,
|
surfaces_a_b_c,
|
||||||
surfaces_a_b_c_d,
|
surfaces_a_b_c_d,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
surface_target to_surface_target(u8 in);
|
surface_target to_surface_target(u8 in);
|
||||||
@ -56,6 +59,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
z16, // typeless 16 bits depth
|
z16, // typeless 16 bits depth
|
||||||
z24s8, // typeless 24 bits depth + 8 bits stencil
|
z24s8, // typeless 24 bits depth + 8 bits stencil
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class surface_depth_format2 : u8
|
enum class surface_depth_format2 : u8
|
||||||
@ -64,6 +68,7 @@ namespace rsx
|
|||||||
z24s8_uint, // unsigned 24 bits depth + 8 bits stencil
|
z24s8_uint, // unsigned 24 bits depth + 8 bits stencil
|
||||||
z16_float, // floating point 16 bits depth
|
z16_float, // floating point 16 bits depth
|
||||||
z24s8_float, // floating point 24 bits depth + 8 bits stencil
|
z24s8_float, // floating point 24 bits depth + 8 bits stencil
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
surface_depth_format to_surface_depth_format(u8 in);
|
surface_depth_format to_surface_depth_format(u8 in);
|
||||||
@ -94,6 +99,7 @@ namespace rsx
|
|||||||
diagonal_centered_2_samples,
|
diagonal_centered_2_samples,
|
||||||
square_centered_4_samples,
|
square_centered_4_samples,
|
||||||
square_rotated_4_samples,
|
square_rotated_4_samples,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
surface_antialiasing to_surface_antialiasing(u8 in);
|
surface_antialiasing to_surface_antialiasing(u8 in);
|
||||||
@ -114,6 +120,7 @@ namespace rsx
|
|||||||
x8b8g8r8_z8b8g8r8,
|
x8b8g8r8_z8b8g8r8,
|
||||||
x8b8g8r8_o8b8g8r8,
|
x8b8g8r8_o8b8g8r8,
|
||||||
a8b8g8r8,
|
a8b8g8r8,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
surface_color_format to_surface_color_format(u8 in);
|
surface_color_format to_surface_color_format(u8 in);
|
||||||
@ -121,7 +128,8 @@ namespace rsx
|
|||||||
enum class window_origin : u8
|
enum class window_origin : u8
|
||||||
{
|
{
|
||||||
top,
|
top,
|
||||||
bottom
|
bottom,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
window_origin to_window_origin(u8 in);
|
window_origin to_window_origin(u8 in);
|
||||||
@ -129,7 +137,8 @@ namespace rsx
|
|||||||
enum class window_pixel_center : u8
|
enum class window_pixel_center : u8
|
||||||
{
|
{
|
||||||
half,
|
half,
|
||||||
integer
|
integer,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
window_pixel_center to_window_pixel_center(u8 in);
|
window_pixel_center to_window_pixel_center(u8 in);
|
||||||
@ -143,7 +152,8 @@ namespace rsx
|
|||||||
greater,
|
greater,
|
||||||
not_equal,
|
not_equal,
|
||||||
greater_or_equal,
|
greater_or_equal,
|
||||||
always
|
always,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
comparison_function to_comparison_function(u16 in);
|
comparison_function to_comparison_function(u16 in);
|
||||||
@ -155,7 +165,8 @@ namespace rsx
|
|||||||
exponential2,
|
exponential2,
|
||||||
exponential_abs,
|
exponential_abs,
|
||||||
exponential2_abs,
|
exponential2_abs,
|
||||||
linear_abs
|
linear_abs,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
fog_mode to_fog_mode(u32 in);
|
fog_mode to_fog_mode(u32 in);
|
||||||
@ -169,6 +180,7 @@ namespace rsx
|
|||||||
texture_dimension_2d = 1,
|
texture_dimension_2d = 1,
|
||||||
texture_dimension_cubemap = 2,
|
texture_dimension_cubemap = 2,
|
||||||
texture_dimension_3d = 3,
|
texture_dimension_3d = 3,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class texture_dimension : u8
|
enum class texture_dimension : u8
|
||||||
@ -176,6 +188,7 @@ namespace rsx
|
|||||||
dimension1d,
|
dimension1d,
|
||||||
dimension2d,
|
dimension2d,
|
||||||
dimension3d,
|
dimension3d,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
texture_dimension to_texture_dimension(u8 in);
|
texture_dimension to_texture_dimension(u8 in);
|
||||||
@ -190,6 +203,7 @@ namespace rsx
|
|||||||
mirror_once_clamp_to_edge,
|
mirror_once_clamp_to_edge,
|
||||||
mirror_once_border,
|
mirror_once_border,
|
||||||
mirror_once_clamp,
|
mirror_once_clamp,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
texture_wrap_mode to_texture_wrap_mode(u8 in);
|
texture_wrap_mode to_texture_wrap_mode(u8 in);
|
||||||
@ -204,6 +218,7 @@ namespace rsx
|
|||||||
x10,
|
x10,
|
||||||
x12,
|
x12,
|
||||||
x16,
|
x16,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
texture_max_anisotropy to_texture_max_anisotropy(u8 in);
|
texture_max_anisotropy to_texture_max_anisotropy(u8 in);
|
||||||
@ -217,6 +232,7 @@ namespace rsx
|
|||||||
nearest_linear, ///< no filtering, linear mix between closest mipmap levels
|
nearest_linear, ///< no filtering, linear mix between closest mipmap levels
|
||||||
linear_linear, ///< linear filtering, linear mix between closest mipmap levels
|
linear_linear, ///< linear filtering, linear mix between closest mipmap levels
|
||||||
convolution_min, ///< Unknown mode but looks close to linear_linear
|
convolution_min, ///< Unknown mode but looks close to linear_linear
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
texture_minify_filter to_texture_minify_filter(u8 in);
|
texture_minify_filter to_texture_minify_filter(u8 in);
|
||||||
@ -226,6 +242,7 @@ namespace rsx
|
|||||||
nearest, ///< no filtering
|
nearest, ///< no filtering
|
||||||
linear, ///< linear filtering
|
linear, ///< linear filtering
|
||||||
convolution_mag, ///< Unknown mode but looks close to linear
|
convolution_mag, ///< Unknown mode but looks close to linear
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
texture_magnify_filter to_texture_magnify_filter(u8 in);
|
texture_magnify_filter to_texture_magnify_filter(u8 in);
|
||||||
@ -240,6 +257,7 @@ namespace rsx
|
|||||||
invert,
|
invert,
|
||||||
incr_wrap,
|
incr_wrap,
|
||||||
decr_wrap,
|
decr_wrap,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
stencil_op to_stencil_op(u16 in);
|
stencil_op to_stencil_op(u16 in);
|
||||||
@ -249,11 +267,12 @@ namespace rsx
|
|||||||
add,
|
add,
|
||||||
min,
|
min,
|
||||||
max,
|
max,
|
||||||
substract,
|
subtract,
|
||||||
reverse_substract,
|
reverse_subtract,
|
||||||
reverse_substract_signed,
|
reverse_subtract_signed,
|
||||||
add_signed,
|
add_signed,
|
||||||
reverse_add_signed,
|
reverse_add_signed,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
blend_equation to_blend_equation(u16 in);
|
blend_equation to_blend_equation(u16 in);
|
||||||
@ -275,6 +294,7 @@ namespace rsx
|
|||||||
one_minus_constant_color,
|
one_minus_constant_color,
|
||||||
constant_alpha,
|
constant_alpha,
|
||||||
one_minus_constant_alpha,
|
one_minus_constant_alpha,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
blend_factor to_blend_factor(u16 in);
|
blend_factor to_blend_factor(u16 in);
|
||||||
@ -297,6 +317,7 @@ namespace rsx
|
|||||||
logic_or_inverted,
|
logic_or_inverted,
|
||||||
logic_nand,
|
logic_nand,
|
||||||
logic_set,
|
logic_set,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
logic_op to_logic_op(u16 in);
|
logic_op to_logic_op(u16 in);
|
||||||
@ -304,7 +325,8 @@ namespace rsx
|
|||||||
enum class front_face : u8
|
enum class front_face : u8
|
||||||
{
|
{
|
||||||
cw, /// clockwise
|
cw, /// clockwise
|
||||||
ccw /// counter clockwise
|
ccw, /// counter clockwise
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
front_face to_front_face(u16 in);
|
front_face to_front_face(u16 in);
|
||||||
@ -314,6 +336,7 @@ namespace rsx
|
|||||||
front = 0x0404, // CELL_GCM_FRONT
|
front = 0x0404, // CELL_GCM_FRONT
|
||||||
back = 0x0405, // CELL_GCM_BACK
|
back = 0x0405, // CELL_GCM_BACK
|
||||||
front_and_back = 0x0408, // CELL_GCM_FRONT_AND_BACK
|
front_and_back = 0x0408, // CELL_GCM_FRONT_AND_BACK
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class user_clip_plane_op : u8
|
enum class user_clip_plane_op : u8
|
||||||
@ -321,6 +344,7 @@ namespace rsx
|
|||||||
disable,
|
disable,
|
||||||
less_than,
|
less_than,
|
||||||
greater_or_equal,
|
greater_or_equal,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
user_clip_plane_op to_user_clip_plane_op(u8 in);
|
user_clip_plane_op to_user_clip_plane_op(u8 in);
|
||||||
@ -329,6 +353,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
smooth,
|
smooth,
|
||||||
flat,
|
flat,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
shading_mode to_shading_mode(u32 in);
|
shading_mode to_shading_mode(u32 in);
|
||||||
@ -338,6 +363,7 @@ namespace rsx
|
|||||||
point,
|
point,
|
||||||
line,
|
line,
|
||||||
fill,
|
fill,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
polygon_mode to_polygon_mode(u32 in);
|
polygon_mode to_polygon_mode(u32 in);
|
||||||
@ -348,6 +374,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
center,
|
center,
|
||||||
corner,
|
corner,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
transfer_origin to_transfer_origin(u8 in);
|
transfer_origin to_transfer_origin(u8 in);
|
||||||
@ -356,6 +383,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
zoh,
|
zoh,
|
||||||
foh,
|
foh,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
transfer_interpolator to_transfer_interpolator(u8 in);
|
transfer_interpolator to_transfer_interpolator(u8 in);
|
||||||
@ -398,7 +426,7 @@ namespace rsx
|
|||||||
r5g6b5,
|
r5g6b5,
|
||||||
a8r8g8b8,
|
a8r8g8b8,
|
||||||
y32,
|
y32,
|
||||||
invalid
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
transfer_destination_format to_transfer_destination_format(u8 in);
|
transfer_destination_format to_transfer_destination_format(u8 in);
|
||||||
@ -407,6 +435,7 @@ namespace rsx
|
|||||||
{
|
{
|
||||||
surface2d,
|
surface2d,
|
||||||
swizzle2d,
|
swizzle2d,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
context_surface to_context_surface(u32 in);
|
context_surface to_context_surface(u32 in);
|
||||||
@ -416,6 +445,7 @@ namespace rsx
|
|||||||
to_memory_get_report,
|
to_memory_get_report,
|
||||||
report_location_main,
|
report_location_main,
|
||||||
memory_host_buffer,
|
memory_host_buffer,
|
||||||
|
invalid,
|
||||||
};
|
};
|
||||||
|
|
||||||
context_dma to_context_dma(u32 in);
|
context_dma to_context_dma(u32 in);
|
||||||
|
@ -32,7 +32,7 @@ pup_object::pup_object(fs::file&& file) : m_file(std::move(file))
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if file size is the expected size, use substraction to avoid overflows
|
// Check if file size is the expected size, use subtraction to avoid overflows
|
||||||
if (file_size < m_header.header_length || file_size - m_header.header_length < m_header.data_length)
|
if (file_size < m_header.header_length || file_size - m_header.header_length < m_header.data_length)
|
||||||
{
|
{
|
||||||
m_formatted_error = fmt::format("Firmware size mismatch, expected: 0x%x + 0x%x, actual: 0x%x", m_header.header_length, m_header.data_length, file_size);
|
m_formatted_error = fmt::format("Firmware size mismatch, expected: 0x%x + 0x%x, actual: 0x%x", m_header.header_length, m_header.data_length, file_size);
|
||||||
@ -89,7 +89,7 @@ pup_error pup_object::validate_hashes()
|
|||||||
|
|
||||||
for (const PUPFileEntry& file : m_file_tbl)
|
for (const PUPFileEntry& file : m_file_tbl)
|
||||||
{
|
{
|
||||||
// Sanity check for offset and length, use substraction to avoid overflows
|
// Sanity check for offset and length, use subtraction to avoid overflows
|
||||||
if (size < file.data_offset || size - file.data_offset < file.data_length)
|
if (size < file.data_offset || size - file.data_offset < file.data_length)
|
||||||
{
|
{
|
||||||
m_formatted_error = fmt::format("File database entry is invalid. (offset=0x%x, length=0x%x, PUP.size=0x%x)", file.data_offset, file.data_length, size);
|
m_formatted_error = fmt::format("File database entry is invalid. (offset=0x%x, length=0x%x, PUP.size=0x%x)", file.data_offset, file.data_length, size);
|
||||||
|
Loading…
Reference in New Issue
Block a user