proxmark3/armsrc/Standalone
2019-05-04 11:36:35 +02:00
..
hf_bog.c chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00
hf_bog.h
hf_colin.c More USB_CMD -> PM3_CMD 2019-05-04 11:36:35 +02:00
hf_colin.h Revert c7a4d7af, remove redundant include 2019-04-22 22:11:57 +02:00
hf_mattyrun.c rework Dbprintf & add color support 2019-04-26 10:36:06 +02:00
hf_mattyrun.h Rename few USB -> PM3 to avoid misleading interpretations 2019-04-30 21:10:11 +02:00
hf_young.c Missing Rename USB -> PM3 2019-05-03 16:57:56 +02:00
hf_young.h
lf_hidbrute.c chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00
lf_hidbrute.h
lf_icerun.c style 2019-04-28 11:08:41 +02:00
lf_icerun.h chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00
lf_proxbrute.c chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00
lf_proxbrute.h
lf_samyrun.c chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00
lf_samyrun.h
placeholder.c Use placeholder for standalone mode if needed 2019-04-25 22:40:46 +02:00
readme.md update standalone readme 2019-04-25 23:40:51 +02:00
standalone.h chg: refactor standalone mode info string 2019-04-25 21:44:34 +02:00

StandAlone Modes

This contains functionality for different StandAlone modes. The fullimage will be built given the correct compiler flags used. Build targets for these files are contained in armsrc/Makefile and common/Makefile.hal

If you want to implement a new standalone mode, you need to implement the methods provided in standalone.h. Have a look at the skeleton standalone mode called IceRun, in the files lf_icerun.c lf_icerun.h.

As it is now, you can only have one standalone mode installed at the time.

Implementing a standalone mode

We suggest you keep your standalone code inside the armsrc/Standalone folder. And that you name your files according to your standalone mode name.

The standalone.h states that you must have two functions implemented.

The ModInfo function, which is your identification of your standalone mode. This string will show when running the command hw status on the client.

The RunMod function, which is your "main" function when running. You need to check for Usb commands, in order to let the pm3 client break the standalone mode. See this basic skeleton of main function RunMod() and Modinfo() below.

void ModInfo(void) {
    DbpString("   LF good description of your mode - aka FooRun (your name)");
}

void RunMod(void) {
    // led show
    StandAloneMode();

    // Do you target LF or HF?
    FpgaDownloadAndGo(FPGA_BITSTREAM_LF);

    // main loop
    for (;;) {
        WDT_HIT();

        // exit from standalone mode, just send a usbcommand
        if (usb_poll_validate_length()) break;

        // do your standalone stuff..
    }

Each standalone mode needs to have its own compiler flag to be added in armsrc/Makefile.

Naming your standalone mode

We suggest that you follow these guidelines:

  • Use HF/LF to denote which frequency your mode is targeting.
  • Use you own github name/similar for perpetual honour to denote your mode.

sample: LF_FOO

Which indicates your mode targets LF and is called FOO.

This leads to your next step, your DEFINE name needed in Makefile.

WITH_STANDALONE_LF_FOO

Update COMMON/MAKEFILE.HAL

Add your suggested DEFINE to the samples of directive flag provided in the common/Makefile.hal.

#PLATFORM_DEFS += -DWITH_STANDALONE_LF_SAMYRUN
#PLATFORM_DEFS += -DWITH_STANDALONE_LF_ICERUN
#PLATFORM_DEFS += -DWITH_STANDALONE_LF_PROXBRUTE
#PLATFORM_DEFS += -DWITH_STANDALONE_LF_HIDBRUTE
#PLATFORM_DEFS += -DWITH_STANDALONE_HF_YOUNG
#PLATFORM_DEFS += -DWITH_STANDALONE_HF_MATTYRUN
#PLATFORM_DEFS += -DWITH_STANDALONE_HF_COLIN
#PLATFORM_DEFS += -DWITH_STANDALONE_HF_BOG
#PLATFORM_DEFS += -DWITH_STANDALONE_LF_FOO

Update ARMSRC/MAKEFILE

Add your source code files like the following sample in the armsrc/Makefile

# WITH_STANDALONE_LF_ICERUN
ifneq (,$(findstring WITH_STANDALONE_LF_ICERUN,$(APP_CFLAGS)))
	SRC_STANDALONE = lf_icerun.c
endif

# WITH_STANDALONE_LF_FOO
ifneq (,$(findstring WITH_STANDALONE_LF_FOO,$(APP_CFLAGS)))
    SRC_STANDALONE = lf_foo.c
endif

Adding identification string of your mode

Do please add a identification string in a function called ModInfo inside your source code file. This will enable an easy way to detect on client side which standalone mode has been installed on the device.

void ModInfo(void) {
    DbpString("   LF good description of your mode - aka FooRun (your name)");
}

Compiling your standalone mode

Once all this is done, you and others can now easily compile different standalone modes by just selecting one of the standalone modes in common/Makefile.hal, e.g.:

PLATFORM_DEFS += -DWITH_STANDALONE_LF_FOO

Remember only one can be selected at a time for now.