mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-09 17:38:00 +00:00
83db341e8a
All the work I've put in in the last few months to eliminate timing and cache side channels from PuTTY's mp_int and cipher implementations has been on a seat-of-the-pants basis: just thinking very hard about what kinds of language construction I think would be safe to use, and trying not to absentmindedly leave a conditional branch or a cast to bool somewhere vital. Now I've got a test suite! The basic idea is that you run the same crypto primitive multiple times, with inputs differing only in ways that are supposed to avoid being leaked by timing or leaving evidence in the cache; then you instrument the code so that it logs all the control flow, memory access and a couple of other relevant things in each of those runs, and finally, compare the logs and expect them to be identical. The instrumentation is done using DynamoRIO, which I found to be well suited to this kind of work: it lets you define custom modifications of the code in a reasonably low-effort way, and it lets you work at both the low level of examining single instructions _and_ the higher level of the function call ABI (so you can give things like malloc special treatment, not to mention intercepting communications from the program being instrumented). Build instructions are all in the comment at the top of testsc.c. At present, I've found this test to give a 100% pass rate using gcc -O0 and -O3 (Ubuntu 18.10). With clang, there are a couple of failures, which I'll fix in the next commit.
17 lines
498 B
CMake
17 lines
498 B
CMake
# CMake script for the 'sclog' DynamoRIO instrumentation system that
|
|
# goes with the PuTTY test binary 'testsc'. For build instructions see
|
|
# the comment at the top of testsc.c.
|
|
|
|
cmake_minimum_required(VERSION 3.5)
|
|
|
|
find_package(DynamoRIO)
|
|
if (NOT DynamoRIO_FOUND)
|
|
message(FATAL_ERROR "DynamoRIO not found")
|
|
endif()
|
|
|
|
add_library(sclog SHARED sclog.c)
|
|
configure_DynamoRIO_client(sclog)
|
|
foreach(extension drmgr drsyms drreg drutil drwrap)
|
|
use_DynamoRIO_extension(sclog ${extension})
|
|
endforeach()
|