2015-06-11 22:12:16 +00:00
|
|
|
// Copyright 2015 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2017-10-05 22:22:15 +00:00
|
|
|
#include <string>
|
|
|
|
#include "common/common_types.h"
|
|
|
|
|
|
|
|
namespace Service {
|
|
|
|
namespace FS {
|
|
|
|
enum class MediaType : u32;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-11 22:12:16 +00:00
|
|
|
namespace Service {
|
2016-02-02 06:17:41 +00:00
|
|
|
|
|
|
|
class Interface;
|
|
|
|
|
2015-06-11 22:12:16 +00:00
|
|
|
namespace AM {
|
|
|
|
|
2017-10-25 17:41:07 +00:00
|
|
|
namespace ErrCodes {
|
|
|
|
enum {
|
2017-10-21 23:28:13 +00:00
|
|
|
CIACurrentlyInstalling = 4,
|
2017-11-07 00:49:39 +00:00
|
|
|
InvalidTID = 31,
|
2017-10-21 23:28:13 +00:00
|
|
|
EmptyCIA = 32,
|
2017-10-25 17:41:07 +00:00
|
|
|
InvalidTIDInList = 60,
|
2017-10-21 23:28:13 +00:00
|
|
|
InvalidCIAHeader = 104,
|
2017-10-25 17:41:07 +00:00
|
|
|
};
|
|
|
|
} // namespace ErrCodes
|
|
|
|
|
2017-10-21 23:28:13 +00:00
|
|
|
enum class CIAInstallState : u32 {
|
|
|
|
InstallStarted,
|
|
|
|
HeaderLoaded,
|
|
|
|
CertLoaded,
|
|
|
|
TicketLoaded,
|
|
|
|
TMDLoaded,
|
|
|
|
ContentWritten,
|
|
|
|
};
|
|
|
|
|
2017-11-14 21:57:44 +00:00
|
|
|
/**
|
|
|
|
* Get the mediatype for an installed title
|
|
|
|
* @param titleId the installed title ID
|
|
|
|
* @returns MediaType which the installed title will reside on
|
|
|
|
*/
|
|
|
|
Service::FS::MediaType GetTitleMediaType(u64 titleId);
|
|
|
|
|
2017-10-05 22:22:15 +00:00
|
|
|
/**
|
|
|
|
* Get the .tmd path for a title
|
|
|
|
* @param media_type the media the title exists on
|
|
|
|
* @param tid the title ID to get
|
2017-10-21 23:28:13 +00:00
|
|
|
* @param update set true if the incoming TMD should be used instead of the current TMD
|
2017-10-05 22:22:15 +00:00
|
|
|
* @returns string path to the .tmd file if it exists, otherwise a path to create one is given.
|
|
|
|
*/
|
2017-10-21 23:28:13 +00:00
|
|
|
std::string GetTitleMetadataPath(Service::FS::MediaType media_type, u64 tid, bool update = false);
|
2017-10-05 22:22:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the .app path for a title's installed content index.
|
|
|
|
* @param media_type the media the title exists on
|
|
|
|
* @param tid the title ID to get
|
|
|
|
* @param index the content index to get
|
2017-10-21 23:28:13 +00:00
|
|
|
* @param update set true if the incoming TMD should be used instead of the current TMD
|
2017-10-05 22:22:15 +00:00
|
|
|
* @returns string path to the .app file
|
|
|
|
*/
|
2017-10-21 23:28:13 +00:00
|
|
|
std::string GetTitleContentPath(Service::FS::MediaType media_type, u64 tid, u16 index = 0,
|
|
|
|
bool update = false);
|
2017-10-05 22:22:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the folder for a title's installed content.
|
|
|
|
* @param media_type the media the title exists on
|
|
|
|
* @param tid the title ID to get
|
|
|
|
* @returns string path to the title folder
|
|
|
|
*/
|
|
|
|
std::string GetTitlePath(Service::FS::MediaType media_type, u64 tid);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the title/ folder for a storage medium.
|
|
|
|
* @param media_type the storage medium to get the path for
|
|
|
|
* @returns string path to the folder
|
|
|
|
*/
|
|
|
|
std::string GetMediaTitlePath(Service::FS::MediaType media_type);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scans the for titles in a storage medium for listing.
|
|
|
|
* @param media_type the storage medium to scan
|
|
|
|
*/
|
|
|
|
void ScanForTitles(Service::FS::MediaType media_type);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scans all storage mediums for titles for listing.
|
|
|
|
*/
|
|
|
|
void ScanForAllTitles();
|
|
|
|
|
2015-06-11 22:12:16 +00:00
|
|
|
/**
|
2016-12-07 22:42:51 +00:00
|
|
|
* AM::GetNumPrograms service function
|
2015-06-11 22:12:16 +00:00
|
|
|
* Gets the number of installed titles in the requested media type
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x00010040)
|
|
|
|
* 1 : Media type to load the titles from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : The number of titles in the requested media type
|
|
|
|
*/
|
2016-12-07 22:42:51 +00:00
|
|
|
void GetNumPrograms(Service::Interface* self);
|
2015-06-11 22:12:16 +00:00
|
|
|
|
|
|
|
/**
|
2017-11-06 18:50:53 +00:00
|
|
|
* AM::FindDLCContentInfos service function
|
|
|
|
* Explicitly checks that TID high value is 0004008C or an error is returned.
|
2016-04-08 19:44:00 +00:00
|
|
|
* Inputs:
|
|
|
|
* 1 : MediaType
|
|
|
|
* 2-3 : u64, Title ID
|
|
|
|
* 4 : Content count
|
|
|
|
* 6 : Content IDs pointer
|
|
|
|
* 8 : Content Infos pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
2017-11-06 18:50:53 +00:00
|
|
|
void FindDLCContentInfos(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
2017-11-06 19:04:12 +00:00
|
|
|
* AM::ListDLCContentInfos service function
|
|
|
|
* Explicitly checks that TID high value is 0004008C or an error is returned.
|
2016-04-08 19:44:00 +00:00
|
|
|
* Inputs:
|
|
|
|
* 1 : Content count
|
|
|
|
* 2 : MediaType
|
|
|
|
* 3-4 : u64, Title ID
|
|
|
|
* 5 : Start Index
|
|
|
|
* 7 : Content Infos pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Number of content infos returned
|
|
|
|
*/
|
2017-11-06 19:04:12 +00:00
|
|
|
void ListDLCContentInfos(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::DeleteContents service function
|
|
|
|
* Inputs:
|
|
|
|
* 1 : MediaType
|
|
|
|
* 2-3 : u64, Title ID
|
|
|
|
* 4 : Content count
|
|
|
|
* 6 : Content IDs pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void DeleteContents(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
2016-12-07 22:42:51 +00:00
|
|
|
* AM::GetProgramList service function
|
2015-06-11 22:12:16 +00:00
|
|
|
* Loads information about the desired number of titles from the desired media type into an array
|
|
|
|
* Inputs:
|
2016-04-08 19:44:00 +00:00
|
|
|
* 1 : Title count
|
2015-06-11 22:12:16 +00:00
|
|
|
* 2 : Media type to load the titles from
|
2016-04-08 19:44:00 +00:00
|
|
|
* 4 : Title IDs output pointer
|
2015-06-11 22:12:16 +00:00
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : The number of titles loaded from the requested media type
|
|
|
|
*/
|
2016-12-07 22:42:51 +00:00
|
|
|
void GetProgramList(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
2016-12-07 22:42:51 +00:00
|
|
|
* AM::GetProgramInfos service function
|
2016-04-08 19:44:00 +00:00
|
|
|
* Inputs:
|
|
|
|
* 1 : u8 Mediatype
|
|
|
|
* 2 : Total titles
|
|
|
|
* 4 : TitleIDList pointer
|
|
|
|
* 6 : TitleList pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
2016-12-07 22:42:51 +00:00
|
|
|
void GetProgramInfos(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
2017-10-25 17:41:07 +00:00
|
|
|
* AM::GetDLCTitleInfos service function
|
|
|
|
* Wrapper for AM::GetProgramInfos, explicitly checks that TID high value is 0004008C.
|
2016-04-08 19:44:00 +00:00
|
|
|
* Inputs:
|
|
|
|
* 1 : u8 Mediatype
|
|
|
|
* 2 : Total titles
|
|
|
|
* 4 : TitleIDList pointer
|
|
|
|
* 6 : TitleList pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
2017-10-25 17:41:07 +00:00
|
|
|
void GetDLCTitleInfos(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetPatchTitleInfos service function
|
|
|
|
* Wrapper for AM::GetProgramInfos, explicitly checks that TID high value is 0004000E.
|
|
|
|
* Inputs:
|
|
|
|
* 1 : u8 Mediatype
|
|
|
|
* 2 : Total titles
|
|
|
|
* 4 : TitleIDList input pointer
|
|
|
|
* 6 : TitleList output pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : TitleIDList input pointer
|
|
|
|
* 4 : TitleList output pointer
|
|
|
|
*/
|
|
|
|
void GetPatchTitleInfos(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::ListDataTitleTicketInfos service function
|
|
|
|
* Inputs:
|
|
|
|
* 1 : Ticket count
|
|
|
|
* 2-3 : u64, Title ID
|
|
|
|
* 4 : Start Index?
|
|
|
|
* 5 : (TicketCount * 24) << 8 | 0x4
|
|
|
|
* 6 : Ticket Infos pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Number of ticket infos returned
|
|
|
|
*/
|
|
|
|
void ListDataTitleTicketInfos(Service::Interface* self);
|
2015-06-11 22:12:16 +00:00
|
|
|
|
2015-07-21 05:12:13 +00:00
|
|
|
/**
|
2017-11-07 00:49:39 +00:00
|
|
|
* AM::GetDLCContentInfoCount service function
|
|
|
|
* Explicitly checks that TID high value is 0004008C or an error is returned.
|
2015-07-21 05:12:13 +00:00
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x100100C0)
|
2016-04-08 19:44:00 +00:00
|
|
|
* 1 : MediaType
|
|
|
|
* 2-3 : u64, Title ID
|
2015-07-21 05:12:13 +00:00
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Number of content infos plus one
|
|
|
|
*/
|
2017-11-07 00:49:39 +00:00
|
|
|
void GetDLCContentInfoCount(Service::Interface* self);
|
2015-07-21 05:12:13 +00:00
|
|
|
|
2016-04-08 19:44:00 +00:00
|
|
|
/**
|
|
|
|
* AM::DeleteTicket service function
|
|
|
|
* Inputs:
|
|
|
|
* 1-2 : u64, Title ID
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void DeleteTicket(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
2016-12-07 22:42:51 +00:00
|
|
|
* AM::GetNumTickets service function
|
2016-04-08 19:44:00 +00:00
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
2016-12-07 22:42:51 +00:00
|
|
|
* 2 : Number of tickets
|
2016-04-08 19:44:00 +00:00
|
|
|
*/
|
2016-12-07 22:42:51 +00:00
|
|
|
void GetNumTickets(Service::Interface* self);
|
2016-04-08 19:44:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetTicketList service function
|
|
|
|
* Inputs:
|
|
|
|
* 1 : Number of TicketList
|
|
|
|
* 2 : Number to skip
|
|
|
|
* 4 : TicketList pointer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Total TicketList
|
|
|
|
*/
|
|
|
|
void GetTicketList(Service::Interface* self);
|
|
|
|
|
2017-10-05 22:22:15 +00:00
|
|
|
/**
|
|
|
|
* AM::QueryAvailableTitleDatabase service function
|
|
|
|
* Inputs:
|
|
|
|
* 1 : Media Type
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Boolean, database availability
|
|
|
|
*/
|
|
|
|
void QueryAvailableTitleDatabase(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::CheckContentRights service function
|
|
|
|
* Inputs:
|
|
|
|
* 1-2 : Title ID
|
|
|
|
* 3 : Content Index
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Boolean, whether we have rights to this content
|
|
|
|
*/
|
|
|
|
void CheckContentRights(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::CheckContentRightsIgnorePlatform service function
|
|
|
|
* Inputs:
|
|
|
|
* 1-2 : Title ID
|
|
|
|
* 3 : Content Index
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Boolean, whether we have rights to this content
|
|
|
|
*/
|
|
|
|
void CheckContentRightsIgnorePlatform(Service::Interface* self);
|
|
|
|
|
2017-10-21 23:28:13 +00:00
|
|
|
/**
|
|
|
|
* AM::BeginImportProgram service function
|
|
|
|
* Begin importing from a CTR Installable Archive
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04020040)
|
|
|
|
* 1 : Media type to install title to
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2-3 : CIAFile handle for application to write to
|
|
|
|
*/
|
|
|
|
void BeginImportProgram(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::EndImportProgram service function
|
|
|
|
* Finish importing from a CTR Installable Archive
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04050002)
|
|
|
|
* 1-2 : CIAFile handle application wrote to
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void EndImportProgram(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetProgramInfoFromCia service function
|
|
|
|
* Get TitleInfo from a CIA file handle
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04080042)
|
|
|
|
* 1 : Media type of the title
|
|
|
|
* 2-3 : File handle CIA data can be read from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2-8: TitleInfo structure
|
|
|
|
*/
|
|
|
|
void GetProgramInfoFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetSystemMenuDataFromCia service function
|
|
|
|
* Loads a CIA file's SMDH data into a specified buffer
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04090004)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* 3-4 : Output buffer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void GetSystemMenuDataFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetDependencyListFromCia service function
|
|
|
|
* Loads a CIA's dependency list into a specified buffer
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x040A0002)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* 64-65 : Output buffer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void GetDependencyListFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetTransferSizeFromCia service function
|
|
|
|
* Returns the total expected transfer size up to the CIA meta offset from a CIA
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x040B0002)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2-3 : Transfer size
|
|
|
|
*/
|
|
|
|
void GetTransferSizeFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetCoreVersionFromCia service function
|
|
|
|
* Returns the core version from a CIA
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x040C0002)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Core version
|
|
|
|
*/
|
|
|
|
void GetCoreVersionFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetRequiredSizeFromCia service function
|
|
|
|
* Returns the required amount of free space required to install a given CIA file
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x040D0042)
|
|
|
|
* 1 : Media type to install title to
|
|
|
|
* 2-3 : File handle CIA data can be read from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2-3 : Required free space for CIA
|
|
|
|
*/
|
|
|
|
void GetRequiredSizeFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetMetaSizeFromCia service function
|
|
|
|
* Returns the size of a given CIA's meta section
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04130002)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
* 2 : Meta section size
|
|
|
|
*/
|
|
|
|
void GetMetaSizeFromCia(Service::Interface* self);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AM::GetMetaDataFromCia service function
|
|
|
|
* Loads meta section data from a CIA file into a given buffer
|
|
|
|
* Inputs:
|
|
|
|
* 0 : Command header (0x04140044)
|
|
|
|
* 1-2 : File handle CIA data can be read from
|
|
|
|
* 3-4 : Output buffer
|
|
|
|
* Outputs:
|
|
|
|
* 1 : Result, 0 on success, otherwise error code
|
|
|
|
*/
|
|
|
|
void GetMetaDataFromCia(Service::Interface* self);
|
|
|
|
|
2015-06-11 22:12:16 +00:00
|
|
|
/// Initialize AM service
|
|
|
|
void Init();
|
|
|
|
|
|
|
|
/// Shutdown AM service
|
|
|
|
void Shutdown();
|
|
|
|
|
|
|
|
} // namespace AM
|
|
|
|
} // namespace Service
|