From e43e86aedad28df44e026a61e2c1112d574337c7 Mon Sep 17 00:00:00 2001 From: shinyquagsire23 Date: Mon, 1 Aug 2016 15:16:36 -0700 Subject: [PATCH 1/3] Add basic MCP coreinit imports --- include/coreinit/mcp.h | 83 +++++++++++++++++++++++++++++++++++++++ rpl/libcoreinit/exports.h | 12 ++++++ 2 files changed, 95 insertions(+) create mode 100644 include/coreinit/mcp.h diff --git a/include/coreinit/mcp.h b/include/coreinit/mcp.h new file mode 100644 index 0000000..c27a6b8 --- /dev/null +++ b/include/coreinit/mcp.h @@ -0,0 +1,83 @@ +#pragma once +#include + +/** + * \defgroup coreinit_mcp MCP IOS Calls + * \ingroup coreinit + * @{ + */ + +#ifdef __cplusplus +extern "C" { +#endif + +typedef enum MCPInstallTarget +{ + MCP_INSTALL_TARGET_MLC = 0, + MCP_INSTALL_TARGET_USB = 1, +} MCPInstallTarget; + +typedef struct MCPInstallProgress MCPInstallProgress; +typedef struct MCPInstallInfo MCPInstallInfo; +typedef struct MCPInstallTitleInfo MCPInstallTitleInfo; + +struct __attribute__((__packed__)) MCPInstallProgress +{ + u32 inProgress; + u64 tid; + u64 sizeTotal; + u64 sizeProgress; + u32 contentsTotal; + u32 contentsProgress; +}; +CHECK_OFFSET(MCPInstallProgress, 0x04, tid); +CHECK_OFFSET(MCPInstallProgress, 0x20, contentsProgress); +CHECK_SIZE(MCPInstallProgress, 0x24); + +struct MCPInstallInfo +{ + UNKNOWN(0x27F); +}; +CHECK_SIZE(MCPInstallInfo, 0x27F); + +struct MCPInstallTitleInfo +{ + UNKNOWN(0x27F); +}; +CHECK_SIZE(MCPInstallTitleInfo, 0x27F); + +int +MCP_Open(); + +int +MCP_Close(int handle); + +int +MCP_InstallSetTargetDevice(int handle, MCPInstallTarget device); + +int +MCP_InstallGetTargetDevice(int handle, MCPInstallTarget *deviceOut); + +int +MCP_InstallSetTargetUsb(int handle, int usb); + +int +MCP_InstallGetInfo(int handle, char *path, MCPInstallInfo *out); + +int +MCP_InstallTitleAsync(int handle, char *path, MCPInstallTitleInfo *out); + +int +MCP_InstallGetProgress(int handle, MCPInstallProgress *installProgressOut); + +int +MCP_InstallTitleAbort(int handle); + +int +MCP_UninstallTitleAsync(int handle, char *path, MCPInstallTitleInfo *out); + +#ifdef __cplusplus +} +#endif + +/** @} */ diff --git a/rpl/libcoreinit/exports.h b/rpl/libcoreinit/exports.h index 1b7be96..df80500 100644 --- a/rpl/libcoreinit/exports.h +++ b/rpl/libcoreinit/exports.h @@ -186,6 +186,18 @@ EXPORT(MEMAdjustFrmHeap); EXPORT(MEMResizeForMBlockFrmHeap); EXPORT(MEMGetAllocatableSizeForFrmHeapEx); +// coreinit/mcp.h +EXPORT(MCP_Open); +EXPORT(MCP_Close); +EXPORT(MCP_InstallSetTargetDevice); +EXPORT(MCP_InstallGetTargetDevice); +EXPORT(MCP_InstallSetTargetUsb); +EXPORT(MCP_InstallGetInfo); +EXPORT(MCP_InstallTitleAsync); +EXPORT(MCP_InstallGetProgress); +EXPORT(MCP_InstallTitleAbort); +EXPORT(MCP_DeleteTitleAsync); + // coreinit/memheap.h EXPORT(MEMDumpHeap); EXPORT(MEMFindContainHeap); From c0148133db74e44377f81f151655e7047766b4c9 Mon Sep 17 00:00:00 2001 From: shinyquagsire23 Date: Mon, 1 Aug 2016 15:22:44 -0700 Subject: [PATCH 2/3] Fix ordering in mcp.h --- include/coreinit/mcp.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/include/coreinit/mcp.h b/include/coreinit/mcp.h index c27a6b8..3579540 100644 --- a/include/coreinit/mcp.h +++ b/include/coreinit/mcp.h @@ -11,16 +11,16 @@ extern "C" { #endif +typedef struct MCPInstallProgress MCPInstallProgress; +typedef struct MCPInstallInfo MCPInstallInfo; +typedef struct MCPInstallTitleInfo MCPInstallTitleInfo; + typedef enum MCPInstallTarget { MCP_INSTALL_TARGET_MLC = 0, MCP_INSTALL_TARGET_USB = 1, } MCPInstallTarget; -typedef struct MCPInstallProgress MCPInstallProgress; -typedef struct MCPInstallInfo MCPInstallInfo; -typedef struct MCPInstallTitleInfo MCPInstallTitleInfo; - struct __attribute__((__packed__)) MCPInstallProgress { u32 inProgress; From 7e3b1445eb11d8f6b8abc8e8331ca7ff4a2406d3 Mon Sep 17 00:00:00 2001 From: shinyquagsire23 Date: Sat, 6 Aug 2016 22:03:30 -0700 Subject: [PATCH 3/3] Add MCP_DeviceList and MCP_FullDeviceList --- include/coreinit/mcp.h | 20 ++++++++++++++++++++ rpl/libcoreinit/exports.h | 2 ++ 2 files changed, 22 insertions(+) diff --git a/include/coreinit/mcp.h b/include/coreinit/mcp.h index 3579540..d5faac2 100644 --- a/include/coreinit/mcp.h +++ b/include/coreinit/mcp.h @@ -14,6 +14,8 @@ extern "C" { typedef struct MCPInstallProgress MCPInstallProgress; typedef struct MCPInstallInfo MCPInstallInfo; typedef struct MCPInstallTitleInfo MCPInstallTitleInfo; +typedef struct MCPDevice MCPDevice; +typedef struct MCPDeviceList MCPDeviceList; typedef enum MCPInstallTarget { @@ -46,6 +48,18 @@ struct MCPInstallTitleInfo }; CHECK_SIZE(MCPInstallTitleInfo, 0x27F); +struct MCPDevice +{ + char name[0x31B]; +}; +CHECK_SIZE(MCPDevice, 0x31B); + +struct MCPDeviceList +{ + MCPDevice devices[32]; +}; +CHECK_SIZE(MCPDeviceList, 0x31B*32); + int MCP_Open(); @@ -76,6 +90,12 @@ MCP_InstallTitleAbort(int handle); int MCP_UninstallTitleAsync(int handle, char *path, MCPInstallTitleInfo *out); +int +MCP_DeviceList(int handle, int *numDevices, MCPDeviceList *outDevices, uint32_t outBufferSize); + +int +MCP_FullDeviceList(int handle, int *numDevices, MCPDeviceList *outDevices, uint32_t outBufferSize); + #ifdef __cplusplus } #endif diff --git a/rpl/libcoreinit/exports.h b/rpl/libcoreinit/exports.h index df80500..898d9b9 100644 --- a/rpl/libcoreinit/exports.h +++ b/rpl/libcoreinit/exports.h @@ -197,6 +197,8 @@ EXPORT(MCP_InstallTitleAsync); EXPORT(MCP_InstallGetProgress); EXPORT(MCP_InstallTitleAbort); EXPORT(MCP_DeleteTitleAsync); +EXPORT(MCP_DeviceList); +EXPORT(MCP_FullDeviceList); // coreinit/memheap.h EXPORT(MEMDumpHeap);