mirror of
				https://github.com/Proxmark/proxmark3.git
				synced 2025-10-25 05:27:29 +08:00 
			
		
		
		
	This makes the PM3 generate pseudo-random nonces rather than sequential nonces, to make it act a bit more like a "real" MFC card. A reader would otherwise be able to detect the PM3 probing based on the predictable nonces and throw different authentication challenges (or refuse to authenticate at all). The code includes an implementation of a rand-like function (prand), similar to the one from libc, which is seeded automatically based on the time it takes between the PM3 starting up and the first call to the RNG. This isn't cryptographically random, but should be "good enough" to be able to evade basic detection.
		
			
				
	
	
		
			59 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| //-----------------------------------------------------------------------------
 | |
| // Jonathan Westhues, Aug 2005
 | |
| //
 | |
| // This code is licensed to you under the terms of the GNU GPL, version 2 or,
 | |
| // at your option, any later version. See the LICENSE.txt file for the text of
 | |
| // the license.
 | |
| //-----------------------------------------------------------------------------
 | |
| // Utility functions used in many places, not specific to any piece of code.
 | |
| //-----------------------------------------------------------------------------
 | |
| 
 | |
| #ifndef __UTIL_H
 | |
| #define __UTIL_H
 | |
| 
 | |
| #include <stddef.h>
 | |
| #include <stdint.h>
 | |
| #include "common.h"
 | |
| 
 | |
| #define BYTEx(x, n) (((x) >> (n * 8)) & 0xff )
 | |
| 
 | |
| #define LED_RED 1
 | |
| #define LED_ORANGE 2
 | |
| #define LED_GREEN 4
 | |
| #define LED_RED2 8
 | |
| #define BUTTON_HOLD 1
 | |
| #define BUTTON_NO_CLICK 0
 | |
| #define BUTTON_SINGLE_CLICK -1
 | |
| #define BUTTON_DOUBLE_CLICK -2
 | |
| #define BUTTON_ERROR -99
 | |
| 
 | |
| void print_result(char *name, uint8_t *buf, size_t len);
 | |
| size_t nbytes(size_t nbits);
 | |
| uint32_t SwapBits(uint32_t value, int nrbits);
 | |
| void num_to_bytes(uint64_t n, size_t len, uint8_t* dest);
 | |
| uint64_t bytes_to_num(uint8_t* src, size_t len);
 | |
| void rol(uint8_t *data, const size_t len);
 | |
| void lsl (uint8_t *data, size_t len);
 | |
| int32_t le24toh (uint8_t data[3]);
 | |
| 
 | |
| void SpinDelay(int ms);
 | |
| void SpinDelayUs(int us);
 | |
| void LED(int led, int ms);
 | |
| void LEDsoff();
 | |
| int BUTTON_CLICKED(int ms);
 | |
| int BUTTON_HELD(int ms);
 | |
| void FormatVersionInformation(char *dst, int len, const char *prefix, void *version_information);
 | |
| 
 | |
| void StartTickCount();
 | |
| uint32_t RAMFUNC GetTickCount();
 | |
| 
 | |
| void StartCountUS();
 | |
| uint32_t RAMFUNC GetCountUS();
 | |
| uint32_t RAMFUNC GetDeltaCountUS();
 | |
| 
 | |
| void StartCountSspClk();
 | |
| uint32_t RAMFUNC GetCountSspClk();
 | |
| 
 | |
| uint32_t prand();
 | |
| 
 | |
| #endif
 |