mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-08 21:47:57 +00:00
cs: prevent exceptions from manifesting
This commit is contained in:
parent
888b35833e
commit
41a4bf53f6
3 changed files with 27 additions and 27 deletions
|
@ -20,14 +20,13 @@ namespace ams::cs {
|
||||||
|
|
||||||
struct CommandDataTakeScreenShot {
|
struct CommandDataTakeScreenShot {
|
||||||
vi::LayerStack layer_stack;
|
vi::LayerStack layer_stack;
|
||||||
std::function<void (s32, s32, s32)> send_header;
|
|
||||||
std::function<void (u8 *, size_t)> send_data;
|
|
||||||
u8 *buffer;
|
u8 *buffer;
|
||||||
size_t buffer_size;
|
size_t buffer_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
Result DoGetFirmwareVersionCommand(settings::system::FirmwareVersion *out);
|
Result DoGetFirmwareVersionCommand(settings::system::FirmwareVersion *out);
|
||||||
|
|
||||||
Result DoTakeScreenShotCommand(const CommandDataTakeScreenShot ¶ms);
|
template<typename SendHeader, typename SendData>
|
||||||
|
Result DoTakeScreenShotCommand(const CommandDataTakeScreenShot ¶ms, SendHeader send_header, SendData send_data);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,14 +13,13 @@
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
#include <stratosphere.hpp>
|
|
||||||
#include "cs_command_impl.hpp"
|
|
||||||
|
|
||||||
namespace ams::cs {
|
namespace ams::cs {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
void SendEmptyData(const CommandDataTakeScreenShot ¶ms, size_t remaining_size) {
|
template<typename SendData>
|
||||||
|
void SendEmptyData(const CommandDataTakeScreenShot ¶ms, size_t remaining_size, SendData send_data) {
|
||||||
/* Clear the data buffer. */
|
/* Clear the data buffer. */
|
||||||
std::memset(params.buffer, 0, params.buffer_size);
|
std::memset(params.buffer, 0, params.buffer_size);
|
||||||
|
|
||||||
|
@ -28,7 +27,7 @@ namespace ams::cs {
|
||||||
while (remaining_size > 0) {
|
while (remaining_size > 0) {
|
||||||
/* Send as much as we can. */
|
/* Send as much as we can. */
|
||||||
const auto cur_size = std::min(remaining_size, params.buffer_size);
|
const auto cur_size = std::min(remaining_size, params.buffer_size);
|
||||||
params.send_data(params.buffer, cur_size);
|
send_data(params.buffer, cur_size);
|
||||||
|
|
||||||
/* Advance. */
|
/* Advance. */
|
||||||
remaining_size -= cur_size;
|
remaining_size -= cur_size;
|
||||||
|
@ -42,7 +41,8 @@ namespace ams::cs {
|
||||||
return ResultSuccess();
|
return ResultSuccess();
|
||||||
}
|
}
|
||||||
|
|
||||||
Result DoTakeScreenShotCommand(const CommandDataTakeScreenShot ¶ms) {
|
template<typename SendHeader, typename SendData>
|
||||||
|
Result DoTakeScreenShotCommand(const CommandDataTakeScreenShot ¶ms, SendHeader send_header, SendData send_data) {
|
||||||
/* Initialize screenshot control. */
|
/* Initialize screenshot control. */
|
||||||
R_TRY(capsrv::InitializeScreenShotControl());
|
R_TRY(capsrv::InitializeScreenShotControl());
|
||||||
|
|
||||||
|
@ -58,18 +58,18 @@ namespace ams::cs {
|
||||||
ON_SCOPE_EXIT { capsrv::CloseRawScreenShotReadStreamForDevelop(); };
|
ON_SCOPE_EXIT { capsrv::CloseRawScreenShotReadStreamForDevelop(); };
|
||||||
|
|
||||||
/* Send the header. */
|
/* Send the header. */
|
||||||
params.send_header(static_cast<s32>(data_size), width, height);
|
send_header(static_cast<s32>(data_size), width, height);
|
||||||
|
|
||||||
/* Read and send data. */
|
/* Read and send data. */
|
||||||
size_t total_read_size = 0;
|
size_t total_read_size = 0;
|
||||||
auto data_guard = SCOPE_GUARD { SendEmptyData(params, data_size - total_read_size); };
|
auto data_guard = SCOPE_GUARD { SendEmptyData(params, data_size - total_read_size, send_data); };
|
||||||
while (total_read_size < data_size) {
|
while (total_read_size < data_size) {
|
||||||
/* Read data from the stream. */
|
/* Read data from the stream. */
|
||||||
size_t read_size;
|
size_t read_size;
|
||||||
R_TRY(capsrv::ReadRawScreenShotReadStreamForDevelop(std::addressof(read_size), params.buffer, params.buffer_size, total_read_size));
|
R_TRY(capsrv::ReadRawScreenShotReadStreamForDevelop(std::addressof(read_size), params.buffer, params.buffer_size, total_read_size));
|
||||||
|
|
||||||
/* Send the data that was read. */
|
/* Send the data that was read. */
|
||||||
params.send_data(params.buffer, read_size);
|
send_data(params.buffer, read_size);
|
||||||
|
|
||||||
/* Advance. */
|
/* Advance. */
|
||||||
total_read_size += read_size;
|
total_read_size += read_size;
|
|
@ -16,6 +16,9 @@
|
||||||
#include <stratosphere.hpp>
|
#include <stratosphere.hpp>
|
||||||
#include "cs_command_impl.hpp"
|
#include "cs_command_impl.hpp"
|
||||||
|
|
||||||
|
/* Include command implementations. */
|
||||||
|
#include "cs_command_impl.inc"
|
||||||
|
|
||||||
namespace ams::cs {
|
namespace ams::cs {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -82,7 +85,18 @@ namespace ams::cs {
|
||||||
/* Create the command data. */
|
/* Create the command data. */
|
||||||
const CommandDataTakeScreenShot params = {
|
const CommandDataTakeScreenShot params = {
|
||||||
.layer_stack = layer_stack,
|
.layer_stack = layer_stack,
|
||||||
.send_header = [&](s32 data_size, s32 width, s32 height) {
|
.buffer = g_data,
|
||||||
|
.buffer_size = sizeof(g_data),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Take the screenshot. */
|
||||||
|
Result result;
|
||||||
|
{
|
||||||
|
/* Acquire the send lock. */
|
||||||
|
auto lk = MakeSendGuardBlock();
|
||||||
|
|
||||||
|
/* Perform the command. */
|
||||||
|
result = DoTakeScreenShotCommand(params, [&](s32 data_size, s32 width, s32 height) {
|
||||||
/* Use global buffer for response. */
|
/* Use global buffer for response. */
|
||||||
ResponseTakeScreenShot *response = reinterpret_cast<ResponseTakeScreenShot *>(g_data);
|
ResponseTakeScreenShot *response = reinterpret_cast<ResponseTakeScreenShot *>(g_data);
|
||||||
|
|
||||||
|
@ -100,23 +114,10 @@ namespace ams::cs {
|
||||||
|
|
||||||
/* Send data. */
|
/* Send data. */
|
||||||
Send(socket, response, sizeof(*response));
|
Send(socket, response, sizeof(*response));
|
||||||
},
|
}, [&](u8 *data, size_t data_size) {
|
||||||
.send_data = [&](u8 *data, size_t data_size) {
|
|
||||||
/* Send data. */
|
/* Send data. */
|
||||||
Send(socket, data, data_size);
|
Send(socket, data, data_size);
|
||||||
},
|
});
|
||||||
.buffer = g_data,
|
|
||||||
.buffer_size = sizeof(g_data),
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Take the screenshot. */
|
|
||||||
Result result;
|
|
||||||
{
|
|
||||||
/* Acquire the send lock. */
|
|
||||||
auto lk = MakeSendGuardBlock();
|
|
||||||
|
|
||||||
/* Perform the command. */
|
|
||||||
result = DoTakeScreenShotCommand(params);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Handle the error case. */
|
/* Handle the error case. */
|
||||||
|
|
Loading…
Reference in a new issue