* digital signal: introduce digital signal * nfca: add nfca signal encoder * nfc: add mifare classic emulation scene * nfca: add classic emulation support to lib and hal * mifare classic: support basic read commands * nfc: add mifare classic menu scene * mifare classic: start parsing commands in emulation * mifare classic: add nested auth * nfc: fix errors * mifare classic: add encrypt function * nfc: fix mifare classic save * lib hex: add hex uint64_t ASCII parser * flipper format: add uint64 hex format support * nfc: add mifare classic key map * nfc: hide mifare classic keys on emulation * mifare classic: add NACK responce * nfc: add partial bytes support in transparent mode * nfc: mifare classic add shadow file support * digital signal: move arr buffer from BSS to heap * mifare classic: process access bits more careful * nfca: fix memory leack * nfc: format sources * mifare classic: cleun up Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include "hex.h"
 | 
						|
 | 
						|
bool hex_char_to_hex_nibble(char c, uint8_t* nibble) {
 | 
						|
    if((c >= '0' && c <= '9') || (c >= 'A' && c <= 'F') || (c >= 'a' && c <= 'f')) {
 | 
						|
        if((c >= '0' && c <= '9')) {
 | 
						|
            *nibble = c - '0';
 | 
						|
        } else if((c >= 'A' && c <= 'F')) {
 | 
						|
            *nibble = c - 'A' + 10;
 | 
						|
        } else {
 | 
						|
            *nibble = c - 'a' + 10;
 | 
						|
        }
 | 
						|
        return true;
 | 
						|
    } else {
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
bool hex_chars_to_uint8(char hi, char low, uint8_t* value) {
 | 
						|
    uint8_t hi_nibble_value, low_nibble_value;
 | 
						|
 | 
						|
    if(hex_char_to_hex_nibble(hi, &hi_nibble_value) &&
 | 
						|
       hex_char_to_hex_nibble(low, &low_nibble_value)) {
 | 
						|
        *value = (hi_nibble_value << 4) | low_nibble_value;
 | 
						|
        return true;
 | 
						|
    } else {
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
bool hex_chars_to_uint64(const char* value_str, uint64_t* value) {
 | 
						|
    uint8_t* _value = (uint8_t*)value;
 | 
						|
    bool parse_success = false;
 | 
						|
 | 
						|
    for(uint8_t i = 0; i < 8; i++) {
 | 
						|
        parse_success = hex_chars_to_uint8(value_str[i * 2], value_str[i * 2 + 1], &_value[7 - i]);
 | 
						|
        if(!parse_success) break;
 | 
						|
    }
 | 
						|
    return parse_success;
 | 
						|
}
 |