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
|