Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nezza/scada-stuff
A collection of scripts & tools for reverse-engineering & hacking SCADA/ICS devices.
https://github.com/nezza/scada-stuff
Last synced: about 2 months ago
JSON representation
A collection of scripts & tools for reverse-engineering & hacking SCADA/ICS devices.
- Host: GitHub
- URL: https://github.com/nezza/scada-stuff
- Owner: nezza
- Created: 2017-10-15T11:41:44.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2018-03-14T15:16:16.000Z (almost 7 years ago)
- Last Synced: 2024-08-04T23:10:57.104Z (5 months ago)
- Language: Python
- Homepage:
- Size: 9.77 KB
- Stars: 101
- Watchers: 12
- Forks: 25
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-security-collection - **54**星 - engineering & hacking SCADA/ICS devices. (<a id="8c5a692b5d26527ef346687e047c5c21"></a>收集)
README
# scada-stuff
## Hopper bFLT loader
A lot of ICS devices use uClinux/eCos which uses the bFLT format. The `hopper_bflt_loader.py` implements basic bFLT support for Hopper. Open a binary with the settings:
```
Base address: 0x0
Entry point: 0x0
File offset: 0x0
CPU: ARMv6 Little endian
```and then run the script on it.
The script is based on the IDA Pro loader written by Craig Heffner from Tactical Network Solutions
## moxa_parse_fw.py
Extracts the firmware images of the simple Mgate and Nport devices without wireless capability.
Firmware images compatible with this tool can be found on the Moxa website.
### Usage
```
moxa_parse_fw.py
```### Output description
The output directory will contain all extracted files in a flat format. The binary firmware itself is saved to `/fw.bin`.
Note that, depending on the device, different CPU architectures are used. Mgate devices seem to use ARM-based CPUs which can be directly loaded into Hopper/IDA Pro/Radare2 with the following settings:
```
Base address: 0x0
Entry point: 0x0
File offset: 0x0
CPU: ARMv6 Little endian
```The NPort devices with a Moxa labelled chip are based on the [R8822](http://www.paradigmtools.com/docs/R8822.PDF) (Thanks [K. Reid Wightman](https://twitter.com/ReverseICS)!)
architecture.## parse_upg.py
Converts .upg firmware files as used by some Schneider Electric devices into a binary file that can be loaded into a disassembler.
### Usage
```
parse_upg.py
```## Moxa NPort W2150 Firmware
The firmware files for the Moxa NPort W2x50 can be loaded directlry into a disassembler with the following settings:
```
Base address: 0x0
Entry point: 0x0
File offset: 0x58
CPU: ARMv6 Little endian
```Note that this only loads the Linux bootlaoder which uncompresses the kernel. The filesystems themselves can be extracted using `binwalk -e`.
Starting with firmware version 2 the firmware is encrypted.
## Advantech ADAM 4570 Firmware
The firmware file (e.g. `ADAM-4570-BE_FW_D1.70_268D671C.bin`) can be directly loaded into a disassembler.