Skip to main content

Library to calculate the IPL3 checksum for N64 ROMs

Project description

ipl3checksum PyPI - Downloads GitHub License GitHub release (latest SemVer) PyPI GitHub contributors

A Python library to calculate the IPL3 checksum for N64 ROMs.

How to use it?

First you need to install the library, one way of doing it is via pip.

python3 -m pip install -U ipl3checksum

Now you can invoke the library from your script.

romBytes = # A big endian bytes-like object
cickind = ipl3checksum.CICKind.CIC_6102_7101

checksum = ipl3checksum.calculateChecksum(romBytes, cickind)
assert checksum is not None # Not able to compute the checksum, probably because rom was too small

print(f"{checksum[0]:08X}")
print(f"{checksum[1]:08X}")

This library also contains a CIC detector:

cickind = ipl3checksum.detectCIC(romBytes)
print(cickind) # Either a `ipl3checksum.CICKind` or None if was not able to detect the CIC

Where does this come from?

This algorithm comes directly from the IPL3, which each variant is part of the first 0x1000 bytes of the rom of every retail N64 ROM.

There are various implementations floating around on the internet, but for this specific one was reverse-engineered by myself. I made this because I couldn't find a library to calculate this checksum, so I decided to reverse-engineer it myself instead of taking somebody else's work. It also was an interesting learning experience.

Note about licensing

Most of the repository is licensed under the MIT license, but I also made a reference implementation that is part of the public domain (licensed under CC0-1.0), feel free to use it however you prefer (acknowledgment is always appreciated, but not required).

I want to learn more! What is an IPL3? What is CIC?

I'm not really the guy that can answer all your hunger for knowledge, but here are a few links that may be helpful:

References

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ipl3checksum-1.0.0.tar.gz (6.3 MB view details)

Uploaded Source

Built Distribution

ipl3checksum-1.0.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file ipl3checksum-1.0.0.tar.gz.

File metadata

  • Download URL: ipl3checksum-1.0.0.tar.gz
  • Upload date:
  • Size: 6.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for ipl3checksum-1.0.0.tar.gz
Algorithm Hash digest
SHA256 4dad785c7e5207687cc6947e8709872a79fd0dec1680d28986d8a12eddbc28f3
MD5 c76ab9a0c7ebe96edf281a9fa31e0f37
BLAKE2b-256 0af43397eb5cff56e3a37c3eda2a0bb81c5839f59c521a2aaf636d3fc2b58855

See more details on using hashes here.

File details

Details for the file ipl3checksum-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ipl3checksum-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for ipl3checksum-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8b521bff61713d67b40092fcb6dcd6c6e4b5b6320ed547d255ab6be0c9d68aa0
MD5 8ff0d8b1b327794c21b750da89a54fa0
BLAKE2b-256 3dfa246d3052c8d4ffc626c1d3ac79ae58a0a79af0125106e42f24679140a58e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page