Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/shred/identify

Amiga library for hardware identification
https://github.com/shred/identify

amiga-library aminet assembly hardware-information

Last synced: 8 days ago
JSON representation

Amiga library for hardware identification

Awesome Lists containing this project

README

        

# identify.library

Identify is a shared Amiga library that helps identifying all kind of system parameters.

The source code was closed, like almost all of my Amiga projects. I have now reviewed and reformatted the files, translated the comments from German to English, and made the project compilable on Linux (and probably other targets) using vbcc. The source is now open to everyone for contributing, studying, archiving, or just enjoying the good old Amiga times.

## Features

* Identifies expansion card names, alerts, and function call names
* Gives information about your Amiga model, CPU, OS version, available memory, chipset, and much more...
* Supports from AmigaOS 2.0 up to the latest AmigaOS 3.2.2
* The expansion database contains 364 manufacturers and 701 boards
* Distinguishes between most GVP and Phase5 boards with unique ID
* Tries to give at least a hint if the board name is not known yet
* Fully FPGA, DraCo, and PowerPC compatible
* Supports PowerUp and WarpOS
* The library is fully localized (catalogs included: Deutsch, Italiano)
* Use the features in ARexx, with the included rexxidentify.library
* English and German documentation
* LGPLv3 licensed, open source
* Source Code available at [GitHub](https://github.com/shred/identify)

## Missing Expansions

[See here](report-missing-boards.md) about how to report missing expansions.

## Frequently Asked Questions

If you have questions about identify, maybe you will find answers [here](docs/faq.md).

## Building from Source

This project is mainly made to be build on Linux machines. However, with a few modifications it can also be built on AmigaOS and other operating systems.

Requirements:

* [GNU make](http://www.gnu.org/software/make/) or another compatible make tool
* [vbcc](http://www.compilers.de/vbcc.html)
* [fd2pragma](https://github.com/adtools/fd2pragma)
* [FlexCat](https://github.com/adtools/flexcat/releases/tag/2.18)
* [AmigaOS NDK 3.2](https://www.hyperion-entertainment.com/index.php/downloads?view=files&parent=40), unpacked on your build machine
* [MUI](http://sasg.com/mui/download.html) by Stefan Stuntz, includes unpacked on your build machine
* [mmu.library](http://aminet.net/package/docs/misc/MuManual) by Thomas Richter, includes unpacked on your build machine
* [lha](https://github.com/jca02266/lha) (compiled with `--enable-multibyte-filename=auto` option, which is the default)
* [AmiTools](https://github.com/cnvogelg/amitools) (optional, for the `pack` target only)

Set the `AMIGA_NDK` env variable to the location of the unpacked `NDK3.2` directory on your build machine. Also set `AMIGA_INCLUDES` to the location of 3rd party include files, where the MUI includes can be found.

Then just invoke `make` to build the project. The compiled project can be found in the `build` directory.

`make release` will compile a release version in the `release` directory. This target is optimized for Linux, and might not run on other operating systems.

`make pack` will create adf files for `IdentifyDev` and `IdentifyUsr` in the `release` directory. These files may be useful to install Identify on disk based systems, but are not part of the official release.

Today's standard encoding is UTF-8. Unfortunately AmigaOS does not support this encoding, so the files in this project have different encodings depending on their purpose. The assembler and C files must use plain ASCII encoding, so they can be edited on Linux and Amiga without encoding problems. For special characters in strings, always use escape sequences. Do not use special characters in comments. `make check` will test if these files contain illegal characters. All purely Amiga-related files (like AmigaGuide or Catalog files) are expected to be ISO-8859-1 encoded. Then again, `README.md` (and other files related to the open source release) are UTF-8 encoded. If you are in doubt, use plain ASCII.

## Contribution and Releases

The source code of this project can be found [at the official GitHub page](https://github.com/shred/identify).

If you found a bug or have a feature request, feel free to [open an issue](https://github.com/shred/identify/issues) or [send a pull request](https://github.com/shred/identify/pulls).

At the AmiNet, you will find [official binaries](http://aminet.net/package/util/libs/IdentifyUsr) and [development files](http://aminet.net/package/util/libs/IdentifyDev).

**Please keep the "IdentifyDev" and "IdentifyUsr" package names reserved for official releases.** If you want to release a fork, use a different package name. But please consider contributing to the reference repository instead. This is better than having an unknown number of forks and different versions of the code floating around.

## Translation

The identify tools are fully localizable. English is the built-in language. Available translations are (in alphabetical order):

* Deutsch (by Richard Körber)
* Français (by Filipe Brandão)
* Italiano (by David Lo Buglio)

If you want to provide other translations, please contact me for assistance.

## Sync with your own Board Database?

If you're managing an own board database in your project, feel invited to sync it with [this database](src/identify/ID_Database.s). However, it would only be fair if you then also share the boards that are missing here. Please open an issue, send a merge request, or just get in contact with me. Thank you!

## Licence

`Identify` is distributed under LGPLv3 ([Lesser Gnu Public Licence](http://www.gnu.org/licenses/lgpl.html)).