From daf91851aa80818ab4dd3c6221aa9c67fd240528 Mon Sep 17 00:00:00 2001 From: bucanero Date: Thu, 14 Nov 2024 11:19:38 -0300 Subject: [PATCH 1/2] clean up --- README.md | 11 +++++++++++ source/saves.c | 46 +++++++++++++++++++++++++++++++++------------- 2 files changed, 44 insertions(+), 13 deletions(-) diff --git a/README.md b/README.md index 8e9819d..6b4556c 100644 --- a/README.md +++ b/README.md @@ -114,6 +114,17 @@ On first run, the application will detect and setup the required user settings. | **External VMCs (HDD)** | `/data/fakeusb/PS2/VMC/` | | **HDD VMC cards** | VMCs will be scanned from PS4 saves on the hard disk | +### PS1 + +| PS1 | Folder | +|-----|--------| +| **USB saves** | `/mnt/usbX/PS1/SAVEDATA/` (`*.mcs`, `*.psx`, `*.ps1`, `*.mcb`, `*.psv`, `*.pda`) | +| **VMC cards** | `/mnt/usbX/PS1/VMC/` (`*.vmc`, `*.mcd`, `*.mcr`, `*.gme`, `*.vm1`, `*.vmp`, `*.vgs`, `*.srm`, `*.bin`) | +| **PSV saves** | `/mnt/usbX/PS3/EXPORT/PSV/` | +| **External saves (HDD)** | `/data/fakeusb/PS1/SAVEDATA/` | +| **External VMCs (HDD)** | `/data/fakeusb/PS1/VMC/` | +| **HDD VMC cards** | VMCs will be scanned from PS4 saves on the hard disk | + ## Offline Account activation To activate an account offline, go to the `User Tools` menu, and select `Activate PS4 Accounts`. diff --git a/source/saves.c b/source/saves.c index aef3e0a..1368c43 100644 --- a/source/saves.c +++ b/source/saves.c @@ -559,7 +559,7 @@ static code_entry_t* _createCmdCode(uint8_t type, const char* name, char code) { code_entry_t* entry = (code_entry_t *)calloc(1, sizeof(code_entry_t)); entry->type = type; - entry->name = strdup(name); + entry->name = name ? strdup(name) : NULL; asprintf(&entry->codes, "%c", code); return entry; @@ -1004,7 +1004,7 @@ static void add_vmc_import_saves(list_t* list, const char* path, const char* fol continue; } - snprintf(psvPath, sizeof(psvPath), "%s %s", CHAR_ICON_COPY, dir->d_name); + snprintf(psvPath, sizeof(psvPath), CHAR_ICON_COPY "%c %s", CHAR_TAG_PS1, dir->d_name); cmd = _createCmdCode(PATCH_COMMAND, psvPath, CMD_IMP_VMC1SAVE); asprintf(&cmd->file, "%s%s%s", path, folder, dir->d_name); cmd->codes[1] = FILE_TYPE_PS1; @@ -1082,7 +1082,8 @@ static void add_vmc2_import_saves(list_t* list, const char* path, const char* fo DIR *d; struct dirent *dir; char psvPath[256]; - int type; + char data[64]; + int type, toff; snprintf(psvPath, sizeof(psvPath), "%s%s", path, folder); d = opendir(psvPath); @@ -1102,28 +1103,34 @@ static void add_vmc2_import_saves(list_t* list, const char* path, const char* fo if (read_file(psvPath, (uint8_t*) psvPath, 0x40) < 0 || psvPath[0x3C] != 0x02) continue; -// toff = 0x80; + toff = 0x80; type = FILE_TYPE_PSV; } else if (endsWith(dir->d_name, ".PSU")) { -// toff = 0x40; + toff = 0x40; type = FILE_TYPE_PSU; } else if (endsWith(dir->d_name, ".CBS")) + { + toff = 0x14; type = FILE_TYPE_CBS; - + } else if (endsWith(dir->d_name, ".XPS") || endsWith(dir->d_name, ".SPS")) + { + toff = 0x02; type = FILE_TYPE_XPS; - + } else if (endsWith(dir->d_name, ".MAX")) + { + toff = 0x10; type = FILE_TYPE_MAX; + } else continue; snprintf(psvPath, sizeof(psvPath), "%s%s%s", path, folder, dir->d_name); LOG("Reading %s...", psvPath); -/* FILE *fp = fopen(psvPath, "rb"); if (!fp) { LOG("Unable to open '%s'", psvPath); @@ -1132,12 +1139,11 @@ static void add_vmc2_import_saves(list_t* list, const char* path, const char* fo fseek(fp, toff, SEEK_SET); fread(data, 1, sizeof(data), fp); fclose(fp); -*/ - cmd = _createCmdCode(PATCH_COMMAND, psvPath, CMD_IMP_VMC2SAVE); + cmd = _createCmdCode(PATCH_COMMAND, NULL, CMD_IMP_VMC2SAVE); cmd->file = strdup(psvPath); cmd->codes[1] = type; - sprintf(cmd->name, "%s %s", CHAR_ICON_COPY, dir->d_name); + asprintf(&cmd->name, CHAR_ICON_COPY "%c (%.10s) %s", CHAR_TAG_PS2, data + 2, dir->d_name); list_append(list, cmd); LOG("[%s] F(%X) name '%s'", cmd->file, cmd->flags, cmd->name+2); @@ -1575,10 +1581,24 @@ int sortSaveList_Compare_TitleID(const void* a, const void* b) return (ret ? ret : sortSaveList_Compare(a, b)); } +static int parseTypeFlags(int flags) +{ + if (flags & SAVE_FLAG_PS4) + return FILE_TYPE_PS4; + else if (flags & SAVE_FLAG_PS1) + return FILE_TYPE_PS1; + else if (flags & SAVE_FLAG_PS2) + return FILE_TYPE_PS2; + else if (flags & SAVE_FLAG_VMC) + return FILE_TYPE_VMC; + + return 0; +} + int sortSaveList_Compare_Type(const void* a, const void* b) { - int ta = ((save_entry_t*) a)->type; - int tb = ((save_entry_t*) b)->type; + int ta = parseTypeFlags(((save_entry_t*) a)->flags); + int tb = parseTypeFlags(((save_entry_t*) b)->flags); if (ta == tb) return sortSaveList_Compare(a, b); From 6874a72619909f9bf7a8a4b3b49bf3061adb3f96 Mon Sep 17 00:00:00 2001 From: bucanero Date: Sat, 16 Nov 2024 08:48:38 -0300 Subject: [PATCH 2/2] changelog --- CHANGELOG.md | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8f5e217..48c8675 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,24 @@ All notable changes to the `apollo-ps4` project will be documented in this file. --- +## [v1.7.0](https://github.com/bucanero/apollo-ps4/releases/tag/v1.7.0) - 2024-11-16 + +### Added + +* Manage PS1 Virtual Memory Card images (VMC) + - Supports `.VM1` and external formats (`.MCR`, `.VMP`, `.BIN`, `.VMC`, `.GME`, `.VGS`, `.SRM`, `.MCD`) + - List, import, export, and delete PS1 saves inside VMC images + - Import - Supported formats: `.MCS`, `.PSV`, `.PSX`, `.PS1`, `.MCB`, `.PDA` + - Export - Supported formats: `.MCS`, `.PSV`, `.PSX` +* Online DB: added PS1 saves listing + +### Fixed + +* Updated Apollo Patch Engine to v1.1.2 + - Fixed SW Code search bug when bytes are not found + +--- + ## [v1.6.0](https://github.com/bucanero/apollo-ps4/releases/tag/v1.6.0) - 2024-11-02 ### Added