vcard: moved more code into loadables

This commit is contained in:
schneider 2011-08-03 10:54:22 +02:00
parent 7539f4e6f7
commit 8f7664a938
5 changed files with 48 additions and 28 deletions

View file

@ -6,6 +6,8 @@
#include <string.h> #include <string.h>
#include "basic/ecc.h"
/**************************************************************************/ /**************************************************************************/
#include "final.gen" #include "final.gen"
@ -18,14 +20,12 @@ void forLoadables(int i){
if(i){ if(i){
lcdSetPixel(0,0); lcdSetPixel(0,0);
font=&Font_Invaders; font=&Font_Invaders;
//filetransfer_send(); ECIES_encyptkeygen(0,0,0,0,0,0);
ECIES_encyptkeygen();
//filetransfer_receive();
//rftransfer_receive();
//rftransfer_send();
systickGetTicks(); systickGetTicks();
ECIES_decryptkeygen(); ECIES_embedded_public_key_validation();
bitstr_parse_export(); point_copy(0,0,0,0);
point_is_zero(0,0);
bitstr_parse_export(0,0);
nrf_rcv_pkt_time_encr(); nrf_rcv_pkt_time_encr();
}; };
}; };

View file

@ -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 //compiles to a quite reasonable assembly code
//void INT2CHARS (unsigned char *ptr, uint32_t val) //void INT2CHARS (unsigned char *ptr, uint32_t val)
void INT2CHARS (char *ptr, uint32_t val) void INT2CHARS (char *ptr, uint32_t val)
@ -50,17 +47,6 @@ r|=*ptr--;
return r; 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 bitstr_is_clear(const bitstr_t x)
{ {
int i; 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) 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)' curves). Coefficient 'b' is given in 'coeff_b'. '(base_x, base_y)'
is a point that generates a large prime order group. */ 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 */ /* 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) int is_point_on_curve(const elem_t x, const elem_t y)
{ {

View file

@ -32,5 +32,27 @@ void ECIES_encryption(char *msg, const char *text, int len,
int ECIES_decryption(char *text, const char *msg, int len, int ECIES_decryption(char *text, const char *msg, int len,
const char *privkey); 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 #endif

View file

@ -318,3 +318,21 @@ int16_t rftransfer_receive(uint8_t *buffer, uint16_t maxlen, uint16_t timeout)
return -2; 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;
}

View file

@ -282,3 +282,4 @@ void rftransfer_send(uint16_t size, uint8_t *data)
nrf_snd_pkt_crc(32,buf); //setup packet nrf_snd_pkt_crc(32,buf); //setup packet
delayms(20); delayms(20);
} }