TegraRcmGUI/kourou/usb_command.h
2020-12-11 12:46:53 +01:00

134 lines
3.2 KiB
C

#ifndef UCOMMAND_H
#define UCOMMAND_H
typedef unsigned char u8;
typedef unsigned short u16;
typedef unsigned int u32;
typedef unsigned long long int u64;
typedef unsigned long DWORD;
#define COMMAND 0x5543
#define BIN_PACKET 0x4249
#define EXEC_COMMAND 0x4558
#define RESPONSE 0x5245
#define DEVINFO 0x4445
#define MAX_FILE_SIZE 0x6400000 //100MB
#define SUCCESS 0
#define USB_BUFFER_LENGTH 0x1000
#define COMMAND_MAX_SIZE 0x120
#define RESPONSE_MAX_SIZE 0x20
#define FS_FAT32 3
#define FS_EXFAT 4
#define FILEBASED 2
#define RAWBASED 1
typedef enum _UC_CommandType : u8
{
NONE,
COPY,
READ_SD_FILE,
WRITE_SD_FILE,
PUSH_PAYLOAD,
REBOOT_RCM,
GET_DEVICE_INFO,
GET_STATUS,
SET_AUTORCM_ON,
SET_AUTORCM_OFF,
SIZE_SD_FILE,
ISDIR_SD,
MKDIR_SD,
MKPATH_SD,
GET_KEYS
} UC_CommandType;
typedef struct _UC_Header
{
u16 signature = COMMAND;
UC_CommandType command;
} UC_Header;
typedef struct _UC_SDIO
{
u16 signature = COMMAND;
UC_CommandType command;
char path[256];
u32 file_size;
bool is_lz4_compressed = false;
bool create_always = false;
} UC_SDIO;
typedef struct _UC_EXEC
{
u16 signature = EXEC_COMMAND;
UC_CommandType command;
u32 bin_size;
} UC_EXEC;
typedef struct _UC_INI
{
u16 signature = EXEC_COMMAND;
UC_CommandType command;
char ini_path[256];
} UC_INI;
typedef struct _UC_BlockHeader
{
u16 signature = BIN_PACKET;
u32 block_size;
u32 block_full_size; // Full size if LZ4 compressed
} UC_BlockHeader;
typedef struct _UC_DeviceInfo
{
u16 signature = DEVINFO; // UC signature
char deviceId[21]; // Console unique ID
u32 battery_capacity; // Fuel gauge
bool autoRCM; // autoRCM state
u32 burnt_fuses; // Number of burnt fuses
bool sdmmc_initialized; // MMC FS initialized
u8 mmc_fs_type; // 3 for FAT32, 4 for exFAT
u16 mmc_fs_cl_size; // Cluster size in sectors (always 512B per sectors)
DWORD mmc_fs_last_cl; // Last allocated cluster
DWORD mmc_fs_free_cl; // Number of free cluster
bool cfw_sxos; // SX OS bootloader
bool cfw_ams; // AMS fusee
bool cbl_hekate; // Hekate
bool cbl_nyx; // Nyx
u8 nyx_version[3]; // Nyx version str (major, minor, micro)
u8 ams_version[3]; // AMS version str (major, minor, micro)
char fw_version[10]; // SysNAND firmware version
bool exFat_driver; // SysNAND exFat driver
char emu_fw_version[10]; // emuNAND firmware version
bool emu_exFat_driver; // emuNAND exFat driver
bool emunand_enabled; // Is EmuNAND enabled ?
int emunand_type;
} UC_DeviceInfo;
/*--------------*/
/* ERROR CODES */
/*--------------*/
// FS
#define OPEN_FILE_FAILED -0x0001
#define FILE_TOO_LARGE -0x0002
#define PATH_TOO_LONG -0x0003
// COM
#define SEND_COMMAND_FAILED -0x1001
#define RECEIVE_COMMAND_FAILED -0x1002
#define USB_WRITE_FAILED -0x1003
#define USB_READ_FAILED -0x1004
// GENERIC
#define BAD_ARGUMENT -0x2005
#define BUFFER_TOO_SMALL -0x2006
#endif // UCOMMAND_H