Added capssuSaveScreenShotWithUserData, capssuSaveScreenShotWithUserIds, capssuSaveScreenShotEx1, and capssuSaveScreenShotEx2. Updated params for capssuSaveScreenShot and capssuSaveScreenShotEx0. Added enum AlbumReportOption, and structs CapsApplicationData/CapsUserIdList. Updated CapsScreenShotAttribute. Updated docs.

This commit is contained in:
yellows8 2019-08-30 23:14:31 -04:00
parent 5dc2fc0b7e
commit eeabd3bed0
No known key found for this signature in database
GPG Key ID: 0AF90DA3F1E60E43
3 changed files with 217 additions and 21 deletions

View File

@ -7,10 +7,30 @@
#pragma once #pragma once
#include "../types.h" #include "../types.h"
#include "../services/sm.h" #include "../services/sm.h"
#include "../services/acc.h"
/// ImageOrientation
typedef enum {
AlbumImageOrientation_Unknown0 = 0, ///< Unknown. Default.
AlbumImageOrientation_Unknown1 = 1, ///< Unknown.
AlbumImageOrientation_Unknown2 = 2, ///< Unknown.
AlbumImageOrientation_Unknown3 = 3, ///< Unknown.
} AlbumImageOrientation;
/// AlbumReportOption
typedef enum {
AlbumReportOption_Unknown0 = 0, ///< Unknown.
AlbumReportOption_Unknown1 = 1, ///< Unknown.
AlbumReportOption_Unknown2 = 2, ///< Unknown.
AlbumReportOption_Unknown3 = 3, ///< Unknown.
} AlbumReportOption;
typedef struct { typedef struct {
u32 unk_x0; u32 unk_x0; ///< Always set to 0 by official sw.
u8 unk_x4[0x3c]; u32 orientation; ///< \ref AlbumImageOrientation
u32 unk_x8; ///< Always set to 0 by official sw.
u32 unk_xc; ///< Always set to 1 by official sw.
u8 unk_x10[0x30]; ///< Always set to 0 by official sw.
} CapsScreenShotAttribute; } CapsScreenShotAttribute;
/// AlbumFileDateTime. This corresponds to each field in the Album entry filename, prior to the "-". /// AlbumFileDateTime. This corresponds to each field in the Album entry filename, prior to the "-".
@ -44,13 +64,18 @@ typedef struct {
u8 data[0x20]; u8 data[0x20];
} CapsApplicationAlbumEntry; } CapsApplicationAlbumEntry;
/// ImageOrientation /// ApplicationData
typedef enum { typedef struct {
AlbumImageOrientation_Unknown0 = 0, ///< Unknown. u8 userdata[0x400]; ///< UserData.
AlbumImageOrientation_Unknown1 = 1, ///< Unknown. u32 size; ///< UserData size.
AlbumImageOrientation_Unknown2 = 2, ///< Unknown. } CapsApplicationData;
AlbumImageOrientation_Unknown3 = 3, ///< Unknown.
} AlbumImageOrientation; /// UserIdList
typedef struct {
union { u128 userIDs[ACC_USER_LIST_SIZE]; } PACKED; ///< userIDs.
u8 count; ///< Total userIDs.
u8 pad[7]; ///< Padding.
} CapsUserIdList;
// Get the ShimLibraryVersion. // Get the ShimLibraryVersion.
u64 capsGetShimLibraryVersion(void); u64 capsGetShimLibraryVersion(void);

View File

@ -11,12 +11,83 @@
/// Initialize caps:su. Only available on [4.0.0+]. /// Initialize caps:su. Only available on [4.0.0+].
Result capssuInitialize(void); Result capssuInitialize(void);
/// Exit caps:su.
void capssuExit(void); void capssuExit(void);
/// Gets the Service for caps:su.
Service* capssuGetServiceSession(void); Service* capssuGetServiceSession(void);
/// Same as \ref capssuSaveScreenShotEx0, except this uses an all-zero CapsScreenShotAttribute where the first u32 is set to attr_val. attr_val can be zero. /**
Result capssuSaveScreenShot(const void* buffer, size_t size, u32 unk, u32 attr_val, CapsApplicationAlbumEntry *out); * @brief This is a wrapper for \ref capssuSaveScreenShotEx0.
* @note This uses an all-zero \ref CapsScreenShotAttribute with orientation = input orientation, and unk_xc = 1.
* @param[in] buffer RGBA8 1280x720 image buffer.
* @param[in] size Size of the buffer.
* @param[in] reportoption \ref AlbumReportOption
* @param[in] orientation \ref AlbumImageOrientation
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShot(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, CapsApplicationAlbumEntry *out);
/// Saves an Album screenshot using the specified gfx data in buffer (1280x720 RGBA8), size must be at least 0x384000. unk can be zero. /**
Result capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScreenShotAttribute *attr, u32 unk, CapsApplicationAlbumEntry *out); * @brief Similar to \ref capssuSaveScreenShot, except this is a wrapper for \ref capssuSaveScreenShotEx1.
* @note This uses an all-zero \ref CapsScreenShotAttribute with orientation = input orientation, and unk_xc = 1.
* @note Only available on [8.0.0+].
* @param[in] buffer RGBA8 1280x720 image data buffer.
* @param[in] size Size of the buffer.
* @param[in] reportoption \ref AlbumReportOption
* @param[in] orientation \ref AlbumImageOrientation
* @param[in] userdata Input UserData buffer. If NULL, the \ref CapsApplicationData will be empty.
* @param[in] userdata_size Input UserData size, must be within bounds for CapsApplicationData::userdata. If 0, the \ref CapsApplicationData will be empty.
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShotWithUserData(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, const void* userdata, size_t userdata_size, CapsApplicationAlbumEntry *out);
/**
* @brief Similar to \ref capssuSaveScreenShot, except this is a wrapper for \ref capssuSaveScreenShotEx2.
* @note This uses an all-zero \ref CapsScreenShotAttribute with orientation = input orientation, and unk_xc = 1.
* @note Only available on [6.0.0+].
* @param[in] buffer RGBA8 1280x720 image data buffer.
* @param[in] size Size of the buffer.
* @param[in] reportoption \ref AlbumReportOption
* @param[in] orientation \ref AlbumImageOrientation
* @param[in] userIDs Input array of account userIDs. If NULL, the \ref CapsUserIdList will be empty.
* @param[in] userID_count Size of the userID array in entries, must be within bounds for CapsUserIdList::userIDs. If 0, the \ref CapsUserIdList will be empty.
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShotWithUserIds(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, const u128* userIDs, size_t userID_count, CapsApplicationAlbumEntry *out);
/**
* @brief Saves an Album screenshot using the specified gfx data in the buffer, with the specified \ref CapsScreenShotAttribute.
* @param[in] buffer RGBA8 1280x720 image data buffer.
* @param[in] size Size of the buffer, must be at least 0x384000.
* @param[in] attr \ref CapsScreenShotAttribute
* @param[in] reportoption \ref AlbumReportOption
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShotEx0(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationAlbumEntry *out);
/**
* @brief Same as \ref capssuSaveScreenShotEx0, except this allows specifying the \ref CapsApplicationData.
* @note Only available on [8.0.0+].
* @param[in] buffer RGBA8 1280x720 image data buffer.
* @param[in] size Size of the buffer, must be at least 0x384000.
* @param[in] attr \ref CapsScreenShotAttribute
* @param[in] reportoption \ref AlbumReportOption
* @parma[in] appdata \ref CapsApplicationData
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShotEx1(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationData *appdata, CapsApplicationAlbumEntry *out);
/**
* @brief Same as \ref capssuSaveScreenShotEx0, except this allows specifying the \ref CapsUserIdList.
* @note Only available on [6.0.0+].
* @param[in] buffer RGBA8 1280x720 image data buffer.
* @param[in] size Size of the buffer, must be at least 0x384000.
* @param[in] attr \ref CapsScreenShotAttribute
* @param[in] reportoption \ref AlbumReportOption
* @parma[in] list \ref CapsUserIdList
* @param[out] out \ref CapsApplicationAlbumEntry. Optional, can be NULL.
*/
Result capssuSaveScreenShotEx2(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsUserIdList *list, CapsApplicationAlbumEntry *out);

View File

@ -7,6 +7,7 @@
#include "services/applet.h" #include "services/applet.h"
#include "services/caps.h" #include "services/caps.h"
#include "services/capssu.h" #include "services/capssu.h"
#include "services/acc.h"
#include "services/sm.h" #include "services/sm.h"
static Service g_capssuSrv; static Service g_capssuSrv;
@ -87,7 +88,7 @@ static Result _capssuSetShimLibraryVersion(u64 version) {
return rc; return rc;
} }
static Result _capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScreenShotAttribute *attr, u32 unk, CapsApplicationAlbumEntry *out) { static Result _capssuSaveScreenShotEx0(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationAlbumEntry *out) {
u64 AppletResourceUserId = 0; u64 AppletResourceUserId = 0;
appletGetAppletResourceUserId(&AppletResourceUserId); appletGetAppletResourceUserId(&AppletResourceUserId);
@ -98,7 +99,7 @@ static Result _capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScre
u64 magic; u64 magic;
u64 cmd_id; u64 cmd_id;
CapsScreenShotAttribute attr; CapsScreenShotAttribute attr;
u32 unk; u32 reportoption;
u64 AppletResourceUserId; u64 AppletResourceUserId;
} *raw; } *raw;
@ -110,7 +111,7 @@ static Result _capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScre
raw->magic = SFCI_MAGIC; raw->magic = SFCI_MAGIC;
raw->cmd_id = 203; raw->cmd_id = 203;
raw->attr = *attr; raw->attr = *attr;
raw->unk = unk; raw->reportoption = reportoption;
raw->AppletResourceUserId = AppletResourceUserId; raw->AppletResourceUserId = AppletResourceUserId;
Result rc = serviceIpcDispatch(&g_capssuSrv); Result rc = serviceIpcDispatch(&g_capssuSrv);
@ -134,16 +135,115 @@ static Result _capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScre
return rc; return rc;
} }
Result capssuSaveScreenShot(const void* buffer, size_t size, u32 unk, u32 attr_val, CapsApplicationAlbumEntry *out) { static Result _capssuSaveScreenShotEx(u64 cmd_id, bool pid, const void* argbuf, size_t argbuf_size, const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationAlbumEntry *out) {
u64 AppletResourceUserId = 0;
appletGetAppletResourceUserId(&AppletResourceUserId);
IpcCommand c;
ipcInitialize(&c);
struct {
u64 magic;
u64 cmd_id;
CapsScreenShotAttribute attr;
u32 reportoption;
u64 AppletResourceUserId;
} *raw;
if (pid) ipcSendPid(&c);
ipcAddSendBuffer(&c, argbuf, argbuf_size, BufferType_Normal);
ipcAddSendBuffer(&c, buffer, size, BufferType_Type1);
raw = serviceIpcPrepareHeader(&g_capssuSrv, &c, sizeof(*raw));
raw->magic = SFCI_MAGIC;
raw->cmd_id = cmd_id;
raw->attr = *attr;
raw->reportoption = reportoption;
raw->AppletResourceUserId = AppletResourceUserId;
Result rc = serviceIpcDispatch(&g_capssuSrv);
if (R_SUCCEEDED(rc)) {
IpcParsedCommand r;
struct {
u64 magic;
u64 result;
CapsApplicationAlbumEntry out;
} *resp;
serviceIpcParse(&g_capssuSrv, &r, sizeof(*resp));
resp = r.Raw;
rc = resp->result;
if (R_SUCCEEDED(rc) && out) *out = resp->out;
}
return rc;
}
Result capssuSaveScreenShot(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, CapsApplicationAlbumEntry *out) {
CapsScreenShotAttribute attr; CapsScreenShotAttribute attr;
memset(&attr, 0, sizeof(attr)); memset(&attr, 0, sizeof(attr));
attr.unk_x0 = attr_val; attr.orientation = orientation;
attr.unk_xc = 1;
return _capssuSaveScreenShotEx0(buffer, size, &attr, unk, out); return _capssuSaveScreenShotEx0(buffer, size, &attr, reportoption, out);
} }
Result capssuSaveScreenShotEx0(const void* buffer, size_t size, CapsScreenShotAttribute *attr, u32 unk, CapsApplicationAlbumEntry *out) { Result capssuSaveScreenShotWithUserData(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, const void* userdata, size_t userdata_size, CapsApplicationAlbumEntry *out) {
return _capssuSaveScreenShotEx0(buffer, size, attr, unk, out); CapsScreenShotAttribute attr;
CapsApplicationData appdata;
if (userdata_size > sizeof(appdata).userdata)
return MAKERESULT(Module_Libnx, LibnxError_BadInput);
memset(&attr, 0, sizeof(attr));
attr.orientation = orientation;
attr.unk_xc = 1;
memset(&appdata, 0, sizeof(appdata));
if (userdata && userdata_size) memcpy(appdata.userdata, userdata, userdata_size);
appdata.size = userdata_size;
return capssuSaveScreenShotEx1(buffer, size, &attr, reportoption, &appdata, out);
}
Result capssuSaveScreenShotWithUserIds(const void* buffer, size_t size, AlbumReportOption reportoption, AlbumImageOrientation orientation, const u128* userIDs, size_t userID_count, CapsApplicationAlbumEntry *out) {
CapsScreenShotAttribute attr;
CapsUserIdList list;
if (userID_count > ACC_USER_LIST_SIZE)
return MAKERESULT(Module_Libnx, LibnxError_BadInput);
memset(&attr, 0, sizeof(attr));
attr.orientation = orientation;
attr.unk_xc = 1;
memset(&list, 0, sizeof(list));
if (userIDs && userID_count) memcpy(list.userIDs, userIDs, userID_count*sizeof(u128));
list.count = userID_count;
return capssuSaveScreenShotEx2(buffer, size, &attr, reportoption, &list, out);
}
Result capssuSaveScreenShotEx0(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationAlbumEntry *out) {
return _capssuSaveScreenShotEx0(buffer, size, attr, reportoption, out);
}
Result capssuSaveScreenShotEx1(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsApplicationData *appdata, CapsApplicationAlbumEntry *out) {
if (hosversionBefore(7,0,0))
return MAKERESULT(Module_Libnx, LibnxError_IncompatSysVer);
return _capssuSaveScreenShotEx(205, true, appdata, sizeof(*appdata), buffer, size, attr, reportoption, out);
}
Result capssuSaveScreenShotEx2(const void* buffer, size_t size, const CapsScreenShotAttribute *attr, AlbumReportOption reportoption, CapsUserIdList *list, CapsApplicationAlbumEntry *out) {
if (hosversionBefore(6,0,0))
return MAKERESULT(Module_Libnx, LibnxError_IncompatSysVer);
return _capssuSaveScreenShotEx(210, false, list, sizeof(*list), buffer, size, attr, reportoption, out);
} }