46 lines
		
	
	
		
			949 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			949 B
		
	
	
	
		
			C
		
	
	
	
	
	
#pragma once
 | 
						|
 | 
						|
#include <toolbox/bit_buffer.h>
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
typedef struct {
 | 
						|
    uint32_t odd;
 | 
						|
    uint32_t even;
 | 
						|
} Crypto1;
 | 
						|
 | 
						|
Crypto1* crypto1_alloc();
 | 
						|
 | 
						|
void crypto1_free(Crypto1* instance);
 | 
						|
 | 
						|
void crypto1_reset(Crypto1* crypto1);
 | 
						|
 | 
						|
void crypto1_init(Crypto1* crypto1, uint64_t key);
 | 
						|
 | 
						|
uint8_t crypto1_bit(Crypto1* crypto1, uint8_t in, int is_encrypted);
 | 
						|
 | 
						|
uint8_t crypto1_byte(Crypto1* crypto1, uint8_t in, int is_encrypted);
 | 
						|
 | 
						|
uint32_t crypto1_word(Crypto1* crypto1, uint32_t in, int is_encrypted);
 | 
						|
 | 
						|
void crypto1_decrypt(Crypto1* crypto, const BitBuffer* buff, BitBuffer* out);
 | 
						|
 | 
						|
void crypto1_encrypt(Crypto1* crypto, uint8_t* keystream, const BitBuffer* buff, BitBuffer* out);
 | 
						|
 | 
						|
void crypto1_encrypt_reader_nonce(
 | 
						|
    Crypto1* crypto,
 | 
						|
    uint64_t key,
 | 
						|
    uint32_t cuid,
 | 
						|
    uint8_t* nt,
 | 
						|
    uint8_t* nr,
 | 
						|
    BitBuffer* out,
 | 
						|
    bool is_nested);
 | 
						|
 | 
						|
uint32_t prng_successor(uint32_t x, uint32_t n);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 |