diff options
| author | liamwhite <liamwhite@users.noreply.github.com> | 2022-12-06 11:27:00 -0500 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-12-06 11:27:00 -0500 | 
| commit | 4b7e73e0a6d72126efebecf3c7003b12106fcab8 (patch) | |
| tree | fd978bf5e08867d86f248ca49884f6b34de6aed3 /src/core | |
| parent | d8534ea140a0e07fa010fe58fae068ed926c1dbc (diff) | |
| parent | eadc1ae1e7a4ce873467b9ea244af752f57ce5e7 (diff) | |
Merge pull request #9392 from lioncash/reporter
reporter: Eliminate undefined behavior in SaveErrorReport
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/reporter.cpp | 35 | ||||
| -rw-r--r-- | src/core/reporter.h | 16 | 
2 files changed, 26 insertions, 25 deletions
| diff --git a/src/core/reporter.cpp b/src/core/reporter.cpp index 6e21296f6..77821e047 100644 --- a/src/core/reporter.cpp +++ b/src/core/reporter.cpp @@ -38,7 +38,7 @@ std::string GetTimestamp() {  using namespace nlohmann; -void SaveToFile(json json, const std::filesystem::path& filename) { +void SaveToFile(const json& json, const std::filesystem::path& filename) {      if (!Common::FS::CreateParentDirs(filename)) {          LOG_ERROR(Core, "Failed to create path for '{}' to save report!",                    Common::FS::PathToUTF8String(filename)); @@ -81,8 +81,8 @@ json GetReportCommonData(u64 title_id, Result result, const std::string& timesta  }  json GetProcessorStateData(const std::string& architecture, u64 entry_point, u64 sp, u64 pc, -                           u64 pstate, std::array<u64, 31> registers, -                           std::optional<std::array<u64, 32>> backtrace = {}) { +                           u64 pstate, const std::array<u64, 31>& registers, +                           const std::optional<std::array<u64, 32>>& backtrace = {}) {      auto out = json{          {"entry_point", fmt::format("{:016X}", entry_point)},          {"sp", fmt::format("{:016X}", sp)}, @@ -224,11 +224,11 @@ void Reporter::SaveCrashReport(u64 title_id, Result result, u64 set_flags, u64 e      out["processor_state"] = std::move(proc_out); -    SaveToFile(std::move(out), GetPath("crash_report", title_id, timestamp)); +    SaveToFile(out, GetPath("crash_report", title_id, timestamp));  }  void Reporter::SaveSvcBreakReport(u32 type, bool signal_debugger, u64 info1, u64 info2, -                                  std::optional<std::vector<u8>> resolved_buffer) const { +                                  const std::optional<std::vector<u8>>& resolved_buffer) const {      if (!IsReportingEnabled()) {          return;      } @@ -250,7 +250,7 @@ void Reporter::SaveSvcBreakReport(u32 type, bool signal_debugger, u64 info1, u64      out["svc_break"] = std::move(break_out); -    SaveToFile(std::move(out), GetPath("svc_break_report", title_id, timestamp)); +    SaveToFile(out, GetPath("svc_break_report", title_id, timestamp));  }  void Reporter::SaveUnimplementedFunctionReport(Kernel::HLERequestContext& ctx, u32 command_id, @@ -271,13 +271,13 @@ void Reporter::SaveUnimplementedFunctionReport(Kernel::HLERequestContext& ctx, u      out["function"] = std::move(function_out); -    SaveToFile(std::move(out), GetPath("unimpl_func_report", title_id, timestamp)); +    SaveToFile(out, GetPath("unimpl_func_report", title_id, timestamp));  }  void Reporter::SaveUnimplementedAppletReport(      u32 applet_id, u32 common_args_version, u32 library_version, u32 theme_color, -    bool startup_sound, u64 system_tick, std::vector<std::vector<u8>> normal_channel, -    std::vector<std::vector<u8>> interactive_channel) const { +    bool startup_sound, u64 system_tick, const std::vector<std::vector<u8>>& normal_channel, +    const std::vector<std::vector<u8>>& interactive_channel) const {      if (!IsReportingEnabled()) {          return;      } @@ -308,10 +308,11 @@ void Reporter::SaveUnimplementedAppletReport(      out["applet_normal_data"] = std::move(normal_out);      out["applet_interactive_data"] = std::move(interactive_out); -    SaveToFile(std::move(out), GetPath("unimpl_applet_report", title_id, timestamp)); +    SaveToFile(out, GetPath("unimpl_applet_report", title_id, timestamp));  } -void Reporter::SavePlayReport(PlayReportType type, u64 title_id, std::vector<std::vector<u8>> data, +void Reporter::SavePlayReport(PlayReportType type, u64 title_id, +                              const std::vector<std::vector<u8>>& data,                                std::optional<u64> process_id, std::optional<u128> user_id) const {      if (!IsReportingEnabled()) {          return; @@ -335,12 +336,12 @@ void Reporter::SavePlayReport(PlayReportType type, u64 title_id, std::vector<std      out["play_report_type"] = fmt::format("{:02}", static_cast<u8>(type));      out["play_report_data"] = std::move(data_out); -    SaveToFile(std::move(out), GetPath("play_report", title_id, timestamp)); +    SaveToFile(out, GetPath("play_report", title_id, timestamp));  }  void Reporter::SaveErrorReport(u64 title_id, Result result, -                               std::optional<std::string> custom_text_main, -                               std::optional<std::string> custom_text_detail) const { +                               const std::optional<std::string>& custom_text_main, +                               const std::optional<std::string>& custom_text_detail) const {      if (!IsReportingEnabled()) {          return;      } @@ -354,11 +355,11 @@ void Reporter::SaveErrorReport(u64 title_id, Result result,      out["backtrace"] = GetBacktraceData(system);      out["error_custom_text"] = { -        {"main", *custom_text_main}, -        {"detail", *custom_text_detail}, +        {"main", custom_text_main.value_or("")}, +        {"detail", custom_text_detail.value_or("")},      }; -    SaveToFile(std::move(out), GetPath("error_report", title_id, timestamp)); +    SaveToFile(out, GetPath("error_report", title_id, timestamp));  }  void Reporter::SaveFSAccessLog(std::string_view log_message) const { diff --git a/src/core/reporter.h b/src/core/reporter.h index 68755cbde..9fdb9d6c1 100644 --- a/src/core/reporter.h +++ b/src/core/reporter.h @@ -36,7 +36,7 @@ public:      // Used by syscall svcBreak      void SaveSvcBreakReport(u32 type, bool signal_debugger, u64 info1, u64 info2, -                            std::optional<std::vector<u8>> resolved_buffer = {}) const; +                            const std::optional<std::vector<u8>>& resolved_buffer = {}) const;      // Used by HLE service handler      void SaveUnimplementedFunctionReport(Kernel::HLERequestContext& ctx, u32 command_id, @@ -44,10 +44,10 @@ public:                                           const std::string& service_name) const;      // Used by stub applet implementation -    void SaveUnimplementedAppletReport(u32 applet_id, u32 common_args_version, u32 library_version, -                                       u32 theme_color, bool startup_sound, u64 system_tick, -                                       std::vector<std::vector<u8>> normal_channel, -                                       std::vector<std::vector<u8>> interactive_channel) const; +    void SaveUnimplementedAppletReport( +        u32 applet_id, u32 common_args_version, u32 library_version, u32 theme_color, +        bool startup_sound, u64 system_tick, const std::vector<std::vector<u8>>& normal_channel, +        const std::vector<std::vector<u8>>& interactive_channel) const;      enum class PlayReportType {          Old, @@ -56,13 +56,13 @@ public:          System,      }; -    void SavePlayReport(PlayReportType type, u64 title_id, std::vector<std::vector<u8>> data, +    void SavePlayReport(PlayReportType type, u64 title_id, const std::vector<std::vector<u8>>& data,                          std::optional<u64> process_id = {}, std::optional<u128> user_id = {}) const;      // Used by error applet      void SaveErrorReport(u64 title_id, Result result, -                         std::optional<std::string> custom_text_main = {}, -                         std::optional<std::string> custom_text_detail = {}) const; +                         const std::optional<std::string>& custom_text_main = {}, +                         const std::optional<std::string>& custom_text_detail = {}) const;      void SaveFSAccessLog(std::string_view log_message) const; | 
