• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1// break-kat corrupts a known-answer-test input in a binary and writes the
2// corrupted binary to stdout. This is used to demonstrate that the KATs in the
3// binary notice the error.
4package main
5
6import (
7	"bytes"
8	"encoding/hex"
9	"flag"
10	"fmt"
11	"io/ioutil"
12	"os"
13	"sort"
14)
15
16var (
17	kats = map[string]string{
18		"HMAC-SHA-256":    "dad91293dfcf2a7c8ecd13fe353fa75b",
19		"AES-CBC-encrypt": "078609a6c5ac2544699adf682fa377f9be8ab6aef563e8c56a36b84f557fadd3",
20		"AES-CBC-decrypt": "347aa5a024b28257b36510be583d4f47adb7bbeedc6005bbbd0d0a9f06bb7b10",
21		"AES-GCM-encrypt": "8fcc4099808e75caaff582898848a88d808b55ab4e9370797d940be8cc1d7884",
22		"AES-GCM-decrypt": "35f3058f875760ff09d3120f70c4bc9ed7a86872e13452202176f7371ae04faae1dd391920f5d13953d896785994823c",
23		"DRBG":            "c4da0740d505f1ee280b95e58c4931ac6de846a0152fbb4a3f174cf4787a4f1a40c2b50babe14aae530be5886d910a27",
24		"DRBG-reseed":     "c7161ca36c2309b716e9859bb96c6d49bdc8352103a18cd24ef42ec97ef46bf446eb1a4576c186e9351803763a7912fe",
25		"SHA-1":           "132fd9bad5c1826263bafbb699f707a5",
26		"SHA-256":         "ff3b857da7236a2baa0f396b51522217",
27		"SHA-512":         "212512f8d2ad8322781c6c4d69a9daa1",
28		"TLS-KDF":         "abc3657b094c7628a0b282996fe75a75f4984fd94d4ecc2fcf53a2c469a3f731",
29		"RSA-sign":        "d2b56e53306f720d7929d8708bf46f1c22300305582b115bedcac722d8aa5ab2",
30		"RSA-verify":      "abe2cbc13d6bd39d48db5334ddbf8d070a93bdcb104e2cc5d0ee486ee295f6b31bda126c41890b98b73e70e6b65d82f95c663121755a90744c8d1c21148a1960be0eca446e9ff497f1345c537ef8119b9a4398e95c5c6de2b1c955905c5299d8ce7a3b6ab76380d9babdd15f610237e1f3f2aa1c1f1e770b62fbb596381b2ebdd77ecef9c90d4c92f7b6b05fed2936285fa94826e62055322a33b6f04c74ce69e5d8d737fb838b79d2d48e3daf71387531882531a95ac964d02ea413bf85952982bbc089527daff5b845c9a0f4d14ef1956d9c3acae882d12da66da0f35794f5ee32232333517db9315232a183b991654dbea41615345c885325926744a53915",
31		"ECDSA-sign":      "1e35930be860d0942ca7bbd6f6ded87f157e4de24f81ed4b875c0e018e89a81f",
32		"ECDSA-verify":    "6780c5fc70275e2c7061a0e7877bb174deadeb9887027f3fa83654158ba7f50c2d36e5799790bfbe2183d33e96f3c51f6a232f2a24488c8e5f64c37ea2cf0529",
33		"Z-computation":   "e7604491269afb5b102d6ea52cb59feb70aede6ce3bfb3e0105485abd861d77b",
34		"FFDH":            "a14f8ad36be37b18b8f35864392f150ab7ee22c47e1870052a3f17918274af18aaeaf4cf6aacfde96c9d586eb7ebaff6b03fe3b79a8e2ff9dd6df34caaf2ac70fd3771d026b41a561ee90e4337d0575f8a0bd160c868e7e3cef88aa1d88448b1e4742ba11480a9f8a8b737347c408d74a7d57598c48875629df0c85327a124ddec1ad50cd597a985588434ce19c6f044a1696b5f244b899b7e77d4f6f20213ae8eb15d37eb8e67e6c8bdbc4fd6e17426283da96f23a897b210058c7c70fb126a5bf606dbeb1a6d5cca04184c4e95c2e8a70f50f5c1eabd066bd79c180456316ac02d366eb3b0e7ba82fb70dcbd737ca55734579dd250fffa8e0584be99d32b35",
35	}
36
37	listTests = flag.Bool("list-tests", false, "List known test values and exit")
38)
39
40func main() {
41	flag.Parse()
42
43	if *listTests {
44		for _, kat := range sortedKATs() {
45			fmt.Println(kat)
46		}
47		os.Exit(0)
48	}
49
50	if flag.NArg() != 2 || kats[flag.Arg(1)] == "" {
51		fmt.Fprintln(os.Stderr, "Usage: break-kat <binary path> <test to break> > output")
52		fmt.Fprintln(os.Stderr, "Possible values for <test to break>:")
53		for _, kat := range sortedKATs() {
54			fmt.Fprintln(os.Stderr, " ", kat)
55		}
56		os.Exit(1)
57	}
58
59	inPath := flag.Arg(0)
60	test := flag.Arg(1)
61	testInputValue, err := hex.DecodeString(kats[test])
62	if err != nil {
63		panic("invalid kat data: " + err.Error())
64	}
65
66	binaryContents, err := ioutil.ReadFile(inPath)
67	if err != nil {
68		fmt.Fprintln(os.Stderr, err)
69		os.Exit(2)
70	}
71
72	i := bytes.Index(binaryContents, testInputValue)
73	if i < 0 {
74		fmt.Fprintln(os.Stderr, "Expected test input value was not found in binary.")
75		os.Exit(3)
76	}
77
78	binaryContents[i] ^= 1
79	os.Stdout.Write(binaryContents)
80}
81
82func sortedKATs() []string {
83	var ret []string
84	for kat := range kats {
85		ret = append(ret, kat)
86	}
87	sort.Strings(ret)
88	return ret
89}
90