diff --git a/src/my_lib.c b/src/my_lib.c index 8764882..51be5b3 100644 --- a/src/my_lib.c +++ b/src/my_lib.c @@ -15,9 +15,55 @@ void init(void) lookup[i] = (uint8_t)rand(); } +char caesarLookup[][26] = { + "abcdefghijklmnopqrstuvwxyz", + "bcdefghijklmnopqrstuvwxyza", + "cdefghijklmnopqrstuvwxyzab", + "defghijklmnopqrstuvwxyzabc", + "efghijklmnopqrstuvwxyzabcd", + "fghijklmnopqrstuvwxyzabcde", + "ghijklmnopqrstuvwxyzabcdef", + "hijklmnopqrstuvwxyzabcdefg", + "ijklmnopqrstuvwxyzabcdefgh", + "jklmnopqrstuvwxyzabcdefghi", + "klmnopqrstuvwxyzabcdefghij", + "lmnopqrstuvwxyzabcdefghijk", + "mnopqrstuvwxyzabcdefghijkl", + "nopqrstuvwxyzabcdefghijklm", + "opqrstuvwxyzabcdefghijklmn", + "pqrstuvwxyzabcdefghijklmno", + "qrstuvwxyzabcdefghijklmnop", + "rstuvwxyzabcdefghijklmnopq", + "stuvwxyzabcdefghijklmnopqr", + "tuvwxyzabcdefghijklmnopqrs", + "uvwxyzabcdefghijklmnopqrst", + "vwxyzabcdefghijklmnopqrstu", + "wxyzabcdefghijklmnopqrstuv", + "xyzabcdefghijklmnopqrstuvw", + "yzabcdefghijklmnopqrstuvwx", + "zabcdefghijklmnopqrstuvwxy" +}; + +void caesarEncrypt(char input[], int length, char output[], int shift) +{ + for(int i = 0; i < length; ++i) + { + if('a' <= input[i] && input[i] <= 'z') + output[i] = caesarLookup[shift][input[i] - 'a']; + else + output[i] = input[i]; + } +} + void lookup_leakage(uint8_t *input, int inputLength, uint8_t *output) { - // Empty and constant time + // Convert input to alpha string + char *alpha = (char *)malloc(inputLength + 1); + for(int i = 0; i < inputLength; ++i) + alpha[i] = 'a' + (input[i] % 26); + alpha[inputLength] = '\0'; + + caesarEncrypt(alpha, inputLength, (char *)output, input[0] % 26); } int branch_leakage(uint8_t *input, int inputLength)