暫無描述

Fabio Battaglia 4b46fba35b Fix string printing 5 年之前
.settings c8347d03c0 Update gitignore and pom 5 年之前
.vscode 5708cf1c58 fix launch.json 5 年之前
docs a29a4dc13b Cleanup the document 5 年之前
lib f17ba35b58 Add empty project 5 年之前
src 4b46fba35b Fix string printing 5 年之前
.classpath 7285306f42 Transform the project into a maven project 5 年之前
.gitignore c8347d03c0 Update gitignore and pom 5 年之前
.project 44d620fd08 Update README 5 年之前
CHANGELOG.md 9761a035b6 Updated changelog 5 年之前
COPYING 07fee47c69 Add licence 5 年之前
README.md 3d7eff106f Change how enter in remote mode is checked, update firmware 5 年之前
TODO.md d6927bb9bd Add check whether restored partial dump is from a different PAL type 5 年之前
pom.xml 7069d933eb Add some tests 5 年之前

README.md

DuPAL Analyzer

Introduction

The DuPAL Analyzer is a companion software to the DuPAL board. It uses the board's REMOTE CONTROL mode to remotely toggle the pins and read the outputs, and is meant to perform blackbox analisys on the registered PAL devices, which are a bit too much for the MCU firmware to handle by itself.

Please, spend some time to read how the Black Box Analysis works and how to handle recovered equations that don't seem to fit a new PAL.

WARNING: Currently, PALs that feeds the output of an equation back into the equation itself are NOT supported by the analisys algorithm. Example:

/o18 = /i2 & /i3 & /i4 & /i5 & o14 & o18 +
       /i2 & /i3 & /i4 & /i5 & o15 & o18 +
       /i2 & /i3 & /i4 & /i5 & o16 & o18 +
       /i2 & /i3 & /i4 & /i5 & o17 & o18 +
       /i5 & /o18

What it CAN do

This analyzer works in tandem with the DuPAL board to:

  • Do a black-box analisys of a set of registered PAL devices and produce a truth table that can be minimized and transformed into logic equations functionally equivalent to those used to program the chip.
  • Do bruteforcing of some combinatorial PAL devices and produce a truth table.
  • While my opinion is that for archival purposes a dump of the chip is the best option, I also think that a working machine beats a dead one any day. So this tool can help you creating a functionally identical PAL device starting from a known-good chip, and also store the data for future use.

What it CAN'T do

  • Produce logic equations out of the PAL: reiventing the wheel is not an intelligent thing to do, you can feed the truth table to software like espresso heuristic logic minimizer and get the equations automatically. You can then further refine them with a tool like Logic Friday, if needed. See below.
  • While the logic equations that are going to be produced by using this + a minimizer are going to be functionally equivalent to those used to program the chip (at least for all the possible inputs), there is a chance they're not going to be identical. This is because the minimizer might further optimize them and because they won't make use of the feedback outputs during optimization.
    • If the feedback outputs are required (e.g. to further reduce the number of terms so they can fit in a new chip), the equations can be placed into Logic Friday and massaged (e.g. factor them, turn them into sums of products, invert them, etc) until a direct substitution with a feedback output becomes easy enough to be performed.
  • Can't resurrect dead ICs: You'll need a PAL in working conditions to obtain a good truth table.
  • Can't work quick: we are not simply "reading" the chip here. We're creating a graph of all the reachable states and all the links between them. This means that we need to reconstruct the behaviour of the black box by feeding it with every possible combination of input. For a chip with 6 registered outputs, and 8 inputs, it means that we're going to have 64 possible states, each one with 256 links out of them that we need to explore. And we cannot teleport from a state to another: we need to move through the graph following links until we get to the state we wish to explore! Analyzing a chip can take from 10 minutes to several hours.

Building

Build and packaging this application requires maven and a JDK compatible with Java 1.8 .

Once both are installed, you can run mvn package from the project root directory and you should end up with a JAR file in target/.

The Analyzer

The analyzer lets the user select which type of registered PAL is inserted in the board's ZIF socket, whether the output pins are known (which saves some time), what is the board's serial interface, and where to save the output files. Once this is known, the application will:

  1. Connect to the board, reset it, and enable the REMOTE MODE, so it accepts command from the application.
  2. If which I/O pins are actually outputs is not known, the board will try to guess this and print the result. This procedure is not bulletproof (or it would take the same time as the proper analisys: in case it did not detect some outputs, these will be found during the analisys and will halt the procedure, allowing the user to specify them for the next run).
  3. The analisys will start. The status will be saved every 5 minutes, so it can be stopped and resumed at leisure. The procedure can take hours to complete.
  4. A truth table formatted in a way that the espresso heuristic logic minimizer likes is saved to a file.

Caveats

Once the truth table is obtained, its content should be minimized and equations calculated: espresso is a good tool for this. Often, some of the resulting equations for the registered outputs will not fit into a new PAL device. There are multiple reasons for this:

  1. To obtain the original equations, one should in theory produce a table where every input is fed to the black box and every output is recorded: with registered devices this is alas impossible: the input of a state depends on the previous state, and not every state can be reached.
    • The result will be a set of equations functionally identical to the originals, for all the states that can be reached in reality, but one cannot always recover the original equations.
  2. To save products in the PAL circuitry, feedback outputs are used. This means some outputs take their value and feed it back to the network inside the PAL. As all the outputs are fed by the same inputs, the equations will be equivalent, but won't contain this simplification that can save important space on the device.
    • I haven't found a way to do an automatic replacement of these terms, but they're usually apparent when looking at the equations that make use of them. Logic Friday is a good tool to put the equations in, and either factorize them, transform the in sums of products or products of sums until You can spot a member that contains the same operands as one of the feedback outputs. At that point it becomes a matter of doing a simple replacement.
    • Refer to docs/Minimize_Equations_with_feedbacks.md in this repository for additional explanation and examples.

Supported devices

The following PAL models are supported:

Combinatorial

  • PAL10L8 (untested)
  • PAL12L6 (untested)
  • PAL16L8

Registered

  • PAL16R4
  • PAL16R6
  • PAL16R8

Command line

The format for command line execution is the following:

java -jar /path/to/dupal_analyzer.jar <serial_port> <pal_type> <output_directory> [hex_output_mask]
  • serial_port: is just the serial port to use to connect to the DuPAL board. Connection is hardcoded at 57600bps 8n1 without flow control.
  • pal_type: is the type of PAL device that is going to be analyzed.
  • output_directory: Where DuPAL Analyzer will output the generated truth table and where it will periodically save the status of the analisys so it can be stopped and recovered later.
  • hex_output_mask: This mask (an byte written as an hex number) is used to tell the Analyzer which IOs are configured as outputs. If it's not present, the Analyzer will try to guess it by itself. It's usually advisable to let the guessing run for a few minutes, then restart the analisys by specifying the guessed mask. If the mask is wrong, during the analisys an error will be thrown as soon as what was thought as an input is found to be an output. At that point the analisys can be restarted with the new mask.

The output mask format

The output mask is a byte represented as an hex value, where a bit is set when the corrisponding pin is considered an output. From MSB to LSB:

   7    6    5    4    3    2    1    0
.----.----.----.----.----.----.----.----.
| 12 | 19 | 13 | 14 | 15 | 16 | 17 | 18 |
'----'----'----'----'----'----'----'----'

Pay attention to the weird position for pin 19, that position is caused by a desire to save a few lines on the firmware.

Requirements

Make sure you have at least a Java 1.8 compatible JRE installed and have access to your serial port devices (In linux it's usually sufficient to add your user to the dialout group).

Credits

  • Thanks to jammarcade.net for hosting all those PAL dumps, I used a lot of them to test my implementation.
  • Thanks to @mesillo for taking time to read my documentation and pointing out possible improvements.