123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- #include <stdio.h>
- #include <stdint.h>
- #include "speck.h"
- void Words16ToBytes(u16 words[],u8 bytes[],int numwords)
- {
- int i,j=0;
- for(i=0;i<numwords;i++){
- bytes[j]=(u8)words[i];
- bytes[j+1]=(u8)(words[i]>>8);
- j+=2;
- }
- }
- void BytesToWords16(u8 bytes[],u16 words[],int numbytes)
- {
- int i,j=0; for(i=0;i<numbytes/2;i++){
- words[i]=(u16)bytes[j] | ((u16)bytes[j+1]<<8);
- j+=2;
- }
- }
- void Speck3264KeySchedule(u16 K[],u16 rk[])
- {
- u16 i,D=K[3],C=K[2],B=K[1],A=K[0];
- for(i=0;i<22;){
- rk[i]=A;
- ER16(B,A,i++);
- rk[i]=A;
- ER16(C,A,i++);
- rk[i]=A;
- ER16(D,A,i++);
- }
-
- }
- void Speck3264Encrypt(u16 Pt[],u16 Ct[],u16 rk[])
- {
- u16 i;
- Ct[0]=Pt[0]; Ct[1]=Pt[1];
-
-
-
- for(i=0;i<22;) {
-
- ER16(Ct[1],Ct[0],rk[i++]);
- }
- }
- void Speck3264Decrypt(u16 Pt[],u16 Ct[],u16 rk[])
- {
- int i;
- Pt[0]=Ct[0]; Pt[1]=Ct[1];
- for(i=21;i>=0;) DR16(Pt[1],Pt[0],rk[i--]);
- }
- void Speck3264_EncryptBlock(u8 pt[], u8 k[], u8 ct[]) {
- u16 Pt[2] = {0};
- u16 K[4] = {0};
- u16 rk[34] = {0};
- u16 Ct[2] = {0};
- BytesToWords16(pt,Pt,8);
- BytesToWords16(k,K,16);
- Speck3264KeySchedule(K,rk);
-
-
- Speck3264Encrypt(Pt,Ct,rk);
- Words16ToBytes(Ct,ct,2);
- }
|