text
[RRG-proxmark3.git] / README.md
blob28e5baffa53641576586a1c5ab3bf0607cd788c6
1 # RRG / Iceman - Proxmark3
4 | Releases     | Coverity    | Contributors |
5 | ------------------- | -------------------:| -------------------:|
6 | [![Latest release](https://img.shields.io/github/v/release/rfidresearchgroup/proxmark3)](https://github.com/RfidResearchGroup/proxmark3/releases/latest) | [![Coverity Status](https://scan.coverity.com/projects/19334/badge.svg)](https://scan.coverity.com/projects/proxmark3-rrg-iceman-repo)| ![GitHub contributors](https://img.shields.io/github/contributors/rfidresearchgroup/proxmark3) |
9 | Actions OSX CI    |  Actions Ubuntu CI    | Windows CI |
10 | ------------------- | -------------------:| -------------------:|
11 | ![MacOS Build and Test](https://github.com/RfidResearchGroup/proxmark3/workflows/MacOS%20Build%20and%20Test/badge.svg?branch=master) | ![Ubuntu Build and Test](https://github.com/RfidResearchGroup/proxmark3/workflows/Ubuntu%20Build%20and%20Test/badge.svg?branch=master) | [![Build status](https://ci.appveyor.com/api/projects/status/b4gwrhq3nc876cuu/branch/master?svg=true)](https://ci.appveyor.com/project/RfidResearchGroup/proxmark3/branch/master) |
15 # PROXMARK3 INSTALLATION AND OVERVIEW
17 | FAQ's & Updates     | Installation        | Use of the Proxmark |
18 | ------------------- |:-------------------:| -------------------:|
19 |[What has changed?](#what-has-changed)  | **[Setup and build for Linux](/doc/md/Installation_Instructions/Linux-Installation-Instructions.md)** | [Compilation Instructions](/doc/md/Use_of_Proxmark/0_Compilation-Instructions.md)|
20 |[Development](#development) | **[Important notes on ModemManager for Linux users](/doc/md/Installation_Instructions/ModemManager-Must-Be-Discarded.md)** | [Validating proxmark client functionality](/doc/md/Use_of_Proxmark/1_Validation.md) |
21 |[Maintainers](#maintainers--package-distro-)| **[Homebrew (Mac OS X) & Upgrading HomeBrew Tap Formula](/doc/md/Installation_Instructions/Mac-OS-X-Homebrew-Installation-Instructions.md)** | [First Use and Verification](/doc/md/Use_of_Proxmark/2_Configuration-and-Verification.md)|
22 |[Proxmark3 GUI](#proxmark3-gui)|**[Setup and build for Windows](/doc/md/Installation_Instructions/Windows-Installation-Instructions.md)**|[Commands & Features](/doc/md/Use_of_Proxmark/3_Commands-and-Features.md)|
23 |[Pre-compiled binaries](#precompiled-binaries)|[Blue shark manual](/doc/bt_manual_v10.md) ||
24 |[Donations](#donations)||[Command Cheat sheet](/doc/cheatsheet.md)|
25 ||[Advanced compilation parameters](/doc/md/Use_of_Proxmark/4_Advanced-compilation-parameters.md)|[More cheat sheets](https://github.com/RfidResearchGroup/proxmark3/wiki/More-cheat-sheets)|
26 ||**[Troubleshooting](/doc/md/Installation_Instructions/Troubleshooting.md)**|[Complete client command set](/doc/commands.md)|
27 ||**[JTAG](/doc/jtag_notes.md)**|[T5577 Introduction Guide](/doc/T5577_Guide.md)|
28 ||**[MacPorts (Mac OS X, experimental)](/doc/md/Installation_Instructions/Mac-OS-X-MacPorts-Installation-Instructions.md)** |
31 ## Notes / helpful documents
33 | Notes |||
34 | ------------------- |:-------------------:| -------------------:|
35 |[Notes on UART](/doc/uart_notes.md)|[Notes on Termux / Android](/doc/termux_notes.md)|[Notes on paths](/doc/path_notes.md)|
36 |[Notes on frame format](/doc/new_frame_format.md)|[Notes on tracelog / wireshark](/doc/trace_notes.md)|[Notes on EMV](/doc/emv_notes.md)|
37 |[Notes on external flash](/doc/ext_flash_notes.md)|[Notes on loclass](/doc/loclass_notes.md)|[Notes on Coverity Scan Config & Run](/doc/md/Development/Coverity-Scan-Config-and-Run.md)|
38 |[Notes on file formats used with Proxmark3](/doc/extensions_notes.md)|[Notes on MFU binary format](/doc/mfu_binary_format_notes.md)|[Notes on FPGA & ARM](/doc/fpga_arm_notes.md)|
39 |[Developing standalone mode](/armsrc/Standalone/readme.md)|[Wiki about standalone mode](https://github.com/RfidResearchGroup/proxmark3/wiki/Standalone-mode)|[Notes on Magic cards](/doc/magic_cards_notes.md)|
40 |[Notes on Color usage](/doc/colors_notes.md)|[Makefile vs CMake](/doc/md/Development/Makefile-vs-CMake.md)|[Notes on Cloner guns](/doc/cloner_notes.md)|
41 |[Notes on cliparser usage](/doc/cliparser.md)|[Notes on clocks](/doc/clocks.md)|[Notes on DESFire usage](/doc/desfire.md)|
43 # How to build?
44 ## Proxmark3 RDV4
45 See the instruction links in the tables above to build, flash and run for your Proxmark3 RDV4 device.
47 ## Generic Proxmark3 platforms
48 In order to build this repo for generic Proxmark3 platforms we urge you to read [Advanced compilation parameters](/doc/md/Use_of_Proxmark/4_Advanced-compilation-parameters.md)
50 We define generic Proxmark3 platforms as following devices.
52 **Supported**
53   - RDV1, RDV2, RDV3 easy
54   - Ryscorp green PCB version
55   - Radiowar black PCB version
56   - numerous Chinese adapted versions of the RDV3 easy (kkmoon, PiSwords etc)
58 **Not supported**
59  - ⚠  Proxmark Evolution (EVO) 
60    - **Note**: unknown pin assignments.
61  - ⚠  Ryscorp Proxmark3 Pro 
62    - **Note**: device has different fpga and unknown pin assignments.
63  - ⚠  iCopy-X
64    - **Note**: experimental support, currently incompatible with iCopy-X GUI as Proxmark client commands are now using cliparser.
65    - **Note**: see also [icopyx-community repos](https://github.com/iCopy-X-Community/) for upstream sources, reversed hw etc.
67 **Unknown support status**
68  - ⚠  VX
69    - **Note**: unknown device hw
72 **256kb flash memory size of generic Proxmark3 platforms**
74 > ⚠ **Note**: 
75 > You need to keep a eye on how large your ARM chip built-in flash memory is. 
76 > With 512kb you are fine but if its 256kb you need to compile this repo with even less functionality.
77 > When running the `./pm3-flash-all` you can see which size your device have if you have the bootloader from this repo installed. 
78 > Otherwise you will find the size reported in the start message when running the Proxmark3 client `./pm3`.
80 > [OBS! Read the 256kb flash memory advisory](/doc/md/Use_of_Proxmark/4_Advanced-compilation-parameters.md#256kb-versions)
83 ## What has changed?
85 Proxmark3 RDV4 hardware modifications:
86   * added flash memory 256kb
87   * added smart card module
88   * added FPC connector for peripherals such as Bluetooth+battery addon
89   * improved antennas
90     * swappable
91     * LF Q factor switch
92     * LF 125/134 frequency switch
93   * tiny PCB form factor
94   * ABS case
96 This repo vs official Proxmark3 repo:
97 see the [Changelog file](CHANGELOG.md) which we try to keep updated. In short this repo gives you a completely different user experience when it comes to Proxmark3.
98   * richer CLI with use of colors / emojis
99   * help text system implemented everywhere
100   * hints system
101   * user preference settings
102   * extensive testing with continuous integration build systems on Linux, OSX and Windows, and regular usage of static analysis tools like 
103     * [Coverity Scan](https://scan.coverity.com/projects/proxmark3-rrg-iceman-repo/)
104     * Cppcheck
105     * GCC and Clang aggressive enforcement of diagnostic flags
106   * auto detection of serial ports and seamless integration with Bluetooth addon
107   * reconnect to device from inside client
108   * Supports tearoff attacks
109   * the most comprehensive compiled known keys dictionaries
110   * Slimed down usb communications with NG-frames
111   * the most compiled public known key recovery software
112   * the fastest implementations of said software
113   * support multiple fileformats for dump files (BIN/EML/JSON) 
114   * interoperability of said fileformats with libnfc, MFC tool app etc
115   * Supports more RFID based protocols than ever
116   * Easy install for package maintainers, distro maintainers
117   * More documentation 
120   
121 All of this and more is what makes this repo different from any other Proxmark3 firmware / client software. It is truely bleeding edge in that sense of available functionality and experience with it. With all extensive testing its also quite more stable than any other Proxmark3 repo.
124 ## Development
126 > ⚠ **Note**: This is a bleeding edge repository. The maintainers actively is working out of this repository and will be periodically re-structuring the code to make it easier to comprehend, navigate, build, test, and contribute to, so **DO expect significant changes to code layout on a regular basis**.
128 > 👉 **Remember!** If you intend to contribute to the code, please read the [coding style notes](CONTRIBUTING.md) first.
129 We usually merge your contributions fast since we do like the idea of getting a functionality in the Proxmark3 and weed out the bugs afterwards.
131 The [public roadmap](https://github.com/RfidResearchGroup/proxmark3/wiki/Public-Roadmap) is an excellent start to read if you are interesting in contributing.
134 ## Supported operative systems 
135 This repo compiles nicely on 
136    - WSL1 on Windows 10
137    - Proxspace enviroment [release v3.10](https://github.com/Gator96100/ProxSpace/releases)
138    - Windows/MinGW environment
139    - Ubuntu, ParrotOS, Gentoo, Pentoo, Kali, NetHunter, Arch Linux, Fedora, Debian, Raspbian
140    - Android / Termux
141    - Mac OS X / Homebrew (or MacPorts, experimental) / Apple Silicon M1
142    - Docker container
143       - [ RRG / Iceman repo based ubuntu 18.04 container ](https://hub.docker.com/r/secopsconsult/proxmark3)
144       - [ Iceman fork based container v1.7 ](https://hub.docker.com/r/iceman1001/proxmark3/)
147 ## Precompiled binaries
148 We don't maintain any precompiled binaries in this repo. There is community effort over at the Proxmark3 forum where package maintainer [@gator96100](https://github.com/gator96100) has set up a AWS bucket with precompiled Proxspace (MinGW) binaries which are recompiled every night and with that also up-to-date. We link to these files here as to make it easier for users. If you are having troubles with these files, we suggest to read the [homepage of his proxmark builds](https://www.proxmarkbuilds.org/) or read the [sticky thread at forum](http://www.proxmark.org/forum/viewtopic.php?pid=24763#p24763) 
150 ### Proxmark3 RDV4 devices
151 - [Precompiled builds for RDV40 dedicated x64](https://www.proxmarkbuilds.org/#rdv40-64/)
152 - [Precompiled builds for RDV40 dedicated with Bluetooth addon x64](https://www.proxmarkbuilds.org/#rdv40_bt-64/)
154 ### Generic Proxmark3 devices
155 - [Precompiled builds for RRG / Iceman repository x64](https://www.proxmarkbuilds.org/#rrg_other-64/)
158 ## Official channels
159 Where do you find the community?
160    - [RFID Hacking community discord server](https://discord.gg/QfPvGFRQxH)
161    - [Proxmark3 IRC channel](https://web.libera.chat/?channels=#proxmark3)
162    - [Proxmark3 sub reddit](https://www.reddit.com/r/proxmark3/)
163    - [Proxmark3 forum](http://www.proxmark.org/forum/index.php)
166 ## Maintainers ( package, distro )
168 To all distro, package maintainers, we tried to make your life easier.
170 `make install` is now available and if you want to know more.
171 - [Notes for maintainers](/doc/md/Development/Maintainers.md)
173 ## Proxmark3 GUI
175 The official PM3-GUI from Gaucho will not work. Not to mention is quite old and not maintained any longer.
177 - [Proxmark3 Universal GUI](https://github.com/burma69/PM3UniversalGUI) will work more or less.
179 - [Proxmark3 GUI cross-compiled](https://github.com/wh201906/Proxmark3GUI/) which is recently updated and claims to support latest source of this repo.
180 - [Proxmark3_GUI](https://github.com/Phreak87/Proxmark3_GUI) simple gui in vb.net
182 # Donations
184 Nothing says thank you as much as a donation. 
186 If you feel the love, do feel free to become a [Iceman patron](https://www.patreon.com/iceman1001).
188 If you are using @gator96100 's Proxspace with pre-compiled binaries do consider buy him a coffee for his efforts.
191 ## Citation
192 Use this bibtex to cite this repository globally:
194 @misc{proxmark3rrg,
195   author = {C. {Herrmann} and P. {Teuwen} and O. {Moiseenko} and M. {Walker} and others},
196   title = {{Proxmark3 -- RRG / Iceman repo}},
197   howpublished = {\url{https://github.com/RfidResearchGroup/proxmark3}},
198   keywords = {rfid nfc iceman proxmark3 125khz 134khz 13.56mhz},
201 If you need to refer to a specific state of the repository, use a commit number or a date of access, e.g.:
203   note = {Accessed: commit 12327f71a27da23831901847886aaf20e8ad3ca0}
204   note = {Accessed: 2021-01-01}