File: des.bench

package info (click to toggle)
tcllib 2.0%2Bdfsg-4
  • links: PTS
  • area: main
  • in suites: trixie
  • size: 83,572 kB
  • sloc: tcl: 306,798; ansic: 14,272; sh: 3,035; xml: 1,766; yacc: 1,157; pascal: 881; makefile: 124; perl: 84; f90: 84; python: 33; ruby: 13; php: 11
file content (105 lines) | stat: -rw-r--r-- 2,611 bytes parent folder | download | duplicates (2)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# -*- tcl -*-
# Tcl Benchmark File
#
# This file contains a number of benchmarks for the 'des' module.
# This allow developers to monitor/gauge/track package performance.
#
# (c) 2005 Andreas Kupries <andreas_kupries@users.sourceforge.net>

# We need at least version 8.5 for the package and thus the
# benchmarks.

if {![package vsatisfies [package provide Tcl] 8.5 9]} {
    return
}

# ### ### ### ######### ######### ######### ###########################
## Setting up the environment ...

package forget tclDES
catch {namespace delete ::des}
catch {source [file join [file dirname [info script]] tcldes.tcl]}

package forget des
catch {namespace delete ::DES}
source [file join [file dirname [info script]] des.tcl]

set i [binary format H* 0000000000000000]
set p [binary format H* 0123456789ABCDEF0123456789ABCDEF]]

set k [binary format H* FEDCBA9876543210]
set c [binary format H* ED39D950FA74BCC4ED39D950FA74BCC4]

# ### ### ### ######### ######### ######### ###########################
## Benchmarks.

bench -desc "DES 1des ECB encryption" -body {
    DES::des -mode ecb -dir enc -key $k -iv $i $p
}

bench -desc "DES 1des ECB decryption" -body {
    DES::des -mode ecb -dir dec -key $k -iv $i $c
}

bench -desc "DES 1des ECB encryption core" -pre {
    set key [DES::Init ecb $k $i]
} -body {
    DES::Encrypt $key $p
} -post {
    DES::Final $key
}

bench -desc "DES 1des ECB decryption core" -pre {
    set key [DES::Init ecb $k $i]
} -body {
    DES::Decrypt $key $c
} -post {
    DES::Final $key
}

bench -desc "DES 1des ECB keyschedule" -body {
    DES::Final [DES::Init ecb $k $i]
}

bench -desc "DES 1des CBC keyschedule" -body {
    DES::Final [DES::Init cbc $k $i]
}

if {[llength [package provide tclDES]] != 0} {
    set k [binary format H* FEDCBA9876543210FEDCBA9876543210FEDCBA9876543210]

    bench -desc "DES 3des ECB encryption" -body {
	DES::des -mode ecb -dir enc -key $k -iv $i $p
    }

    bench -desc "DES 3des ECB decryption" -body {
	DES::des -mode ecb -dir dec -key $k -iv $i $c
    }

    bench -desc "DES 3des ECB encryption core" -pre {
	set key [DES::Init ecb $k $i]
    } -body {
	DES::Encrypt $key $p
    } -post {
	DES::Final $key
    }

    bench -desc "DES 3des ECB decryption core" -pre {
	set key [DES::Init ecb $k $i]
    } -body {
	DES::Decrypt $key $c
    } -post {
	DES::Final $key
    }

    bench -desc "DES 3des ECB keyschedule" -body {
	DES::Final [DES::Init ecb $k $i]
    }

    bench -desc "DES 3des CBC keyschedule" -body {
	DES::Final [DES::Init cbc $k $i]
    }
}

# ### ### ### ######### ######### ######### ###########################
## Complete