forked from Keysight/Jlsca
-
Notifications
You must be signed in to change notification settings - Fork 0
/
attackdes-tests.jl
62 lines (49 loc) · 1.53 KB
/
attackdes-tests.jl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# This file is part of Jlsca, license is GPLv3, see https://www.gnu.org/licenses/gpl-3.0.en.html
#
# Author: Cees-Bart Breunesse
using Base.Test
using Sca
using Trs
function testDesTraces(conditional::Bool,direction::Direction, analysis::Analysis, onetest::Bool=false)
tracedir = "destraces"
filenames = readdir(tracedir)
# leakageFunctions = [bit7]
for filename in filenames
if filename[end-3+1:end] != "trs"
continue
end
fullfilename = joinpath(tracedir,filename)
@printf("file: %s\n", fullfilename)
params = getParameters(fullfilename, direction)
params.analysis = analysis
# params.analysis.leakageFunctions = [hw]
# create Trace instance
if conditional
@everyworker begin
using Trs
trs = InspectorTrace($fullfilename)
setPostProcessor(trs, CondAvg(SplitByTracesSliced()))
end
else
trs = InspectorTrace(fullfilename)
end
if conditional
key = sca(DistributedTrace(),params,1,200)
else
key = sca(trs,params,1, 200)
end
@test(key == get(params.knownKey))
if onetest
break
end
end
end
x = DPA()
x.leakageFunctions = [hw]
@time testDesTraces(true, BACKWARD, x)
@time testDesTraces(true, FORWARD, DPA())
@time testDesTraces(false, BACKWARD, DPA())
@time testDesTraces(false, FORWARD, DPA())
x = LRA()
x.basisModel = x -> basisModelSingleBits(x, 4)
@time testDesTraces(true, FORWARD, x, true)