Skip to content

Install games in HDLoader format to APA-formatted hard drive

Notifications You must be signed in to change notification settings

ps2homebrew/hdl-dump

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hdl_dump and hdl_dumb

Contents

  • Intro
  • Networking server
  • Compilation
  • Configuration and list file location
  • Configuration
  • New features

Intro

The latest version, as well as documentation, can be found on the new official repository, https://github.com/ps2homebrew/hdl-dump/

Me reads [email protected] and psx-scene forums every now and then.(c)

Easy guide for installing games can be found here http://web.archive.org/web/20120720230755/http://openps2loader.info/hdldump/howto.html

Networking server

Update: Currently, OPL built-in NBD server is the preferred option.

Deprecated: A UDP-based network server is available, based on the SMAP driver released by @sp193 http://ichiba.geocities.jp/ysai187/PS2/smap.htm. It is called hdl_svr_093.elf and is now part of the hdl_dump sources.

Note: You might need to punch a hole in your firewall for incoming UDP from port 12345.

Compilation

First of all, you have to update your PS2SDK.

Finally: You can run the shell script in the project folder: mkrel.sh. It will compile both GUI and CLI versions for Windows.

  • Linux: Build and copy executable into a directory of your choice.

      make RELEASE=yes
    

    Advanced Linux build commands:

      make XC=win          # for Windows cross-compilation using mingw32
      make -C gui          # for WineLib compilation (currently not working)
      make -C gui XC=win   # for GUI cross-compilation using mingw32
    
  • Mac OS X or FreeBSD: You'll need to have GNU make installed, then

      gmake RELEASE=yes IIN_OPTICAL_MMAP=no
    

    or

      make RELEASE=yes IIN_OPTICAL_MMAP=no
    
  • Windows: You need to have MINGW32 installed; then use

      make RELEASE=yes
      make -C gui RELEASE=yes
    

    to compile command-line or GUI version.

Configuration and list file location

You can place these files in the folder where is installed hdl_dump for making it portable.

  • Windows:

    %APPDATA%\hdl_dump.conf %APPDATA%\hdl_dump.list

  • Linux, Mac OS X and FreeBSD: (~ is your home dir)

    ~/.hdl_dump.conf ~/.hdl_dump.list

Configuration

  • disc_database_file -- full path to your disc compatibility database file;

New features

All new stuff can be used from HDD OSD, BB Navigator, or XMB from PSX DVR.

ZSO support

hdl-dump supports zso compressed files. For using ZSO, you must keep original ISO (or cue/bin) files in the same folder and with the same name as ZSO compressed file. You should select original ISO (or cue/bin) and hdl-dump will check zso existence on installation. If ZSO file exists, it will install ZSO, if it does not exist it will install original ISO. Unfortunately, you need to keep original file for program to work.

inject_dvd, inject_cd, install or copy_hdd.

This command will install games onto the hard disk.

Warning: Be careful with copy_hdd - every HDLoader game will be given the same icon.

Optionally, you can place boot.elf (which is actually miniopl.elf) in the folder where hdl_dump is launched from. You can also optionally include list.ico (*.ico from memory card) and icon.sys (*.sys from memory card), or you can write your own icon.sys file.

If you don't include an *.ico, the HDLoader logo is used. If you don't include *.sys, the default HDLoader icon settings are used..

Note: following options aren't supported by PSX1 (PSX DESR 1st generation).

boot.elf, boot.kelf - PS2 executable file in signed or unsigned form. OPL-Launcher is a preferable option. Injection address - 0x111000. Size limit - 2,026,464 bytes (thanks to kHn)

inject_mbr

hdl_dump inject_mbr /dev/sdb MBR.KELF

When you use this command and place the hard drive into your PlayStation 2 phat, it will launch the injected MBR.KELF. This option can be used as an entry point for PS2.

All HDD data will remain intact.

MBR.KELF injection address - 0x00404000 (for compatibility with PlayStation BB Navigator)

MBR.KELF size should be a maximum of 883200 bytes and have a valid header.

modify_header

This command injects header attributes into an existing partition.

hdl_dump.exe modify_header 192.168.0.10 PP.TEST

It can inject these files:

  • system.cnf
  • icon.sys
  • list.ico
  • del.ico
  • boot.kelf
  • boot.elf
  • boot.kirx

Any one can be skipped. It first tries to inject boot.kelf, then if not found it will try to inject boot.elf.

Now icon.sys can be in any of 2 formats: Memory Card format or HDD format.

del.ico injection address: 0x041000 (If del.ico is used list.ico maximum size 260,096 bytes)

boot.elf (or boot.kelf) injection address - 0x111000

boot.elf size limit - 2,026,464 bytes (thanks to kHn)

boot.kelf size limit - 3,076,096 bytes (if boot.kirx not used)

boot.kelf size limit - 2,031,616 bytes (if boot.kirx is used)

boot.kirx injection address - 0x301000

boot.kirx size limit - 1,044,480 bytes

Hiding Games

You can hide games so that they are not visible in the HDD Browser by using the -hide switch with the install, inject_cd, inject_dvd, or modify commands. A hidden game can be made visible again using the -unhide switch with the modify command. This is a necessary option for installing the games on PSX1 (1st DESR generation).

Others

If you want to know more about these files (and their restrictions), you have to study the official SONY ps2sdk document called hdd_rule_3.0.2.pdf

There are also some undocumented features like this:

  • If you want to inject boot.kelf (or boot.elf), you have to change BOOT2 in system.cnf.

      BOOT2 = PATINFO
    

    If you need to erase boot.elf from the PATINFO you have to place zero-sized boot.kelf or elf in program folder. _Note: PSX1 (DESR 1st generation) doesn't support the PATINFO parameter.

  • If you want to launch KELF from the PFS partition you have to change BOOT2 in system.cnf

      BOOT2 = pfs:/EXECUTE.KELF
    

    where EXECUTE.KELF - is the path to KELF that is placed into the partition. Changedable.

  • If you want to inject kirx into the partition you have to add a line into system.cnf

      IOPRP = PATINFO
    

    Don't ask about kirx - I don't know where that is used. _Note: PSX1 (DESR 1st generation) doesn't support the IOPRP parameter.

  • If you don't want to boot from HDD OSD you have to add such a line into system.cnf

      BOOT2 = NOBOOT
    

Happy gaming.