2012-11-15 00:39:56 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
2016-04-14 01:09:41 +02:00
|
|
|
enum CellOk : s32
|
2012-11-15 00:39:56 +01:00
|
|
|
{
|
2016-04-14 01:09:41 +02:00
|
|
|
CELL_OK = 0,
|
|
|
|
|
};
|
2015-03-12 20:39:41 +01:00
|
|
|
|
2016-08-15 18:18:05 +02:00
|
|
|
enum CellError : u32
|
2016-04-14 01:09:41 +02:00
|
|
|
{
|
2016-08-15 18:18:05 +02:00
|
|
|
CELL_EAGAIN = 0x80010001, // The resource is temporarily unavailable
|
|
|
|
|
CELL_EINVAL = 0x80010002, // An invalid argument value is specified
|
|
|
|
|
CELL_ENOSYS = 0x80010003, // The feature is not yet implemented
|
|
|
|
|
CELL_ENOMEM = 0x80010004, // Memory allocation failure
|
|
|
|
|
CELL_ESRCH = 0x80010005, // The resource with the specified identifier does not exist
|
|
|
|
|
CELL_ENOENT = 0x80010006, // The file does not exist
|
|
|
|
|
CELL_ENOEXEC = 0x80010007, // The file is in unrecognized format
|
|
|
|
|
CELL_EDEADLK = 0x80010008, // Resource deadlock is avoided
|
|
|
|
|
CELL_EPERM = 0x80010009, // The operation is not permitted
|
|
|
|
|
CELL_EBUSY = 0x8001000A, // The device or resource is busy
|
|
|
|
|
CELL_ETIMEDOUT = 0x8001000B, // The operation is timed out
|
|
|
|
|
CELL_EABORT = 0x8001000C, // The operation is aborted
|
|
|
|
|
CELL_EFAULT = 0x8001000D, // Invalid memory access
|
|
|
|
|
CELL_ESTAT = 0x8001000F, // State of the target thread is invalid
|
|
|
|
|
CELL_EALIGN = 0x80010010, // Alignment is invalid.
|
|
|
|
|
CELL_EKRESOURCE = 0x80010011, // Shortage of the kernel resources
|
|
|
|
|
CELL_EISDIR = 0x80010012, // The file is a directory
|
|
|
|
|
CELL_ECANCELED = 0x80010013, // Operation canceled
|
|
|
|
|
CELL_EEXIST = 0x80010014, // Entry already exists
|
|
|
|
|
CELL_EISCONN = 0x80010015, // Port is already connected
|
|
|
|
|
CELL_ENOTCONN = 0x80010016, // Port is not connected
|
|
|
|
|
CELL_EAUTHFAIL = 0x80010017, // Program authentication fail
|
|
|
|
|
CELL_ENOTMSELF = 0x80010018, // The file is not a MSELF
|
|
|
|
|
CELL_ESYSVER = 0x80010019, // System version error
|
|
|
|
|
CELL_EAUTHFATAL = 0x8001001A, // Fatal system error
|
|
|
|
|
CELL_EDOM = 0x8001001B,
|
|
|
|
|
CELL_ERANGE = 0x8001001C,
|
|
|
|
|
CELL_EILSEQ = 0x8001001D,
|
|
|
|
|
CELL_EFPOS = 0x8001001E,
|
|
|
|
|
CELL_EINTR = 0x8001001F,
|
|
|
|
|
CELL_EFBIG = 0x80010020,
|
|
|
|
|
CELL_EMLINK = 0x80010021,
|
|
|
|
|
CELL_ENFILE = 0x80010022,
|
|
|
|
|
CELL_ENOSPC = 0x80010023,
|
|
|
|
|
CELL_ENOTTY = 0x80010024,
|
|
|
|
|
CELL_EPIPE = 0x80010025,
|
|
|
|
|
CELL_EROFS = 0x80010026,
|
|
|
|
|
CELL_ESPIPE = 0x80010027,
|
|
|
|
|
CELL_E2BIG = 0x80010028,
|
|
|
|
|
CELL_EACCES = 0x80010029,
|
|
|
|
|
CELL_EBADF = 0x8001002A,
|
|
|
|
|
CELL_EIO = 0x8001002B,
|
|
|
|
|
CELL_EMFILE = 0x8001002C,
|
|
|
|
|
CELL_ENODEV = 0x8001002D,
|
|
|
|
|
CELL_ENOTDIR = 0x8001002E,
|
|
|
|
|
CELL_ENXIO = 0x8001002F,
|
|
|
|
|
CELL_EXDEV = 0x80010030,
|
|
|
|
|
CELL_EBADMSG = 0x80010031,
|
|
|
|
|
CELL_EINPROGRESS = 0x80010032,
|
|
|
|
|
CELL_EMSGSIZE = 0x80010033,
|
|
|
|
|
CELL_ENAMETOOLONG = 0x80010034,
|
|
|
|
|
CELL_ENOLCK = 0x80010035,
|
|
|
|
|
CELL_ENOTEMPTY = 0x80010036,
|
|
|
|
|
CELL_ENOTSUP = 0x80010037,
|
|
|
|
|
CELL_EFSSPECIFIC = 0x80010038,
|
|
|
|
|
CELL_EOVERFLOW = 0x80010039,
|
|
|
|
|
CELL_ENOTMOUNTED = 0x8001003A,
|
|
|
|
|
CELL_ENOTSDATA = 0x8001003B,
|
2016-04-14 01:09:41 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Special return type signaling on errors
|
|
|
|
|
struct ppu_error_code
|
|
|
|
|
{
|
|
|
|
|
s32 value;
|
|
|
|
|
|
|
|
|
|
// Print error message, error code is returned
|
|
|
|
|
static s32 report(s32 error, const char* text);
|
|
|
|
|
|
|
|
|
|
// Must be specialized for specific tag type T
|
|
|
|
|
template<typename T>
|
|
|
|
|
static const char* print(T code)
|
|
|
|
|
{
|
|
|
|
|
return nullptr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
s32 error_check(T code)
|
|
|
|
|
{
|
|
|
|
|
if (const auto text = print(code))
|
|
|
|
|
{
|
|
|
|
|
return report(code, text);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return code;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ppu_error_code() = default;
|
|
|
|
|
|
|
|
|
|
// General error check
|
|
|
|
|
template<typename T, typename = std::enable_if_t<std::is_enum<T>::value>>
|
|
|
|
|
ppu_error_code(T value)
|
|
|
|
|
: value(error_check(value))
|
|
|
|
|
{
|
|
|
|
|
}
|
2012-11-15 00:39:56 +01:00
|
|
|
|
2016-04-14 01:09:41 +02:00
|
|
|
// Force error reporting with a message specified
|
|
|
|
|
ppu_error_code(s32 value, const char* text)
|
|
|
|
|
: value(report(value, text))
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Silence any error
|
2016-08-15 17:30:33 +02:00
|
|
|
constexpr ppu_error_code(not_an_error_t value)
|
2016-05-13 15:55:34 +02:00
|
|
|
: value(static_cast<s32>(value))
|
2016-04-14 01:09:41 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Conversion
|
|
|
|
|
constexpr operator s32() const
|
|
|
|
|
{
|
|
|
|
|
return value;
|
|
|
|
|
}
|
2015-03-12 20:39:41 +01:00
|
|
|
};
|
2016-04-14 01:09:41 +02:00
|
|
|
|
|
|
|
|
template<typename T, typename>
|
|
|
|
|
struct ppu_gpr_cast_impl;
|
|
|
|
|
|
|
|
|
|
template<>
|
|
|
|
|
struct ppu_gpr_cast_impl<ppu_error_code, void>
|
|
|
|
|
{
|
|
|
|
|
static inline u64 to(const ppu_error_code& code)
|
|
|
|
|
{
|
|
|
|
|
return code;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline ppu_error_code from(const u64 reg)
|
|
|
|
|
{
|
2016-08-15 17:30:33 +02:00
|
|
|
return not_an_error(reg);
|
2016-04-14 01:09:41 +02:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template<>
|
|
|
|
|
inline const char* ppu_error_code::print(CellError error)
|
|
|
|
|
{
|
|
|
|
|
switch (error)
|
|
|
|
|
{
|
|
|
|
|
STR_CASE(CELL_EAGAIN);
|
|
|
|
|
STR_CASE(CELL_EINVAL);
|
|
|
|
|
STR_CASE(CELL_ENOSYS);
|
|
|
|
|
STR_CASE(CELL_ENOMEM);
|
|
|
|
|
STR_CASE(CELL_ESRCH);
|
|
|
|
|
STR_CASE(CELL_ENOENT);
|
|
|
|
|
STR_CASE(CELL_ENOEXEC);
|
|
|
|
|
STR_CASE(CELL_EDEADLK);
|
|
|
|
|
STR_CASE(CELL_EPERM);
|
|
|
|
|
STR_CASE(CELL_EBUSY);
|
|
|
|
|
STR_CASE(CELL_ETIMEDOUT);
|
|
|
|
|
STR_CASE(CELL_EABORT);
|
|
|
|
|
STR_CASE(CELL_EFAULT);
|
|
|
|
|
STR_CASE(CELL_ESTAT);
|
|
|
|
|
STR_CASE(CELL_EALIGN);
|
|
|
|
|
STR_CASE(CELL_EKRESOURCE);
|
|
|
|
|
STR_CASE(CELL_EISDIR);
|
|
|
|
|
STR_CASE(CELL_ECANCELED);
|
|
|
|
|
STR_CASE(CELL_EEXIST);
|
|
|
|
|
STR_CASE(CELL_EISCONN);
|
|
|
|
|
STR_CASE(CELL_ENOTCONN);
|
|
|
|
|
STR_CASE(CELL_EAUTHFAIL);
|
|
|
|
|
STR_CASE(CELL_ENOTMSELF);
|
|
|
|
|
STR_CASE(CELL_ESYSVER);
|
|
|
|
|
STR_CASE(CELL_EAUTHFATAL);
|
|
|
|
|
STR_CASE(CELL_EDOM);
|
|
|
|
|
STR_CASE(CELL_ERANGE);
|
|
|
|
|
STR_CASE(CELL_EILSEQ);
|
|
|
|
|
STR_CASE(CELL_EFPOS);
|
|
|
|
|
STR_CASE(CELL_EINTR);
|
|
|
|
|
STR_CASE(CELL_EFBIG);
|
|
|
|
|
STR_CASE(CELL_EMLINK);
|
|
|
|
|
STR_CASE(CELL_ENFILE);
|
|
|
|
|
STR_CASE(CELL_ENOSPC);
|
|
|
|
|
STR_CASE(CELL_ENOTTY);
|
|
|
|
|
STR_CASE(CELL_EPIPE);
|
|
|
|
|
STR_CASE(CELL_EROFS);
|
|
|
|
|
STR_CASE(CELL_ESPIPE);
|
|
|
|
|
STR_CASE(CELL_E2BIG);
|
|
|
|
|
STR_CASE(CELL_EACCES);
|
|
|
|
|
STR_CASE(CELL_EBADF);
|
|
|
|
|
STR_CASE(CELL_EIO);
|
|
|
|
|
STR_CASE(CELL_EMFILE);
|
|
|
|
|
STR_CASE(CELL_ENODEV);
|
|
|
|
|
STR_CASE(CELL_ENOTDIR);
|
|
|
|
|
STR_CASE(CELL_ENXIO);
|
|
|
|
|
STR_CASE(CELL_EXDEV);
|
|
|
|
|
STR_CASE(CELL_EBADMSG);
|
|
|
|
|
STR_CASE(CELL_EINPROGRESS);
|
|
|
|
|
STR_CASE(CELL_EMSGSIZE);
|
|
|
|
|
STR_CASE(CELL_ENAMETOOLONG);
|
|
|
|
|
STR_CASE(CELL_ENOLCK);
|
|
|
|
|
STR_CASE(CELL_ENOTEMPTY);
|
|
|
|
|
STR_CASE(CELL_ENOTSUP);
|
|
|
|
|
STR_CASE(CELL_EFSSPECIFIC);
|
|
|
|
|
STR_CASE(CELL_EOVERFLOW);
|
|
|
|
|
STR_CASE(CELL_ENOTMOUNTED);
|
|
|
|
|
STR_CASE(CELL_ENOTSDATA);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
|
}
|