firestarter


Namefirestarter JSON
Version 2.0.6 PyPI version JSON
download
home_pageNone
SummaryEPROM programmer software for the Relatively Universal ROM Programmer
upload_time2025-07-19 11:50:27
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseNone
keywords firestarter eprom rom eeprom flash programmer arduino electronics retro computing retro game console commodore atari apple c64 nes
VCS
bugtrack_url
requirements argparse pyserial requests tqdm argcomplete rich
Travis-CI No Travis.
coveralls test coverage No coveralls.
            
<p align="center"><img src="https://github.com/henols/firestarter_app/blob/main/images/firestarter_logo.png" alt="Firestarter EPROM Programmer" width="200"></p>

----

# Firestarter

[![PyPI version](https://badge.fury.io/py/firestarter.svg)](https://badge.fury.io/py/firestarter)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/E1E21I2WWW)

---

Firestarter is an application for the [Relatively-Universal-ROM-Programmer](https://github.com/AndersBNielsen/Relatively-Universal-ROM-Programmer) RURP Arduino shield ([Get one here](https://www.imania.dk/samlesaet-hobbyelektronik-og-ic-er-relatively-universal-rom-programmer.htm).

The Firestarter Firmware can be found here [Firestarter](https://github.com/henols/firestarter).

Firestarter in action [watch the video](https://youtu.be/JDHOKbyNnrE?si=0_iXKPZZwyyNGUTZ).

Anders S Nielsen creator of the Relatively-Universal-ROM-Programmer talks about Firestarter [watch the video](https://youtu.be/SZQ50XZlk5o?si=IKOqQUeG4Rms1cUs).

Support and discussions forum at [Discord](https://discord.com/invite/kmhbxAjQc3).

## Table of Content
- [Installation](#Installation)
  - [Installing the Firestarter Python Program](#installing-the-firestarter-python-program)
  - [Installing the Firmware on the Arduino](#installing-the-firmware-on-the-arduino)
- [Usage](#usage)
  - [General Usage](#general-usage)
  - [Commands](#commands)
    - [Read](#read)
    - [Write](#write)
    - [Blank](#blank)
    - [Erase](#erase)
    - [Id](#id)
    - [Info](#info)
    - [Vpp](#vpp)
    - [Vpe](#vpe)
    - [Hw](#hardware)
    - [Fw](#firmware)
    - [Config](#configuration)

- [Examples](#examples)
  - [Read](#read-1)
  - [Write](#write-1)
  - [Info](#info-1)
- [Override and adding to the database](#override-and-adding-to-the-database)
  - [Eprom Configuration](#eprom-configuration)
  - [Pin Layout](#pin-layout)
  - [Contributing to the database](#contributing-to-the-database)
- [Handling EPROMs with Non-Standard Pin Layout (Adapters)](#handling-eproms-with-non-standard-pin-layout-adapters)
  - [Configuration Steps](#configuration-steps)
  - [Using the Adapter Configuration](#using-the-adapter-configuration)
- [Contributing](#contributing)
- [License](#license)
- [Support me](#support-me)


## Installation
To install the Firestarter Python program and the firmware on the Arduino, follow the steps below:

### Installing the Firestarter Python Program
Use the package manager [pip](https://pip.pypa.io/en/stable/) to install Firestarter.

``` bash
pip install firestarter 
```

This command installs the Firestarter application, which allows you to interact with EPROMs using the Relatively-Universal-ROM-Programmer.

#### Auto complete
How to enable auto complete for firestarter, see: [auto complete](autocomplete.md)

### Installing the Firmware on the Arduino

First, a few things to remember. 
1. Don't attach the Programmer shield while power is on.
2. Don't turn on power if the controller (Arduino) isn't programmed with appropriate firmware.
3. Don't insert a ROM in the socket until you're ready to write it. Don't leave a ROM in the socket during reset or programming.

To install the firmware on the Arduino, use the **fw** command with the `--install` option. This command installs the latest firmware version on the Arduino.

Firestarter is using **avrdude** to install the firmware.
**avrdude** is avalible as a separate [installer](https://github.com/avrdudes/avrdude) or via Arduino IDE.

#### Options
* `-p, --avrdude-path <path>`: Full path to avrdude (optional), set if avrdude is not found.
* `-c, --avrdude-config-path <path>`: Full path to avrdude config file (optional), may be needed if avrdude cannot find its default configuration (e.g., with older versions like 6.3 or non-standard installations).
* `--port <port>`: Serial port name (optional), set if the Arduino is not found.
* `-b, --board <board>`: Microcontroller board (optional), defaults to *uno*, other supported boards *leonardo*.
* `-f, --force`: Will install firmware even if the version is the same.
### Description
The `fw --install` command installs the latest firmware on the Arduino. The process typically involves the following steps:

1. **Locate avrdude**: The command locates the avrdude tool, which is used to upload the firmware to the Arduino. You can specify the path to `avrdude` using the `--avrdude-path` option if it is not found automatically.
2. **Identify Serial Port**: The command identifies the serial port to which the Arduino is connected. You can specify the port using the `--port` option.
3. **Upload Firmware**: The command uploads the latest firmware to the Arduino using `avrdude`.

### Example
To install the firmware on the **Arduino UNO**, you can run:
``` bash
firestarter fw --install
```

To install the firmware on the **Arduino Leonardo**, you can run:
``` bash
firestarter fw --install --board leonardo
```


## Usage
Firestarter provides several commands to interact with EPROMs using the Relatively-Universal-ROM-Programmer.
Available commands: read, write, blank, erase, list, search, info, vpp, vcc, fw, config

### General Usage

``` bash
firestarter [options] {command}
```
  * `-h, --help`: Show help message
  * `-v, --verbose`: Enable verbose mode
  * `--version`: Show the Firestarter version and exit.

### Commands

#### Read
Reads the content from an EPROM.
``` bash
firestarter read <eprom> [output_file]
```
* `<eprom>`: The name of the EPROM.
* `[output_file]`: (Optional) Output file name, defaults to `<EPROM_NAME>.bin`.
##### Description
The read command reads the data from the specified EPROM and optionally saves it to a file. The process typically involves the following steps:

1. **Identify EPROM:** The command identifies the specified EPROM.
2. **Read Data:** The data from the EPROM is read.
3. **Save Data:** If an output file is specified, the read data is saved to that file. If no output file is specified, the data is saved to a file named `<EPROM_NAME>.bin`.

#### Write
Writes a binary file to an EPROM.
``` bash
firestarter write <eprom> <input_file> [options]
```
* `<eprom>`: The name of the EPROM.
* `<input_file>`: Input file name.
##### Options
* `-b, --ignore-blank-check`: Ignore blank check before write (and skip erase).
* `-f, --force`: Force write, even if the VPP or chip ID don't match.
* `-a, --address <address>`: Write start address in decimal or hexadecimal.
##### Description
The write command writes the contents of a specified binary file to the EPROM. The process typically involves the following steps:

1. **Blank Check:** By default, the command checks if the EPROM is blank before writing. This can be skipped using the `--ignore-blank-check` option.
2. **Erase:** If the EPROM is not blank, it may need to be erased before writing. This step is also skipped if `--ignore-blank-check` is used.
3. **Write:** The binary data from the input file is written to the EPROM starting at the specified address (if provided).
4. **Verification:** The written data is verified to ensure it matches the input file.

#### Blank 
Checks if an EPROM is blank.
``` bash
firestarter blank <eprom>
```

* `<eprom>`: The name of the EPROM.

#### Erase
Erases an EPROM, if supported.
``` bash
firestarter erase <eprom>
```
* `<eprom>`: The name of the EPROM.
#### List
Lists all EPROMs in the database.
``` bash
firestarter list [options]
```

* `-v, --verified`: Only shows verified EPROMs.

#### Search
Searches for EPROMs in the database.
``` bash
firestarter search <text>
```

* `<text>`: Text to search for.

#### Info
Displays information about an EPROM.
``` bash
firestarter info <eprom>
```

* `<eprom>`: EPROM name.
##### Options
* `-c, --config`: Show EPROM configuration data in JSON format.

##### Description
The info command retrieves and displays detailed information about the specified EPROM. This information typically includes:

* EPROM name
* Manufacturer
* Device ID
* Memory size
* Supported voltages
* Pin configuration
* Any other relevant technical specifications

#### VPP
Displays the VPP voltage.
``` bash
firestarter vpp
```

#### VCC
Displays the VCC voltage.
``` bash
firestarter vcc
```

#### Firmware
Checks or installs the firmware version.
``` bash
firestarter fw [options]
```

* `-i, --install`: Try to install the latest firmware. (Do this *without* a chip in the socket or without the shield attached)
* `-p, --avrdude-path <path>`: Full path to avrdude (optional), set if avrdude is not found.
* `--port <port>`: Serial port name (optional).
* `-c, --avrdude-config-path <path>`: Full path to avrdude config file (optional).
* `-b, --board <board>`: Microcontroller board (optional, defaults to *uno*).
* `-f, --force`: Install firmware even if the version matches.

#### Configuration
Shows current configuration values. Use options to set specific values.
``` bash
firestarter config [options]
```

* `-rev, <revision>`: WARNING Overrides hardware revision (0-2), only use with HW mods. -1 disables override.
* `-r1, --r16 <resistance>`: Set R16 resistance, resistor connected to VPE.
* `-r2, --r14r15 <resistance>`: Set R14/R15 resistance, resistors connected to GND.

## Examples
### Read
To read an EPROM named W27C512 and save the output to output.bin:
``` bash
firestarter read W27C512 output.bin
```
### Write
To write a binary file input.bin to an EPROM named W27C512:
``` bash
firestarter write W27C512 input.bin
```
### Info
To get information about an EPROM named W27C512:
``` bash
firestarter info W27C512
```
This command will output detailed information about the W27C512 EPROM, showing package layout and the jumper configuration for the RURP shield.
``` text
Eprom Info 
Name:           W27C512
Manufacturer:   WINBOND
Number of pins: 28
Memory size:    0x10000
Type:           EPROM
Can be erased:  True
Chip ID:        0xda08
VPP:            12v
Pulse delay:    100µS

       28-DIP package
        -----v-----
  A15 -|  1     28 |- VCC   
  A12 -|  2     27 |- A14   
  A7  -|  3     26 |- A13   
  A6  -|  4     25 |- A8    
  A5  -|  5     24 |- A9    
  A4  -|  6     23 |- A11   
  A3  -|  7     22 |- OE/Vpp
  A2  -|  8     21 |- A10   
  A1  -|  9     20 |- CE    
  A0  -| 10     19 |- D7    
  D0  -| 11     18 |- D6    
  D1  -| 12     17 |- D5    
  D2  -| 13     16 |- D4    
  GND -| 14     15 |- D3    
        -----------

        Jumper config
JP1    5V [ ●(● ●)] A13   : A13
JP2    5V [(● ●)● ] A17   : VCC
JP3 28pin [ ● ● ● ] 32pin : NA
```

## Override and adding to the database
### Eprom Configuration
By adding a file named `database.json` in the **.firestarter** folder under the home directory, it is possible to overide **Eprom** configurations or add new **Eproms** in the Firestarter database.

To overide an **Eprom** configuration extract the configuration for the intended **Eprom** with the info config command, ex: `firestarter info W27C512 -c` and the configuration will be printed.

W27C512 config:
``` json
{
    "WINBOND": [
        {
            "name": "W27C512",
            "pin-count": 28,
            "can-erase": true,
            "has-chip-id": true,
            "chip-id": "0x0000da08",
            "pin-map": 16,
            "protocol-id": "0x07",
            "memory-size": "0x10000",
            "type": "memory",
            "voltages": {
                "vpp": "12"
            },
            "pulse-delay": "0x0064",
            "flags": "0x00000078",
            "verified": true
        }
    ]
}
```
To overide the `pulse-delay` copy the configuration into the `database.json` in the **.firestarter** folder and remove all fields that aren't relevant to the change except for the manufacturer name and the **Eprom** name, ex:
``` json
{
    "WINBOND": [
        {
            "name": "W27C512",
            "pulse-delay": "0x0064"
        }
    ]
}
```

### Pin layout
By adding a file named `pin-maps.json` in the **.firestarter** folder under the home directory, it is possible to overide a **pin map** or add new **pin map** that aren't existing.

To overide or add a new **pin map** use the info config command, ex: `firestarter info W27C512 -c` to get a starting point.
W27C512 pin map:
``` json
{
    "28": {
        "16": {
            "address-bus-pins": [
                10, 9, 8, 7, 6, 5, 4, 3, 25, 24, 21, 23, 2, 26, 27, 1
            ]
        }
    }
}
```
The top level key (`"28"`) refers to the number of pins for the **Eprom** and the sub-key (`"16"`) is the `pin-map` in the configuration data for an **Eprom**.
Valid fields:
- `address-bus-pins` is an array with the pin numbers from the **Eprom** pin layout, starts with least significant address pin (A0) and added in order to the most significant address pin (A0,A2,...Ax).
- `rw-pin` Optional, if a read/write or a program enable pin is pressent `rw-pin` must be set to the pin layout number.
- `vpp-pin` Optional, if the **Eprom** needs programming voltage (Vpp) on pin 1 `vpp-pin` must be set to 1.

### Contributing to the database
Please report back new or changed configurations to Firestarter.
Create an [Issue](https://github.com/henols/firestarter_app/issues) where you describe the added **Eprom** or the changes that are done and add the json configurations from the database.json and pin-maps.json that are made.

## Handling EPROMs with Non-Standard Pin Layout (Adapters)

Some EPROMs, especially older 24-pin types or those adapted from other packages, require the programming voltage (VPP) or have or not using the OE (Output Enable) pin on a pin different from the standard locations the Firestarter hardware shield expects.

*   **Standard 28/32-pin Sockets:** Firestarter typically applies VPP via **Pin 1** or on the **OE (Output Enable) Pin (20)**.
*   **Standard 24-pin Sockets (using specific protocols):** Might not have the **OE (Output Enable)** pin (e.g., Pin 20 on a 24-pin EPROM, which maps to Pin 22 on the 28-pin ZIF socket), wich Firestarter expects it to be connected to.

When an EPROM's VPP pin doesn't match these expectations (like the M2716 needing VPP on its Pin 21) or the **OE** is omitted, you need two things:

1.  **A Physical Hardware Adapter:** This adapter sits between the Firestarter shield's socket and the EPROM. It reroutes the VPP signal or the OE pin from the pin where Firestarter *outputs* it (e.g., Pin 1 of the 28-pin socket) to the pin where the EPROM *needs* it (e.g., Pin 21 of the M2716). It also maps all other necessary pins correctly.
2.  **A Custom Software Configuration:** You need to tell Firestarter about this new "virtual" EPROM definition that uses the adapter. This involves defining the EPROM's characteristics and, crucially, the *new pin mapping* as seen by the programmer through the adapter.

### Configuration Steps:

The configuration requires adding entries to two files in your `.firestarter` user directory: `database.json` (for the EPROM definition) and `pin-maps.json` (for the physical pin connections of the adapter).

#### Step 1: Define the Adapter Setup in `database.json`

1.  **Find Base Configuration:** Get the original JSON configuration for your EPROM (e.g., `firestarter info M2716 -c`).
2.  **Create New Entry:** In your user `database.json` file, add a new entry under the appropriate manufacturer (e.g., "INTEL").
3.  **Assign Unique Name:** Give it a descriptive name indicating it uses an adapter (e.g., `M2716-adapter`).
4.  **Set `pin-count`:** Use the pin count of the *adapter's socket* that plugs into the programmer (usually 28 or 32). For the M2716 adapter example, this is `28`.
5.  **Assign Unique `pin-map` ID:** Create a *new, unique identifier* for this adapter's pin mapping. This ID links this definition to the corresponding map in `pin-maps.json`. In the example, `2716` is used.
6.  **Copy/Verify Parameters:** Copy essential parameters like `protocol-id`, `memory-size`, `type`, `voltages` (ensure VPP voltage is correct!), `pulse-delay`, and `flags` from the original EPROM definition. Adjust `can-erase` and `has-chip-id` as needed for the specific chip.

**Example (`database.json` entry for M2716-adapter):**

```json
{
    "INTEL": [
        {
            "name": "M2716-adapter",  // Unique name for the adapter setup
            "pin-count": 28,          // Pin count of the adapter socket plugging into the programmer
            "can-erase": false,
            "has-chip-id": false,
            "pin-map": 2716,          // Unique ID linking to pin-maps.json
            "protocol-id": "0x0b",    // Copied from original M2716
            "memory-size": "0x800",   // Copied from original M2716
            "type": "memory",
            "voltages": {
                "vpp": "25"           // VPP required by the M2716
            },
            "pulse-delay": "0x01f4",  // Copied from original M2716
            "flags": "0x00000048",    // Copied from original M2716
            "verified": false
        }
    ]
}
```

#### Step 2: Define the Adapter Pin Mapping in `pin-maps.json`
1. **Find/Create Section:** In your user pin-maps.json, find or create the section corresponding to the `pin-count` of your adapter socket (e.g., `"28"`).
2. **Add New Map Entry:** Add a new key using the exact unique *`pin-map`* ID you created in `database.json` (e.g., `"2716"`).
3. **Define `address-bus-pins`:** List the programmer socket pins (the pins on the 28-pin ZIF socket in this example) that are connected to the EPROM's address lines (A0, A1, A2...) through the adapter. The order must be A0 first, then A1, A2, etc.
4. **Define vpp-pin (Crucial for VPP Rerouting):**
    * If your adapter routes VPP from the programmer's Pin 1 (standard 28/32-pin VPP output) to the EPROM's actual VPP pin, add `"vpp-pin": 1`. This tells Firestarter to control VPP using its standard VPP circuitry connected to Pin 1 of its socket. **This is the case in the M2716-adapter example.**
    * If your adapter routes VPP from the programmer's **OE Pin** (Pin 22 on the 28-pin socket) to the EPROM's actual VPP pin, you would typically omit the `vpp-pin` entry here. Firestarter would likely use the OE pin for VPP control based on the `protocol-id` (like `0x0b`).
5. **Define `rw-pin` (If Applicable):** If the EPROM has a Write Enable (WE) or Program (PGM) pin, add `rw-pin` and set its value to the programmer socket pin connected to the EPROM's WE/PGM pin via the adapter.

**Example (`pin-maps.json` entry for M2716-adapter):**

*(This adapter routes VPP from the programmer's Pin 1 to the EPROM's Pin 21)*
```json
{
    "28": {
        "2716": { // Matches the pin-map ID from database.json
            "address-bus-pins": [
                10, 9, 8, 7, 6, 5, 4, 3, 25, 24, 21 // Programmer socket pins for A0-A10 via adapter
            ],
            "vpp-pin": 1 // Tells Firestarter to use Pin 1 on its socket for VPP control
        }
        // ... other pin maps for 28-pin sockets ...
    }
    // ... other pin counts like "24", "32" ...
}
```
### Using the Adapter Configuration
After saving these changes to your user `database.json` and `pin-maps.json` files, you can now use the adapter definition directly with Firestarter:
```bash
firestarter write M2716-adapter my_rom_file.bin
firestarter read M2716-adapter backup.bin
firestarter blank M2716-adapter
```
Firestarter will use the `M2716-adapter` definition, look up the `pin-map` ID `2716` under the `28`-pin section in `pin-maps.json`, and correctly control the address lines and apply VPP using Pin 1 of its own socket, which the physical adapter then routes to the correct pin on the M2716 EPROM.

## Contributing
Pull requests are welcome. For major changes, please open an issue first
to discuss what you would like to change.

Please make sure to update tests as appropriate.

## License
[MIT](https://raw.githubusercontent.com/henols/firestarter_app/main/LICENSE)

## Support me
Support me on ko-fi to keep me motivated to continue to develop Firestarter.

[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/E1E21I2WWW)

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "firestarter",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "firestarter, eprom, rom, eeprom, flash, programmer, arduino, electronics, retro computing, retro game console, commodore, atari, apple, c64, nes",
    "author": null,
    "author_email": "Henrik Olsson <henols@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/c5/e7/5bebafa3ca8620ffb7130a264f0657ebb441f12e0d75bf77aebb84f6b3a8/firestarter-2.0.6.tar.gz",
    "platform": null,
    "description": "\n<p align=\"center\"><img src=\"https://github.com/henols/firestarter_app/blob/main/images/firestarter_logo.png\" alt=\"Firestarter EPROM Programmer\" width=\"200\"></p>\n\n----\n\n# Firestarter\n\n[![PyPI version](https://badge.fury.io/py/firestarter.svg)](https://badge.fury.io/py/firestarter)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n\n[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/E1E21I2WWW)\n\n---\n\nFirestarter is an application for the [Relatively-Universal-ROM-Programmer](https://github.com/AndersBNielsen/Relatively-Universal-ROM-Programmer) RURP Arduino shield ([Get one here](https://www.imania.dk/samlesaet-hobbyelektronik-og-ic-er-relatively-universal-rom-programmer.htm).\n\nThe Firestarter Firmware can be found here [Firestarter](https://github.com/henols/firestarter).\n\nFirestarter in action [watch the video](https://youtu.be/JDHOKbyNnrE?si=0_iXKPZZwyyNGUTZ).\n\nAnders S Nielsen creator of the Relatively-Universal-ROM-Programmer talks about Firestarter [watch the video](https://youtu.be/SZQ50XZlk5o?si=IKOqQUeG4Rms1cUs).\n\nSupport and discussions forum at [Discord](https://discord.com/invite/kmhbxAjQc3).\n\n## Table of Content\n- [Installation](#Installation)\n  - [Installing the Firestarter Python Program](#installing-the-firestarter-python-program)\n  - [Installing the Firmware on the Arduino](#installing-the-firmware-on-the-arduino)\n- [Usage](#usage)\n  - [General Usage](#general-usage)\n  - [Commands](#commands)\n    - [Read](#read)\n    - [Write](#write)\n    - [Blank](#blank)\n    - [Erase](#erase)\n    - [Id](#id)\n    - [Info](#info)\n    - [Vpp](#vpp)\n    - [Vpe](#vpe)\n    - [Hw](#hardware)\n    - [Fw](#firmware)\n    - [Config](#configuration)\n\n- [Examples](#examples)\n  - [Read](#read-1)\n  - [Write](#write-1)\n  - [Info](#info-1)\n- [Override and adding to the database](#override-and-adding-to-the-database)\n  - [Eprom Configuration](#eprom-configuration)\n  - [Pin Layout](#pin-layout)\n  - [Contributing to the database](#contributing-to-the-database)\n- [Handling EPROMs with Non-Standard Pin Layout (Adapters)](#handling-eproms-with-non-standard-pin-layout-adapters)\n  - [Configuration Steps](#configuration-steps)\n  - [Using the Adapter Configuration](#using-the-adapter-configuration)\n- [Contributing](#contributing)\n- [License](#license)\n- [Support me](#support-me)\n\n\n## Installation\nTo install the Firestarter Python program and the firmware on the Arduino, follow the steps below:\n\n### Installing the Firestarter Python Program\nUse the package manager [pip](https://pip.pypa.io/en/stable/) to install Firestarter.\n\n``` bash\npip install firestarter \n```\n\nThis command installs the Firestarter application, which allows you to interact with EPROMs using the Relatively-Universal-ROM-Programmer.\n\n#### Auto complete\nHow to enable auto complete for firestarter, see: [auto complete](autocomplete.md)\n\n### Installing the Firmware on the Arduino\n\nFirst, a few things to remember. \n1. Don't attach the Programmer shield while power is on.\n2. Don't turn on power if the controller (Arduino) isn't programmed with appropriate firmware.\n3. Don't insert a ROM in the socket until you're ready to write it. Don't leave a ROM in the socket during reset or programming.\n\nTo install the firmware on the Arduino, use the **fw** command with the `--install` option. This command installs the latest firmware version on the Arduino.\n\nFirestarter is using **avrdude** to install the firmware.\n**avrdude** is avalible as a separate [installer](https://github.com/avrdudes/avrdude) or via Arduino IDE.\n\n#### Options\n* `-p, --avrdude-path <path>`: Full path to avrdude (optional), set if avrdude is not found.\n* `-c, --avrdude-config-path <path>`: Full path to avrdude config file (optional), may be needed if avrdude cannot find its default configuration (e.g., with older versions like 6.3 or non-standard installations).\n* `--port <port>`: Serial port name (optional), set if the Arduino is not found.\n* `-b, --board <board>`: Microcontroller board (optional), defaults to *uno*, other supported boards *leonardo*.\n* `-f, --force`: Will install firmware even if the version is the same.\n### Description\nThe `fw --install` command installs the latest firmware on the Arduino. The process typically involves the following steps:\n\n1. **Locate avrdude**: The command locates the avrdude tool, which is used to upload the firmware to the Arduino. You can specify the path to `avrdude` using the `--avrdude-path` option if it is not found automatically.\n2. **Identify Serial Port**: The command identifies the serial port to which the Arduino is connected. You can specify the port using the `--port` option.\n3. **Upload Firmware**: The command uploads the latest firmware to the Arduino using `avrdude`.\n\n### Example\nTo install the firmware on the **Arduino UNO**, you can run:\n``` bash\nfirestarter fw --install\n```\n\nTo install the firmware on the **Arduino Leonardo**, you can run:\n``` bash\nfirestarter fw --install --board leonardo\n```\n\n\n## Usage\nFirestarter provides several commands to interact with EPROMs using the Relatively-Universal-ROM-Programmer.\nAvailable commands: read, write, blank, erase, list, search, info, vpp, vcc, fw, config\n\n### General Usage\n\n``` bash\nfirestarter [options] {command}\n```\n  * `-h, --help`: Show help message\n  * `-v, --verbose`: Enable verbose mode\n  * `--version`: Show the Firestarter version and exit.\n\n### Commands\n\n#### Read\nReads the content from an EPROM.\n``` bash\nfirestarter read <eprom> [output_file]\n```\n* `<eprom>`: The name of the EPROM.\n* `[output_file]`: (Optional) Output file name, defaults to `<EPROM_NAME>.bin`.\n##### Description\nThe read command reads the data from the specified EPROM and optionally saves it to a file. The process typically involves the following steps:\n\n1. **Identify EPROM:** The command identifies the specified EPROM.\n2. **Read Data:** The data from the EPROM is read.\n3. **Save Data:** If an output file is specified, the read data is saved to that file. If no output file is specified, the data is saved to a file named `<EPROM_NAME>.bin`.\n\n#### Write\nWrites a binary file to an EPROM.\n``` bash\nfirestarter write <eprom> <input_file> [options]\n```\n* `<eprom>`: The name of the EPROM.\n* `<input_file>`: Input file name.\n##### Options\n* `-b, --ignore-blank-check`: Ignore blank check before write (and skip erase).\n* `-f, --force`: Force write, even if the VPP or chip ID don't match.\n* `-a, --address <address>`: Write start address in decimal or hexadecimal.\n##### Description\nThe write command writes the contents of a specified binary file to the EPROM. The process typically involves the following steps:\n\n1. **Blank Check:** By default, the command checks if the EPROM is blank before writing. This can be skipped using the `--ignore-blank-check` option.\n2. **Erase:** If the EPROM is not blank, it may need to be erased before writing. This step is also skipped if `--ignore-blank-check` is used.\n3. **Write:** The binary data from the input file is written to the EPROM starting at the specified address (if provided).\n4. **Verification:** The written data is verified to ensure it matches the input file.\n\n#### Blank \nChecks if an EPROM is blank.\n``` bash\nfirestarter blank <eprom>\n```\n\n* `<eprom>`: The name of the EPROM.\n\n#### Erase\nErases an EPROM, if supported.\n``` bash\nfirestarter erase <eprom>\n```\n* `<eprom>`: The name of the EPROM.\n#### List\nLists all EPROMs in the database.\n``` bash\nfirestarter list [options]\n```\n\n* `-v, --verified`: Only shows verified EPROMs.\n\n#### Search\nSearches for EPROMs in the database.\n``` bash\nfirestarter search <text>\n```\n\n* `<text>`: Text to search for.\n\n#### Info\nDisplays information about an EPROM.\n``` bash\nfirestarter info <eprom>\n```\n\n* `<eprom>`: EPROM name.\n##### Options\n* `-c, --config`: Show EPROM configuration data in JSON format.\n\n##### Description\nThe info command retrieves and displays detailed information about the specified EPROM. This information typically includes:\n\n* EPROM name\n* Manufacturer\n* Device ID\n* Memory size\n* Supported voltages\n* Pin configuration\n* Any other relevant technical specifications\n\n#### VPP\nDisplays the VPP voltage.\n``` bash\nfirestarter vpp\n```\n\n#### VCC\nDisplays the VCC voltage.\n``` bash\nfirestarter vcc\n```\n\n#### Firmware\nChecks or installs the firmware version.\n``` bash\nfirestarter fw [options]\n```\n\n* `-i, --install`: Try to install the latest firmware. (Do this *without* a chip in the socket or without the shield attached)\n* `-p, --avrdude-path <path>`: Full path to avrdude (optional), set if avrdude is not found.\n* `--port <port>`: Serial port name (optional).\n* `-c, --avrdude-config-path <path>`: Full path to avrdude config file (optional).\n* `-b, --board <board>`: Microcontroller board (optional, defaults to *uno*).\n* `-f, --force`: Install firmware even if the version matches.\n\n#### Configuration\nShows current configuration values. Use options to set specific values.\n``` bash\nfirestarter config [options]\n```\n\n* `-rev, <revision>`: WARNING Overrides hardware revision (0-2), only use with HW mods. -1 disables override.\n* `-r1, --r16 <resistance>`: Set R16 resistance, resistor connected to VPE.\n* `-r2, --r14r15 <resistance>`: Set R14/R15 resistance, resistors connected to GND.\n\n## Examples\n### Read\nTo read an EPROM named W27C512 and save the output to output.bin:\n``` bash\nfirestarter read W27C512 output.bin\n```\n### Write\nTo write a binary file input.bin to an EPROM named W27C512:\n``` bash\nfirestarter write W27C512 input.bin\n```\n### Info\nTo get information about an EPROM named W27C512:\n``` bash\nfirestarter info W27C512\n```\nThis command will output detailed information about the W27C512 EPROM, showing package layout and the jumper configuration for the RURP shield.\n``` text\nEprom Info \nName:           W27C512\nManufacturer:   WINBOND\nNumber of pins: 28\nMemory size:    0x10000\nType:           EPROM\nCan be erased:  True\nChip ID:        0xda08\nVPP:            12v\nPulse delay:    100\u00b5S\n\n       28-DIP package\n        -----v-----\n  A15 -|  1     28 |- VCC   \n  A12 -|  2     27 |- A14   \n  A7  -|  3     26 |- A13   \n  A6  -|  4     25 |- A8    \n  A5  -|  5     24 |- A9    \n  A4  -|  6     23 |- A11   \n  A3  -|  7     22 |- OE/Vpp\n  A2  -|  8     21 |- A10   \n  A1  -|  9     20 |- CE    \n  A0  -| 10     19 |- D7    \n  D0  -| 11     18 |- D6    \n  D1  -| 12     17 |- D5    \n  D2  -| 13     16 |- D4    \n  GND -| 14     15 |- D3    \n        -----------\n\n        Jumper config\nJP1    5V [ \u25cf(\u25cf \u25cf)] A13   : A13\nJP2    5V [(\u25cf \u25cf)\u25cf ] A17   : VCC\nJP3 28pin [ \u25cf \u25cf \u25cf ] 32pin : NA\n```\n\n## Override and adding to the database\n### Eprom Configuration\nBy adding a file named `database.json` in the **.firestarter** folder under the home directory, it is possible to overide **Eprom** configurations or add new **Eproms** in the Firestarter database.\n\nTo overide an **Eprom** configuration extract the configuration for the intended **Eprom** with the info config command, ex: `firestarter info W27C512 -c` and the configuration will be printed.\n\nW27C512 config:\n``` json\n{\n    \"WINBOND\": [\n        {\n            \"name\": \"W27C512\",\n            \"pin-count\": 28,\n            \"can-erase\": true,\n            \"has-chip-id\": true,\n            \"chip-id\": \"0x0000da08\",\n            \"pin-map\": 16,\n            \"protocol-id\": \"0x07\",\n            \"memory-size\": \"0x10000\",\n            \"type\": \"memory\",\n            \"voltages\": {\n                \"vpp\": \"12\"\n            },\n            \"pulse-delay\": \"0x0064\",\n            \"flags\": \"0x00000078\",\n            \"verified\": true\n        }\n    ]\n}\n```\nTo overide the `pulse-delay` copy the configuration into the `database.json` in the **.firestarter** folder and remove all fields that aren't relevant to the change except for the manufacturer name and the **Eprom** name, ex:\n``` json\n{\n    \"WINBOND\": [\n        {\n            \"name\": \"W27C512\",\n            \"pulse-delay\": \"0x0064\"\n        }\n    ]\n}\n```\n\n### Pin layout\nBy adding a file named `pin-maps.json` in the **.firestarter** folder under the home directory, it is possible to overide a **pin map** or add new **pin map** that aren't existing.\n\nTo overide or add a new **pin map** use the info config command, ex: `firestarter info W27C512 -c` to get a starting point.\nW27C512 pin map:\n``` json\n{\n    \"28\": {\n        \"16\": {\n            \"address-bus-pins\": [\n                10, 9, 8, 7, 6, 5, 4, 3, 25, 24, 21, 23, 2, 26, 27, 1\n            ]\n        }\n    }\n}\n```\nThe top level key (`\"28\"`) refers to the number of pins for the **Eprom** and the sub-key (`\"16\"`) is the `pin-map` in the configuration data for an **Eprom**.\nValid fields:\n- `address-bus-pins` is an array with the pin numbers from the **Eprom** pin layout, starts with least significant address pin (A0) and added in order to the most significant address pin (A0,A2,...Ax).\n- `rw-pin` Optional, if a read/write or a program enable pin is pressent `rw-pin` must be set to the pin layout number.\n- `vpp-pin` Optional, if the **Eprom** needs programming voltage (Vpp) on pin 1 `vpp-pin` must be set to 1.\n\n### Contributing to the database\nPlease report back new or changed configurations to Firestarter.\nCreate an [Issue](https://github.com/henols/firestarter_app/issues) where you describe the added **Eprom** or the changes that are done and add the json configurations from the database.json and pin-maps.json that are made.\n\n## Handling EPROMs with Non-Standard Pin Layout (Adapters)\n\nSome EPROMs, especially older 24-pin types or those adapted from other packages, require the programming voltage (VPP) or have or not using the OE (Output Enable) pin on a pin different from the standard locations the Firestarter hardware shield expects.\n\n*   **Standard 28/32-pin Sockets:** Firestarter typically applies VPP via **Pin 1** or on the **OE (Output Enable) Pin (20)**.\n*   **Standard 24-pin Sockets (using specific protocols):** Might not have the **OE (Output Enable)** pin (e.g., Pin 20 on a 24-pin EPROM, which maps to Pin 22 on the 28-pin ZIF socket), wich Firestarter expects it to be connected to.\n\nWhen an EPROM's VPP pin doesn't match these expectations (like the M2716 needing VPP on its Pin 21) or the **OE** is omitted, you need two things:\n\n1.  **A Physical Hardware Adapter:** This adapter sits between the Firestarter shield's socket and the EPROM. It reroutes the VPP signal or the OE pin from the pin where Firestarter *outputs* it (e.g., Pin 1 of the 28-pin socket) to the pin where the EPROM *needs* it (e.g., Pin 21 of the M2716). It also maps all other necessary pins correctly.\n2.  **A Custom Software Configuration:** You need to tell Firestarter about this new \"virtual\" EPROM definition that uses the adapter. This involves defining the EPROM's characteristics and, crucially, the *new pin mapping* as seen by the programmer through the adapter.\n\n### Configuration Steps:\n\nThe configuration requires adding entries to two files in your `.firestarter` user directory: `database.json` (for the EPROM definition) and `pin-maps.json` (for the physical pin connections of the adapter).\n\n#### Step 1: Define the Adapter Setup in `database.json`\n\n1.  **Find Base Configuration:** Get the original JSON configuration for your EPROM (e.g., `firestarter info M2716 -c`).\n2.  **Create New Entry:** In your user `database.json` file, add a new entry under the appropriate manufacturer (e.g., \"INTEL\").\n3.  **Assign Unique Name:** Give it a descriptive name indicating it uses an adapter (e.g., `M2716-adapter`).\n4.  **Set `pin-count`:** Use the pin count of the *adapter's socket* that plugs into the programmer (usually 28 or 32). For the M2716 adapter example, this is `28`.\n5.  **Assign Unique `pin-map` ID:** Create a *new, unique identifier* for this adapter's pin mapping. This ID links this definition to the corresponding map in `pin-maps.json`. In the example, `2716` is used.\n6.  **Copy/Verify Parameters:** Copy essential parameters like `protocol-id`, `memory-size`, `type`, `voltages` (ensure VPP voltage is correct!), `pulse-delay`, and `flags` from the original EPROM definition. Adjust `can-erase` and `has-chip-id` as needed for the specific chip.\n\n**Example (`database.json` entry for M2716-adapter):**\n\n```json\n{\n    \"INTEL\": [\n        {\n            \"name\": \"M2716-adapter\",  // Unique name for the adapter setup\n            \"pin-count\": 28,          // Pin count of the adapter socket plugging into the programmer\n            \"can-erase\": false,\n            \"has-chip-id\": false,\n            \"pin-map\": 2716,          // Unique ID linking to pin-maps.json\n            \"protocol-id\": \"0x0b\",    // Copied from original M2716\n            \"memory-size\": \"0x800\",   // Copied from original M2716\n            \"type\": \"memory\",\n            \"voltages\": {\n                \"vpp\": \"25\"           // VPP required by the M2716\n            },\n            \"pulse-delay\": \"0x01f4\",  // Copied from original M2716\n            \"flags\": \"0x00000048\",    // Copied from original M2716\n            \"verified\": false\n        }\n    ]\n}\n```\n\n#### Step 2: Define the Adapter Pin Mapping in `pin-maps.json`\n1. **Find/Create Section:** In your user pin-maps.json, find or create the section corresponding to the `pin-count` of your adapter socket (e.g., `\"28\"`).\n2. **Add New Map Entry:** Add a new key using the exact unique *`pin-map`* ID you created in `database.json` (e.g., `\"2716\"`).\n3. **Define `address-bus-pins`:** List the programmer socket pins (the pins on the 28-pin ZIF socket in this example) that are connected to the EPROM's address lines (A0, A1, A2...) through the adapter. The order must be A0 first, then A1, A2, etc.\n4. **Define vpp-pin (Crucial for VPP Rerouting):**\n    * If your adapter routes VPP from the programmer's Pin 1 (standard 28/32-pin VPP output) to the EPROM's actual VPP pin, add `\"vpp-pin\": 1`. This tells Firestarter to control VPP using its standard VPP circuitry connected to Pin 1 of its socket. **This is the case in the M2716-adapter example.**\n    * If your adapter routes VPP from the programmer's **OE Pin** (Pin 22 on the 28-pin socket) to the EPROM's actual VPP pin, you would typically omit the `vpp-pin` entry here. Firestarter would likely use the OE pin for VPP control based on the `protocol-id` (like `0x0b`).\n5. **Define `rw-pin` (If Applicable):** If the EPROM has a Write Enable (WE) or Program (PGM) pin, add `rw-pin` and set its value to the programmer socket pin connected to the EPROM's WE/PGM pin via the adapter.\n\n**Example (`pin-maps.json` entry for M2716-adapter):**\n\n*(This adapter routes VPP from the programmer's Pin 1 to the EPROM's Pin 21)*\n```json\n{\n    \"28\": {\n        \"2716\": { // Matches the pin-map ID from database.json\n            \"address-bus-pins\": [\n                10, 9, 8, 7, 6, 5, 4, 3, 25, 24, 21 // Programmer socket pins for A0-A10 via adapter\n            ],\n            \"vpp-pin\": 1 // Tells Firestarter to use Pin 1 on its socket for VPP control\n        }\n        // ... other pin maps for 28-pin sockets ...\n    }\n    // ... other pin counts like \"24\", \"32\" ...\n}\n```\n### Using the Adapter Configuration\nAfter saving these changes to your user `database.json` and `pin-maps.json` files, you can now use the adapter definition directly with Firestarter:\n```bash\nfirestarter write M2716-adapter my_rom_file.bin\nfirestarter read M2716-adapter backup.bin\nfirestarter blank M2716-adapter\n```\nFirestarter will use the `M2716-adapter` definition, look up the `pin-map` ID `2716` under the `28`-pin section in `pin-maps.json`, and correctly control the address lines and apply VPP using Pin 1 of its own socket, which the physical adapter then routes to the correct pin on the M2716 EPROM.\n\n## Contributing\nPull requests are welcome. For major changes, please open an issue first\nto discuss what you would like to change.\n\nPlease make sure to update tests as appropriate.\n\n## License\n[MIT](https://raw.githubusercontent.com/henols/firestarter_app/main/LICENSE)\n\n## Support me\nSupport me on ko-fi to keep me motivated to continue to develop Firestarter.\n\n[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/E1E21I2WWW)\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "EPROM programmer software for the Relatively Universal ROM Programmer",
    "version": "2.0.6",
    "project_urls": {
        "Homepage": "https://github.com/henols/firestarter_app"
    },
    "split_keywords": [
        "firestarter",
        " eprom",
        " rom",
        " eeprom",
        " flash",
        " programmer",
        " arduino",
        " electronics",
        " retro computing",
        " retro game console",
        " commodore",
        " atari",
        " apple",
        " c64",
        " nes"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "83b443fe1664291ef50cf260da028b59241accb5e7aee73a29c5a6b49c40fb6e",
                "md5": "01ae5a6375f1eac409b5d607b6485adc",
                "sha256": "e703089cddd4506e4d6284469fa15bb3066ec3ee7f23ff0d34c8184d0fcb9311"
            },
            "downloads": -1,
            "filename": "firestarter-2.0.6-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "01ae5a6375f1eac409b5d607b6485adc",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 68876,
            "upload_time": "2025-07-19T11:50:26",
            "upload_time_iso_8601": "2025-07-19T11:50:26.447309Z",
            "url": "https://files.pythonhosted.org/packages/83/b4/43fe1664291ef50cf260da028b59241accb5e7aee73a29c5a6b49c40fb6e/firestarter-2.0.6-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "c5e75bebafa3ca8620ffb7130a264f0657ebb441f12e0d75bf77aebb84f6b3a8",
                "md5": "5f96a54418bae6eaa208d80740608372",
                "sha256": "38eee0ad298ae1754f7aadef398ae2ccc1f83a69138898f2cd48a19c75c2cba8"
            },
            "downloads": -1,
            "filename": "firestarter-2.0.6.tar.gz",
            "has_sig": false,
            "md5_digest": "5f96a54418bae6eaa208d80740608372",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 2816262,
            "upload_time": "2025-07-19T11:50:27",
            "upload_time_iso_8601": "2025-07-19T11:50:27.893923Z",
            "url": "https://files.pythonhosted.org/packages/c5/e7/5bebafa3ca8620ffb7130a264f0657ebb441f12e0d75bf77aebb84f6b3a8/firestarter-2.0.6.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-07-19 11:50:27",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "henols",
    "github_project": "firestarter_app",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "argparse",
            "specs": []
        },
        {
            "name": "pyserial",
            "specs": []
        },
        {
            "name": "requests",
            "specs": []
        },
        {
            "name": "tqdm",
            "specs": []
        },
        {
            "name": "argcomplete",
            "specs": []
        },
        {
            "name": "rich",
            "specs": []
        }
    ],
    "lcname": "firestarter"
}
        
Elapsed time: 1.47104s