vcard: moved more code into loadables
This commit is contained in:
parent
7539f4e6f7
commit
8f7664a938
5 changed files with 48 additions and 28 deletions
|
@ -6,6 +6,8 @@
|
|||
|
||||
#include <string.h>
|
||||
|
||||
#include "basic/ecc.h"
|
||||
|
||||
/**************************************************************************/
|
||||
|
||||
#include "final.gen"
|
||||
|
@ -18,14 +20,12 @@ void forLoadables(int i){
|
|||
if(i){
|
||||
lcdSetPixel(0,0);
|
||||
font=&Font_Invaders;
|
||||
//filetransfer_send();
|
||||
ECIES_encyptkeygen();
|
||||
//filetransfer_receive();
|
||||
//rftransfer_receive();
|
||||
//rftransfer_send();
|
||||
ECIES_encyptkeygen(0,0,0,0,0,0);
|
||||
systickGetTicks();
|
||||
ECIES_decryptkeygen();
|
||||
bitstr_parse_export();
|
||||
ECIES_embedded_public_key_validation();
|
||||
point_copy(0,0,0,0);
|
||||
point_is_zero(0,0);
|
||||
bitstr_parse_export(0,0);
|
||||
nrf_rcv_pkt_time_encr();
|
||||
};
|
||||
};
|
||||
|
|
|
@ -25,9 +25,6 @@ unsigned char rnd1()
|
|||
}
|
||||
|
||||
|
||||
#define MACRO(A) do { A; } while(0)
|
||||
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
||||
|
||||
//compiles to a quite reasonable assembly code
|
||||
//void INT2CHARS (unsigned char *ptr, uint32_t val)
|
||||
void INT2CHARS (char *ptr, uint32_t val)
|
||||
|
@ -50,17 +47,6 @@ r|=*ptr--;
|
|||
return r;
|
||||
}
|
||||
|
||||
/* some basic bit-manipulation routines that act on these vectors follow */
|
||||
#define bitstr_getbit(A, idx) ((A[(idx) / 32] >> ((idx) % 32)) & 1)
|
||||
#define bitstr_setbit(A, idx) MACRO( A[(idx) / 32] |= 1 << ((idx) % 32) )
|
||||
#define bitstr_clrbit(A, idx) MACRO( A[(idx) / 32] &= ~(1 << ((idx) % 32)) )
|
||||
|
||||
#define bitstr_clear(A) MACRO( memset(A, 0, sizeof(bitstr_t)) )
|
||||
#define bitstr_copy(A, B) MACRO( memcpy(A, B, sizeof(bitstr_t)) )
|
||||
#define bitstr_swap(A, B) MACRO( bitstr_t h; \
|
||||
bitstr_copy(h, A); bitstr_copy(A, B); bitstr_copy(B, h) )
|
||||
#define bitstr_is_equal(A, B) (! memcmp(A, B, sizeof(bitstr_t)))
|
||||
|
||||
int bitstr_is_clear(const bitstr_t x)
|
||||
{
|
||||
int i;
|
||||
|
@ -184,7 +170,6 @@ int bitstr_parse_export(char *exp, const char *s)
|
|||
|
||||
|
||||
|
||||
#define field_set1(A) MACRO( A[0] = 1; memset(A + 1, 0, sizeof(elem_t) - 4) )
|
||||
|
||||
int field_is1(const elem_t x)
|
||||
{
|
||||
|
@ -253,12 +238,6 @@ void field_invert(elem_t z, const elem_t x) /* field inversion */
|
|||
curves). Coefficient 'b' is given in 'coeff_b'. '(base_x, base_y)'
|
||||
is a point that generates a large prime order group. */
|
||||
|
||||
|
||||
#define point_is_zero(x, y) (bitstr_is_clear(x) && bitstr_is_clear(y))
|
||||
#define point_set_zero(x, y) MACRO( bitstr_clear(x); bitstr_clear(y) )
|
||||
#define point_copy(x1, y1, x2, y2) MACRO( bitstr_copy(x1, x2); \
|
||||
bitstr_copy(y1, y2) )
|
||||
|
||||
/* check if y^2 + x*y = x^3 + *x^2 + coeff_b holds */
|
||||
int is_point_on_curve(const elem_t x, const elem_t y)
|
||||
{
|
||||
|
|
|
@ -32,5 +32,27 @@ void ECIES_encryption(char *msg, const char *text, int len,
|
|||
int ECIES_decryption(char *text, const char *msg, int len,
|
||||
const char *privkey);
|
||||
|
||||
#define MACRO(A) do { A; } while(0)
|
||||
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
||||
/* some basic bit-manipulation routines that act on these vectors follow */
|
||||
#define bitstr_getbit(A, idx) ((A[(idx) / 32] >> ((idx) % 32)) & 1)
|
||||
#define bitstr_setbit(A, idx) MACRO( A[(idx) / 32] |= 1 << ((idx) % 32) )
|
||||
#define bitstr_clrbit(A, idx) MACRO( A[(idx) / 32] &= ~(1 << ((idx) % 32)) )
|
||||
|
||||
#define bitstr_clear(A) MACRO( memset(A, 0, sizeof(bitstr_t)) )
|
||||
#define bitstr_copy(A, B) MACRO( memcpy(A, B, sizeof(bitstr_t)) )
|
||||
#define bitstr_swap(A, B) MACRO( bitstr_t h; \
|
||||
bitstr_copy(h, A); bitstr_copy(A, B); bitstr_copy(B, h) )
|
||||
#define bitstr_is_equal(A, B) (! memcmp(A, B, sizeof(bitstr_t)))
|
||||
|
||||
#define field_set1(A) MACRO( A[0] = 1; memset(A + 1, 0, sizeof(elem_t) - 4) )
|
||||
|
||||
|
||||
#define point_is_zero(x, y) (bitstr_is_clear(x) && bitstr_is_clear(y))
|
||||
#define point_set_zero(x, y) MACRO( bitstr_clear(x); bitstr_clear(y) )
|
||||
#define point_copy(x1, y1, x2, y2) MACRO( bitstr_copy(x1, x2); \
|
||||
bitstr_copy(y1, y2) )
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
|
|
|
@ -318,3 +318,21 @@ int16_t rftransfer_receive(uint8_t *buffer, uint16_t maxlen, uint16_t timeout)
|
|||
return -2;
|
||||
}
|
||||
|
||||
int ECIES_decryptkeygen(uint8_t *rx, uint8_t *ry,
|
||||
uint8_t k1[16], uint8_t k2[16], const char *privkey)
|
||||
{
|
||||
elem_t Rx, Ry, Zx, Zy;
|
||||
exp_t d;
|
||||
bitstr_import(Rx, (char*)rx);
|
||||
bitstr_import(Ry, (char*)ry);
|
||||
if (ECIES_embedded_public_key_validation(Rx, Ry) < 0)
|
||||
return -1;
|
||||
bitstr_parse(d, privkey);
|
||||
point_copy(Zx, Zy, Rx, Ry);
|
||||
point_mult(Zx, Zy, d);
|
||||
point_double(Zx, Zy); /* cofactor h = 2 on B163 */
|
||||
if (point_is_zero(Zx, Zy))
|
||||
return -1;
|
||||
ECIES_kdf((char*)k1,(char*) k2, Zx, Rx, Ry);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -282,3 +282,4 @@ void rftransfer_send(uint16_t size, uint8_t *data)
|
|||
nrf_snd_pkt_crc(32,buf); //setup packet
|
||||
delayms(20);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue