Getting started with PSn00bSDK
October 11, 2022 ยท View on GitHub
Installing a prebuilt release (recommended)
-
Install prerequisites. Currently CMake is the only external dependency; you can install it from here or using MSys2 or your distro's package manager. Make sure you have at least CMake 3.21.
-
Head over to the releases page, download the latest release's ZIP for your operating system and extract its contents to a directory of your choice, preferably one whose absolute path is short (such as
C:\PSn00bSDKor/opt/psn00bsdk). Proceed to add thebinsubdirectory you extracted (e.g.C:\PSn00bSDK\binor/opt/psn00bsdk/bin) to yourPATHenvironment variable, through System Properties on Windows or by modifying your profile script on Linux. -
You may optionally set the
PSN00BSDK_LIBSenvironment variable to point to thelib/libpsn00bsubdirectory (again, the full path would be something likeC:\PSn00bSDK\lib\libpsn00bor/opt/psn00bsdk/lib/libpsn00b). Doing so is highly recommended as it will save you from having to hardcode a path to the SDK in your projects later on. -
You should now be able to invoke the compiler (
mipsel-none-elf-gcc) as well as PSn00bSDK commands such aself2xandmkpsxiso. If you get "command not found" errors try rebooting, otherwise you can skip to Creating a project.
Building from source
The instructions below are for Windows and Linux. Building on macOS hasn't been tested extensively yet, however it should work once the GCC toolchain is built and installed properly.
IMPORTANT: due to a bug in libflac (used by mkpsxiso), building using
MinGW on Windows currently requires -DMKPSXISO_NO_LIBFLAC=ON to be passed to
CMake when configuring PSn00bSDK. This will result in the dumpsxiso utility
being built without support for ripping CD audio tracks to FLAC, however the
mkpsxiso command will still retain FLAC support.
-
Install prerequisites and a host compiler toolchain. On Linux (most distros) install the following packages from your distro's package manager:
gitbuild-essential,base-develor similarmakeorninja-buildcmake(3.21 or later is required, download it from here if your package manager only provides older versions)
On Windows you can obtain these dependencies by installing MSys2, opening the "MSys2 MSYS" shell and running:
pacman -Syu git mingw-w64-x86_64-make mingw-w64-x86_64-ninja mingw-w64-x86_64-cmake mingw-w64-x86_64-gccIf you are prompted to close the shell, you may have to reopen it afterwards and rerun the command to finish installation. Do not use the MSys2 shell for the next steps, use a regular command prompt or PowerShell instead.
Add these directories (replace
C:\msys64if you installed MSys2 to a different location) to thePATHenvironment variable using System Properties:C:\msys64\mingw64\binC:\msys64\usr\bin
-
Download a precompiled copy of the GCC toolchain for
mipsel-none-elffrom the releases page and extract it into one of the directories listed in step 3. If you want to build the toolchain yourself, see toolchain.md.NOTE: PSn00bSDK is also compatible with toolchains that target
mipsel-unknown-elf. If you already have such a toolchain, you can use it by passing-DPSN00BSDK_TARGET=mipsel-unknown-elfto CMake when configuring the SDK (see step 5). -
If you chose a non-standard install location for the toolchain, add the
binsubfolder (inside the top-level toolchain directory) to thePATHenvironment variable. This step is unnecessary if you installed/extracted the toolchain into any of these directories:C:\Program Files\mipsel-none-elfC:\Program Files (x86)\mipsel-none-elfC:\mipsel-none-elf/usr/local/mipsel-none-elf/usr/mipsel-none-elf/opt/mipsel-none-elf
-
Clone the PSn00bSDK repo, then run the following command from the PSn00bSDK repository to download additional dependencies:
git submodule update --init --recursive -
Compile the libraries, tools and examples using CMake:
cmake --preset default . cmake --build ./buildIf you want to install the SDK to a custom location rather than the default one (
C:\Program Files\PSn00bSDKor/usr/localdepending on your OS), add--install-prefix <location>to the first command. Remember to add-DPSN00BSDK_TARGET=mipsel-unknown-elfif necessary.NOTE: Ninja is used by default to build the SDK. If you can't get it to work or don't have it installed, pass
-G "Unix Makefiles"(or-G "MinGW Makefiles"on Windows) to the first command to build usingmakeinstead. -
Install the SDK to the path you chose (add
sudoor run it from a command prompt with admin privileges if necessary):cmake --install ./buildThis will create and populate the following subfolders in the installation directory:
binlib/libpsn00bshare/psn00bsdk
-
You may optionally set the
PSN00BSDK_LIBSenvironment variable to point to thelib/libpsn00bsubfolder inside the install directory. Doing so is highly recommended as it will save you from having to hardcode a path to the SDK in your projects later on. You might also want to add thebinfolder toPATHif it's not listed already.
Although not strictly required, you'll probably want to install a PS1 emulator with debugging capabilities such as no$psx (Windows only), DuckStation or pcsx-redux. Avoid ePSXe and anything based on MAME as they are inaccurate.
Building installer packages
CPack can be used to build NSIS-based installers, DEB/RPM packages and zipped releases that include built SDK libraries, headers as well as the GCC toolchain. Distributing prebuilt releases is however discouraged since PSn00bSDK is still far from being feature-complete.
-
Follow steps 1-4 above to set up the toolchain, then install NSIS on Windows or
dpkgandrpmon Linux. -
Run the following commands from the PSn00bSDK directory (pass the appropriate options to the first command if necessary):
cmake --preset package . cmake --build ./build -t packageAll built packages will be copied to the
build/packagesfolder.
Creating a project
-
Copy the contents of
share/psn00bsdk/templatewithin the PSn00bSDK installation directory (or thetemplatefolder within the repo) to a new empty folder, which will become your project's root directory. -
If you haven't set the
PSN00BSDK_LIBSenvironment variable previously or if you want to use a different PSn00bSDK installation for the project, editCMakePresets.jsonto set the path you installed the SDK to. See the setup guide for details. -
Configure and build the template by running:
cmake --preset default . cmake --build ./buildIf you did everything correctly there should be a
template.binCD image in thebuildfolder. Test it in an emulator to ensure it works.
The toolchain script defines a few CMake macros to create PS1 executables, DLLs and CD images. See the reference for details.
Last updated on 2022-10-11 by spicyjpeg