1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include <stddef.h>
6 #include <stdint.h>
7 #include <stdio.h>
8 #include <string.h>
9
10 #include "crypto/p224.h"
11
12 #include "base/macros.h"
13 #include "testing/gtest/include/gtest/gtest.h"
14
15 namespace crypto {
16
17 using p224::Point;
18
19 // kBasePointExternal is the P224 base point in external representation.
20 static const uint8_t kBasePointExternal[56] = {
21 0xb7, 0x0e, 0x0c, 0xbd, 0x6b, 0xb4, 0xbf, 0x7f, 0x32, 0x13, 0x90, 0xb9,
22 0x4a, 0x03, 0xc1, 0xd3, 0x56, 0xc2, 0x11, 0x22, 0x34, 0x32, 0x80, 0xd6,
23 0x11, 0x5c, 0x1d, 0x21, 0xbd, 0x37, 0x63, 0x88, 0xb5, 0xf7, 0x23, 0xfb,
24 0x4c, 0x22, 0xdf, 0xe6, 0xcd, 0x43, 0x75, 0xa0, 0x5a, 0x07, 0x47, 0x64,
25 0x44, 0xd5, 0x81, 0x99, 0x85, 0x00, 0x7e, 0x34,
26 };
27
28 // TestVector represents a test of scalar multiplication of the base point.
29 // |scalar| is a big-endian scalar and |affine| is the external representation
30 // of g*scalar.
31 struct TestVector {
32 uint8_t scalar[28];
33 uint8_t affine[28 * 2];
34 };
35
36 static const int kNumNISTTestVectors = 52;
37
38 // kNISTTestVectors are the NIST test vectors for P224.
39 static const TestVector kNISTTestVectors[kNumNISTTestVectors] = {
40 {
41 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
42 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
43 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
44 0x00, 0x00, 0x00, 0x01},
45 {0xb7, 0x0e, 0x0c, 0xbd, 0x6b, 0xb4, 0xbf, 0x7f,
46 0x32, 0x13, 0x90, 0xb9, 0x4a, 0x03, 0xc1, 0xd3,
47 0x56, 0xc2, 0x11, 0x22, 0x34, 0x32, 0x80, 0xd6,
48 0x11, 0x5c, 0x1d, 0x21, 0xbd, 0x37, 0x63, 0x88,
49 0xb5, 0xf7, 0x23, 0xfb, 0x4c, 0x22, 0xdf, 0xe6,
50 0xcd, 0x43, 0x75, 0xa0, 0x5a, 0x07, 0x47, 0x64,
51 0x44, 0xd5, 0x81, 0x99, 0x85, 0x00, 0x7e, 0x34
52 },
53 },
54 {
55 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
56 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
57 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
58 0x00, 0x00, 0x00, 0x02, },
59
60 {0x70, 0x6a, 0x46, 0xdc, 0x76, 0xdc, 0xb7, 0x67,
61 0x98, 0xe6, 0x0e, 0x6d, 0x89, 0x47, 0x47, 0x88,
62 0xd1, 0x6d, 0xc1, 0x80, 0x32, 0xd2, 0x68, 0xfd,
63 0x1a, 0x70, 0x4f, 0xa6, 0x1c, 0x2b, 0x76, 0xa7,
64 0xbc, 0x25, 0xe7, 0x70, 0x2a, 0x70, 0x4f, 0xa9,
65 0x86, 0x89, 0x28, 0x49, 0xfc, 0xa6, 0x29, 0x48,
66 0x7a, 0xcf, 0x37, 0x09, 0xd2, 0xe4, 0xe8, 0xbb,
67 },
68 },
69 {
70 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
71 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
72 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
73 0x00, 0x00, 0x00, 0x03, },
74 {0xdf, 0x1b, 0x1d, 0x66, 0xa5, 0x51, 0xd0, 0xd3,
75 0x1e, 0xff, 0x82, 0x25, 0x58, 0xb9, 0xd2, 0xcc,
76 0x75, 0xc2, 0x18, 0x02, 0x79, 0xfe, 0x0d, 0x08,
77 0xfd, 0x89, 0x6d, 0x04, 0xa3, 0xf7, 0xf0, 0x3c,
78 0xad, 0xd0, 0xbe, 0x44, 0x4c, 0x0a, 0xa5, 0x68,
79 0x30, 0x13, 0x0d, 0xdf, 0x77, 0xd3, 0x17, 0x34,
80 0x4e, 0x1a, 0xf3, 0x59, 0x19, 0x81, 0xa9, 0x25,
81 },
82 },
83 {
84 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
85 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
86 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
87 0x00, 0x00, 0x00, 0x04, },
88 {0xae, 0x99, 0xfe, 0xeb, 0xb5, 0xd2, 0x69, 0x45,
89 0xb5, 0x48, 0x92, 0x09, 0x2a, 0x8a, 0xee, 0x02,
90 0x91, 0x29, 0x30, 0xfa, 0x41, 0xcd, 0x11, 0x4e,
91 0x40, 0x44, 0x73, 0x01, 0x04, 0x82, 0x58, 0x0a,
92 0x0e, 0xc5, 0xbc, 0x47, 0xe8, 0x8b, 0xc8, 0xc3,
93 0x78, 0x63, 0x2c, 0xd1, 0x96, 0xcb, 0x3f, 0xa0,
94 0x58, 0xa7, 0x11, 0x4e, 0xb0, 0x30, 0x54, 0xc9,
95 },
96 },
97 {
98 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
99 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
100 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
101 0x00, 0x00, 0x00, 0x05, },
102 {0x31, 0xc4, 0x9a, 0xe7, 0x5b, 0xce, 0x78, 0x07,
103 0xcd, 0xff, 0x22, 0x05, 0x5d, 0x94, 0xee, 0x90,
104 0x21, 0xfe, 0xdb, 0xb5, 0xab, 0x51, 0xc5, 0x75,
105 0x26, 0xf0, 0x11, 0xaa, 0x27, 0xe8, 0xbf, 0xf1,
106 0x74, 0x56, 0x35, 0xec, 0x5b, 0xa0, 0xc9, 0xf1,
107 0xc2, 0xed, 0xe1, 0x54, 0x14, 0xc6, 0x50, 0x7d,
108 0x29, 0xff, 0xe3, 0x7e, 0x79, 0x0a, 0x07, 0x9b,
109 },
110 },
111 {
112 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
113 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
114 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
115 0x00, 0x00, 0x00, 0x06, },
116 {0x1f, 0x24, 0x83, 0xf8, 0x25, 0x72, 0x25, 0x1f,
117 0xca, 0x97, 0x5f, 0xea, 0x40, 0xdb, 0x82, 0x1d,
118 0xf8, 0xad, 0x82, 0xa3, 0xc0, 0x02, 0xee, 0x6c,
119 0x57, 0x11, 0x24, 0x08, 0x89, 0xfa, 0xf0, 0xcc,
120 0xb7, 0x50, 0xd9, 0x9b, 0x55, 0x3c, 0x57, 0x4f,
121 0xad, 0x7e, 0xcf, 0xb0, 0x43, 0x85, 0x86, 0xeb,
122 0x39, 0x52, 0xaf, 0x5b, 0x4b, 0x15, 0x3c, 0x7e,
123 },
124 },
125 {
126 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
127 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
128 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
129 0x00, 0x00, 0x00, 0x07, },
130 {0xdb, 0x2f, 0x6b, 0xe6, 0x30, 0xe2, 0x46, 0xa5,
131 0xcf, 0x7d, 0x99, 0xb8, 0x51, 0x94, 0xb1, 0x23,
132 0xd4, 0x87, 0xe2, 0xd4, 0x66, 0xb9, 0x4b, 0x24,
133 0xa0, 0x3c, 0x3e, 0x28, 0x0f, 0x3a, 0x30, 0x08,
134 0x54, 0x97, 0xf2, 0xf6, 0x11, 0xee, 0x25, 0x17,
135 0xb1, 0x63, 0xef, 0x8c, 0x53, 0xb7, 0x15, 0xd1,
136 0x8b, 0xb4, 0xe4, 0x80, 0x8d, 0x02, 0xb9, 0x63,
137 },
138 },
139 {
140 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
141 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
142 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
143 0x00, 0x00, 0x00, 0x08, },
144 {0x85, 0x8e, 0x6f, 0x9c, 0xc6, 0xc1, 0x2c, 0x31,
145 0xf5, 0xdf, 0x12, 0x4a, 0xa7, 0x77, 0x67, 0xb0,
146 0x5c, 0x8b, 0xc0, 0x21, 0xbd, 0x68, 0x3d, 0x2b,
147 0x55, 0x57, 0x15, 0x50, 0x04, 0x6d, 0xcd, 0x3e,
148 0xa5, 0xc4, 0x38, 0x98, 0xc5, 0xc5, 0xfc, 0x4f,
149 0xda, 0xc7, 0xdb, 0x39, 0xc2, 0xf0, 0x2e, 0xbe,
150 0xe4, 0xe3, 0x54, 0x1d, 0x1e, 0x78, 0x04, 0x7a,
151 },
152 },
153 {
154 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
155 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
156 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
157 0x00, 0x00, 0x00, 0x09, },
158 {0x2f, 0xdc, 0xcc, 0xfe, 0xe7, 0x20, 0xa7, 0x7e,
159 0xf6, 0xcb, 0x3b, 0xfb, 0xb4, 0x47, 0xf9, 0x38,
160 0x31, 0x17, 0xe3, 0xda, 0xa4, 0xa0, 0x7e, 0x36,
161 0xed, 0x15, 0xf7, 0x8d, 0x37, 0x17, 0x32, 0xe4,
162 0xf4, 0x1b, 0xf4, 0xf7, 0x88, 0x30, 0x35, 0xe6,
163 0xa7, 0x9f, 0xce, 0xdc, 0x0e, 0x19, 0x6e, 0xb0,
164 0x7b, 0x48, 0x17, 0x16, 0x97, 0x51, 0x74, 0x63,
165 },
166 },
167 {
168 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
169 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
170 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
171 0x00, 0x00, 0x00, 0x0a, },
172 {0xae, 0xa9, 0xe1, 0x7a, 0x30, 0x65, 0x17, 0xeb,
173 0x89, 0x15, 0x2a, 0xa7, 0x09, 0x6d, 0x2c, 0x38,
174 0x1e, 0xc8, 0x13, 0xc5, 0x1a, 0xa8, 0x80, 0xe7,
175 0xbe, 0xe2, 0xc0, 0xfd, 0x39, 0xbb, 0x30, 0xea,
176 0xb3, 0x37, 0xe0, 0xa5, 0x21, 0xb6, 0xcb, 0xa1,
177 0xab, 0xe4, 0xb2, 0xb3, 0xa3, 0xe5, 0x24, 0xc1,
178 0x4a, 0x3f, 0xe3, 0xeb, 0x11, 0x6b, 0x65, 0x5f,
179 },
180 },
181 {
182 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
183 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
184 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
185 0x00, 0x00, 0x00, 0x0b, },
186 {0xef, 0x53, 0xb6, 0x29, 0x4a, 0xca, 0x43, 0x1f,
187 0x0f, 0x3c, 0x22, 0xdc, 0x82, 0xeb, 0x90, 0x50,
188 0x32, 0x4f, 0x1d, 0x88, 0xd3, 0x77, 0xe7, 0x16,
189 0x44, 0x8e, 0x50, 0x7c, 0x20, 0xb5, 0x10, 0x00,
190 0x40, 0x92, 0xe9, 0x66, 0x36, 0xcf, 0xb7, 0xe3,
191 0x2e, 0xfd, 0xed, 0x82, 0x65, 0xc2, 0x66, 0xdf,
192 0xb7, 0x54, 0xfa, 0x6d, 0x64, 0x91, 0xa6, 0xda,
193 },
194 },
195 {
196 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
197 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
198 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
199 0x00, 0x00, 0x00, 0x0c, },
200 {0x6e, 0x31, 0xee, 0x1d, 0xc1, 0x37, 0xf8, 0x1b,
201 0x05, 0x67, 0x52, 0xe4, 0xde, 0xab, 0x14, 0x43,
202 0xa4, 0x81, 0x03, 0x3e, 0x9b, 0x4c, 0x93, 0xa3,
203 0x04, 0x4f, 0x4f, 0x7a, 0x20, 0x7d, 0xdd, 0xf0,
204 0x38, 0x5b, 0xfd, 0xea, 0xb6, 0xe9, 0xac, 0xda,
205 0x8d, 0xa0, 0x6b, 0x3b, 0xbe, 0xf2, 0x24, 0xa9,
206 0x3a, 0xb1, 0xe9, 0xe0, 0x36, 0x10, 0x9d, 0x13,
207 },
208 },
209 {
210 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
211 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
212 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
213 0x00, 0x00, 0x00, 0x0d, },
214 {0x34, 0xe8, 0xe1, 0x7a, 0x43, 0x0e, 0x43, 0x28,
215 0x97, 0x93, 0xc3, 0x83, 0xfa, 0xc9, 0x77, 0x42,
216 0x47, 0xb4, 0x0e, 0x9e, 0xbd, 0x33, 0x66, 0x98,
217 0x1f, 0xcf, 0xae, 0xca, 0x25, 0x28, 0x19, 0xf7,
218 0x1c, 0x7f, 0xb7, 0xfb, 0xcb, 0x15, 0x9b, 0xe3,
219 0x37, 0xd3, 0x7d, 0x33, 0x36, 0xd7, 0xfe, 0xb9,
220 0x63, 0x72, 0x4f, 0xdf, 0xb0, 0xec, 0xb7, 0x67,
221 },
222 },
223 {
224 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
225 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
226 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
227 0x00, 0x00, 0x00, 0x0e, },
228 {0xa5, 0x36, 0x40, 0xc8, 0x3d, 0xc2, 0x08, 0x60,
229 0x3d, 0xed, 0x83, 0xe4, 0xec, 0xf7, 0x58, 0xf2,
230 0x4c, 0x35, 0x7d, 0x7c, 0xf4, 0x80, 0x88, 0xb2,
231 0xce, 0x01, 0xe9, 0xfa, 0xd5, 0x81, 0x4c, 0xd7,
232 0x24, 0x19, 0x9c, 0x4a, 0x5b, 0x97, 0x4a, 0x43,
233 0x68, 0x5f, 0xbf, 0x5b, 0x8b, 0xac, 0x69, 0x45,
234 0x9c, 0x94, 0x69, 0xbc, 0x8f, 0x23, 0xcc, 0xaf,
235 },
236 },
237 {
238 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
239 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
240 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
241 0x00, 0x00, 0x00, 0x0f, },
242 {0xba, 0xa4, 0xd8, 0x63, 0x55, 0x11, 0xa7, 0xd2,
243 0x88, 0xae, 0xbe, 0xed, 0xd1, 0x2c, 0xe5, 0x29,
244 0xff, 0x10, 0x2c, 0x91, 0xf9, 0x7f, 0x86, 0x7e,
245 0x21, 0x91, 0x6b, 0xf9, 0x97, 0x9a, 0x5f, 0x47,
246 0x59, 0xf8, 0x0f, 0x4f, 0xb4, 0xec, 0x2e, 0x34,
247 0xf5, 0x56, 0x6d, 0x59, 0x56, 0x80, 0xa1, 0x17,
248 0x35, 0xe7, 0xb6, 0x10, 0x46, 0x12, 0x79, 0x89,
249 },
250 },
251 {
252 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
253 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
254 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
255 0x00, 0x00, 0x00, 0x10, },
256 {0x0b, 0x6e, 0xc4, 0xfe, 0x17, 0x77, 0x38, 0x24,
257 0x04, 0xef, 0x67, 0x99, 0x97, 0xba, 0x8d, 0x1c,
258 0xc5, 0xcd, 0x8e, 0x85, 0x34, 0x92, 0x59, 0xf5,
259 0x90, 0xc4, 0xc6, 0x6d, 0x33, 0x99, 0xd4, 0x64,
260 0x34, 0x59, 0x06, 0xb1, 0x1b, 0x00, 0xe3, 0x63,
261 0xef, 0x42, 0x92, 0x21, 0xf2, 0xec, 0x72, 0x0d,
262 0x2f, 0x66, 0x5d, 0x7d, 0xea, 0xd5, 0xb4, 0x82,
263 },
264 },
265 {
266 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
267 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
268 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
269 0x00, 0x00, 0x00, 0x11, },
270 {0xb8, 0x35, 0x7c, 0x3a, 0x6c, 0xee, 0xf2, 0x88,
271 0x31, 0x0e, 0x17, 0xb8, 0xbf, 0xef, 0xf9, 0x20,
272 0x08, 0x46, 0xca, 0x8c, 0x19, 0x42, 0x49, 0x7c,
273 0x48, 0x44, 0x03, 0xbc, 0xff, 0x14, 0x9e, 0xfa,
274 0x66, 0x06, 0xa6, 0xbd, 0x20, 0xef, 0x7d, 0x1b,
275 0x06, 0xbd, 0x92, 0xf6, 0x90, 0x46, 0x39, 0xdc,
276 0xe5, 0x17, 0x4d, 0xb6, 0xcc, 0x55, 0x4a, 0x26,
277 },
278 },
279 {
280 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
281 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
282 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
283 0x00, 0x00, 0x00, 0x12, },
284 {0xc9, 0xff, 0x61, 0xb0, 0x40, 0x87, 0x4c, 0x05,
285 0x68, 0x47, 0x92, 0x16, 0x82, 0x4a, 0x15, 0xea,
286 0xb1, 0xa8, 0x38, 0xa7, 0x97, 0xd1, 0x89, 0x74,
287 0x62, 0x26, 0xe4, 0xcc, 0xea, 0x98, 0xd6, 0x0e,
288 0x5f, 0xfc, 0x9b, 0x8f, 0xcf, 0x99, 0x9f, 0xab,
289 0x1d, 0xf7, 0xe7, 0xef, 0x70, 0x84, 0xf2, 0x0d,
290 0xdb, 0x61, 0xbb, 0x04, 0x5a, 0x6c, 0xe0, 0x02,
291 },
292 },
293 {
294 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
295 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
296 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
297 0x00, 0x00, 0x00, 0x13, },
298 {0xa1, 0xe8, 0x1c, 0x04, 0xf3, 0x0c, 0xe2, 0x01,
299 0xc7, 0xc9, 0xac, 0xe7, 0x85, 0xed, 0x44, 0xcc,
300 0x33, 0xb4, 0x55, 0xa0, 0x22, 0xf2, 0xac, 0xdb,
301 0xc6, 0xca, 0xe8, 0x3c, 0xdc, 0xf1, 0xf6, 0xc3,
302 0xdb, 0x09, 0xc7, 0x0a, 0xcc, 0x25, 0x39, 0x1d,
303 0x49, 0x2f, 0xe2, 0x5b, 0x4a, 0x18, 0x0b, 0xab,
304 0xd6, 0xce, 0xa3, 0x56, 0xc0, 0x47, 0x19, 0xcd,
305 },
306 },
307 {
308 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
309 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
310 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
311 0x00, 0x00, 0x00, 0x14, },
312 {0xfc, 0xc7, 0xf2, 0xb4, 0x5d, 0xf1, 0xcd, 0x5a,
313 0x3c, 0x0c, 0x07, 0x31, 0xca, 0x47, 0xa8, 0xaf,
314 0x75, 0xcf, 0xb0, 0x34, 0x7e, 0x83, 0x54, 0xee,
315 0xfe, 0x78, 0x24, 0x55, 0x0d, 0x5d, 0x71, 0x10,
316 0x27, 0x4c, 0xba, 0x7c, 0xde, 0xe9, 0x0e, 0x1a,
317 0x8b, 0x0d, 0x39, 0x4c, 0x37, 0x6a, 0x55, 0x73,
318 0xdb, 0x6b, 0xe0, 0xbf, 0x27, 0x47, 0xf5, 0x30,
319 },
320 },
321 {
322 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
323 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
324 0x00, 0x00, 0x00, 0x00, 0x01, 0x8e, 0xbb, 0xb9,
325 0x5e, 0xed, 0x0e, 0x13, },
326 {0x61, 0xf0, 0x77, 0xc6, 0xf6, 0x2e, 0xd8, 0x02,
327 0xda, 0xd7, 0xc2, 0xf3, 0x8f, 0x5c, 0x67, 0xf2,
328 0xcc, 0x45, 0x36, 0x01, 0xe6, 0x1b, 0xd0, 0x76,
329 0xbb, 0x46, 0x17, 0x9e, 0x22, 0x72, 0xf9, 0xe9,
330 0xf5, 0x93, 0x3e, 0x70, 0x38, 0x8e, 0xe6, 0x52,
331 0x51, 0x34, 0x43, 0xb5, 0xe2, 0x89, 0xdd, 0x13,
332 0x5d, 0xcc, 0x0d, 0x02, 0x99, 0xb2, 0x25, 0xe4,
333 },
334 },
335 {
336 {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
337 0x00, 0x00, 0x00, 0x00, 0x00, 0x15, 0x9d, 0x89,
338 0x3d, 0x4c, 0xdd, 0x74, 0x72, 0x46, 0xcd, 0xca,
339 0x43, 0x59, 0x0e, 0x13, },
340 {0x02, 0x98, 0x95, 0xf0, 0xaf, 0x49, 0x6b, 0xfc,
341 0x62, 0xb6, 0xef, 0x8d, 0x8a, 0x65, 0xc8, 0x8c,
342 0x61, 0x39, 0x49, 0xb0, 0x36, 0x68, 0xaa, 0xb4,
343 0xf0, 0x42, 0x9e, 0x35, 0x3e, 0xa6, 0xe5, 0x3f,
344 0x9a, 0x84, 0x1f, 0x20, 0x19, 0xec, 0x24, 0xbd,
345 0xe1, 0xa7, 0x56, 0x77, 0xaa, 0x9b, 0x59, 0x02,
346 0xe6, 0x10, 0x81, 0xc0, 0x10, 0x64, 0xde, 0x93,
347 },
348 },
349 {
350 {0x41, 0xff, 0xc1, 0xff, 0xff, 0xfe, 0x01, 0xff,
351 0xfc, 0x00, 0x03, 0xff, 0xfe, 0x00, 0x07, 0xc0,
352 0x01, 0xff, 0xf0, 0x00, 0x03, 0xff, 0xf0, 0x7f,
353 0xfe, 0x00, 0x07, 0xc0, },
354 {0xab, 0x68, 0x99, 0x30, 0xbc, 0xae, 0x4a, 0x4a,
355 0xa5, 0xf5, 0xcb, 0x08, 0x5e, 0x82, 0x3e, 0x8a,
356 0xe3, 0x0f, 0xd3, 0x65, 0xeb, 0x1d, 0xa4, 0xab,
357 0xa9, 0xcf, 0x03, 0x79, 0x33, 0x45, 0xa1, 0x21,
358 0xbb, 0xd2, 0x33, 0x54, 0x8a, 0xf0, 0xd2, 0x10,
359 0x65, 0x4e, 0xb4, 0x0b, 0xab, 0x78, 0x8a, 0x03,
360 0x66, 0x64, 0x19, 0xbe, 0x6f, 0xbd, 0x34, 0xe7,
361 },
362 },
363 {
364 {0x7f, 0xff, 0xff, 0xc0, 0x3f, 0xff, 0xc0, 0x03,
365 0xff, 0xff, 0xfc, 0x00, 0x7f, 0xff, 0x00, 0x00,
366 0x00, 0x00, 0x07, 0x00, 0x00, 0x10, 0x00, 0x00,
367 0x00, 0x0e, 0x00, 0xff, },
368 {0xbd, 0xb6, 0xa8, 0x81, 0x7c, 0x1f, 0x89, 0xda,
369 0x1c, 0x2f, 0x3d, 0xd8, 0xe9, 0x7f, 0xeb, 0x44,
370 0x94, 0xf2, 0xed, 0x30, 0x2a, 0x4c, 0xe2, 0xbc,
371 0x7f, 0x5f, 0x40, 0x25, 0x4c, 0x70, 0x20, 0xd5,
372 0x7c, 0x00, 0x41, 0x18, 0x89, 0x46, 0x2d, 0x77,
373 0xa5, 0x43, 0x8b, 0xb4, 0xe9, 0x7d, 0x17, 0x77,
374 0x00, 0xbf, 0x72, 0x43, 0xa0, 0x7f, 0x16, 0x80,
375 },
376 },
377 {
378 {0x7f, 0xff, 0xff, 0x04, 0x00, 0x00, 0x00, 0x00,
379 0xff, 0xff, 0xf0, 0x1f, 0xff, 0xf8, 0xff, 0xff,
380 0xc0, 0x0f, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00,
381 0x00, 0x0f, 0xff, 0xff, },
382 {0xd5, 0x8b, 0x61, 0xaa, 0x41, 0xc3, 0x2d, 0xd5,
383 0xeb, 0xa4, 0x62, 0x64, 0x7d, 0xba, 0x75, 0xc5,
384 0xd6, 0x7c, 0x83, 0x60, 0x6c, 0x0a, 0xf2, 0xbd,
385 0x92, 0x84, 0x46, 0xa9, 0xd2, 0x4b, 0xa6, 0xa8,
386 0x37, 0xbe, 0x04, 0x60, 0xdd, 0x10, 0x7a, 0xe7,
387 0x77, 0x25, 0x69, 0x6d, 0x21, 0x14, 0x46, 0xc5,
388 0x60, 0x9b, 0x45, 0x95, 0x97, 0x6b, 0x16, 0xbd,
389 },
390 },
391 {
392 {0x7f, 0xff, 0xff, 0xc0, 0x00, 0xff, 0xfe, 0x3f,
393 0xff, 0xfc, 0x10, 0x00, 0x00, 0x20, 0x00, 0x3f,
394 0xff, 0xff, 0x00, 0x00, 0x00, 0xfc, 0x00, 0x00,
395 0x3f, 0xff, 0xff, 0xff, },
396 {0xdc, 0x9f, 0xa7, 0x79, 0x78, 0xa0, 0x05, 0x51,
397 0x09, 0x80, 0xe9, 0x29, 0xa1, 0x48, 0x5f, 0x63,
398 0x71, 0x6d, 0xf6, 0x95, 0xd7, 0xa0, 0xc1, 0x8b,
399 0xb5, 0x18, 0xdf, 0x03, 0xed, 0xe2, 0xb0, 0x16,
400 0xf2, 0xdd, 0xff, 0xc2, 0xa8, 0xc0, 0x15, 0xb1,
401 0x34, 0x92, 0x82, 0x75, 0xce, 0x09, 0xe5, 0x66,
402 0x1b, 0x7a, 0xb1, 0x4c, 0xe0, 0xd1, 0xd4, 0x03,
403 },
404 },
405 {
406 {0x70, 0x01, 0xf0, 0x00, 0x1c, 0x00, 0x01, 0xc0,
407 0x00, 0x00, 0x1f, 0xff, 0xff, 0xfc, 0x00, 0x00,
408 0x1f, 0xff, 0xff, 0xf8, 0x00, 0x0f, 0xc0, 0x00,
409 0x00, 0x01, 0xfc, 0x00, },
410 {0x49, 0x9d, 0x8b, 0x28, 0x29, 0xcf, 0xb8, 0x79,
411 0xc9, 0x01, 0xf7, 0xd8, 0x5d, 0x35, 0x70, 0x45,
412 0xed, 0xab, 0x55, 0x02, 0x88, 0x24, 0xd0, 0xf0,
413 0x5b, 0xa2, 0x79, 0xba, 0xbf, 0x92, 0x95, 0x37,
414 0xb0, 0x6e, 0x40, 0x15, 0x91, 0x96, 0x39, 0xd9,
415 0x4f, 0x57, 0x83, 0x8f, 0xa3, 0x3f, 0xc3, 0xd9,
416 0x52, 0x59, 0x8d, 0xcd, 0xbb, 0x44, 0xd6, 0x38,
417 },
418 },
419 {
420 {0x00, 0x00, 0x00, 0x00, 0x1f, 0xfc, 0x00, 0x00,
421 0x00, 0xff, 0xf0, 0x30, 0x00, 0x1f, 0x00, 0x00,
422 0xff, 0xff, 0xf0, 0x00, 0x00, 0x38, 0x00, 0x00,
423 0x00, 0x00, 0x00, 0x02, },
424 {0x82, 0x46, 0xc9, 0x99, 0x13, 0x71, 0x86, 0x63,
425 0x2c, 0x5f, 0x9e, 0xdd, 0xf3, 0xb1, 0xb0, 0xe1,
426 0x76, 0x4c, 0x5e, 0x8b, 0xd0, 0xe0, 0xd8, 0xa5,
427 0x54, 0xb9, 0xcb, 0x77, 0xe8, 0x0e, 0xd8, 0x66,
428 0x0b, 0xc1, 0xcb, 0x17, 0xac, 0x7d, 0x84, 0x5b,
429 0xe4, 0x0a, 0x7a, 0x02, 0x2d, 0x33, 0x06, 0xf1,
430 0x16, 0xae, 0x9f, 0x81, 0xfe, 0xa6, 0x59, 0x47,
431 },
432 },
433 {
434 {0x7f, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
435 0x07, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
436 0x00, 0x00, 0xff, 0xfe, 0x08, 0x00, 0x00, 0x1f,
437 0xf0, 0x00, 0x1f, 0xff, },
438 {0x66, 0x70, 0xc2, 0x0a, 0xfc, 0xce, 0xae, 0xa6,
439 0x72, 0xc9, 0x7f, 0x75, 0xe2, 0xe9, 0xdd, 0x5c,
440 0x84, 0x60, 0xe5, 0x4b, 0xb3, 0x85, 0x38, 0xeb,
441 0xb4, 0xbd, 0x30, 0xeb, 0xf2, 0x80, 0xd8, 0x00,
442 0x8d, 0x07, 0xa4, 0xca, 0xf5, 0x42, 0x71, 0xf9,
443 0x93, 0x52, 0x7d, 0x46, 0xff, 0x3f, 0xf4, 0x6f,
444 0xd1, 0x19, 0x0a, 0x3f, 0x1f, 0xaa, 0x4f, 0x74,
445 },
446 },
447 {
448 {0x00, 0x00, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff,
449 0xff, 0xc0, 0x00, 0x07, 0xff, 0xff, 0xe0, 0xff,
450 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0xff,
451 0xff, 0xff, 0xff, 0xff, },
452 {0x00, 0x0e, 0xca, 0x93, 0x42, 0x47, 0x42, 0x5c,
453 0xfd, 0x94, 0x9b, 0x79, 0x5c, 0xb5, 0xce, 0x1e,
454 0xff, 0x40, 0x15, 0x50, 0x38, 0x6e, 0x28, 0xd1,
455 0xa4, 0xc5, 0xa8, 0xeb, 0xd4, 0xc0, 0x10, 0x40,
456 0xdb, 0xa1, 0x96, 0x28, 0x93, 0x1b, 0xc8, 0x85,
457 0x53, 0x70, 0x31, 0x7c, 0x72, 0x2c, 0xbd, 0x9c,
458 0xa6, 0x15, 0x69, 0x85, 0xf1, 0xc2, 0xe9, 0xce,
459 },
460 },
461 {
462 {0x7f, 0xff, 0xfc, 0x03, 0xff, 0x80, 0x7f, 0xff,
463 0xe0, 0x00, 0x1f, 0xff, 0xff, 0x80, 0x0f, 0xff,
464 0x80, 0x00, 0x01, 0xff, 0xff, 0x00, 0x01, 0xff,
465 0xff, 0xfe, 0x00, 0x1f, },
466 {0xef, 0x35, 0x3b, 0xf5, 0xc7, 0x3c, 0xd5, 0x51,
467 0xb9, 0x6d, 0x59, 0x6f, 0xbc, 0x9a, 0x67, 0xf1,
468 0x6d, 0x61, 0xdd, 0x9f, 0xe5, 0x6a, 0xf1, 0x9d,
469 0xe1, 0xfb, 0xa9, 0xcd, 0x21, 0x77, 0x1b, 0x9c,
470 0xdc, 0xe3, 0xe8, 0x43, 0x0c, 0x09, 0xb3, 0x83,
471 0x8b, 0xe7, 0x0b, 0x48, 0xc2, 0x1e, 0x15, 0xbc,
472 0x09, 0xee, 0x1f, 0x2d, 0x79, 0x45, 0xb9, 0x1f,
473 },
474 },
475 {
476 {0x00, 0x00, 0x00, 0x07, 0xff, 0xc0, 0x7f, 0xff,
477 0xff, 0xff, 0x01, 0xff, 0xfe, 0x03, 0xff, 0xfe,
478 0x40, 0x00, 0x38, 0x00, 0x07, 0xe0, 0x00, 0x3f,
479 0xfe, 0x00, 0x00, 0x00, },
480 {0x40, 0x36, 0x05, 0x2a, 0x30, 0x91, 0xeb, 0x48,
481 0x10, 0x46, 0xad, 0x32, 0x89, 0xc9, 0x5d, 0x3a,
482 0xc9, 0x05, 0xca, 0x00, 0x23, 0xde, 0x2c, 0x03,
483 0xec, 0xd4, 0x51, 0xcf, 0xd7, 0x68, 0x16, 0x5a,
484 0x38, 0xa2, 0xb9, 0x6f, 0x81, 0x25, 0x86, 0xa9,
485 0xd5, 0x9d, 0x41, 0x36, 0x03, 0x5d, 0x9c, 0x85,
486 0x3a, 0x5b, 0xf2, 0xe1, 0xc8, 0x6a, 0x49, 0x93,
487 },
488 },
489 {
490 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
491 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
492 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
493 0x5c, 0x5c, 0x2a, 0x29, },
494 {0xfc, 0xc7, 0xf2, 0xb4, 0x5d, 0xf1, 0xcd, 0x5a,
495 0x3c, 0x0c, 0x07, 0x31, 0xca, 0x47, 0xa8, 0xaf,
496 0x75, 0xcf, 0xb0, 0x34, 0x7e, 0x83, 0x54, 0xee,
497 0xfe, 0x78, 0x24, 0x55, 0xf2, 0xa2, 0x8e, 0xef,
498 0xd8, 0xb3, 0x45, 0x83, 0x21, 0x16, 0xf1, 0xe5,
499 0x74, 0xf2, 0xc6, 0xb2, 0xc8, 0x95, 0xaa, 0x8c,
500 0x24, 0x94, 0x1f, 0x40, 0xd8, 0xb8, 0x0a, 0xd1,
501 },
502 },
503 {
504 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
505 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
506 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
507 0x5c, 0x5c, 0x2a, 0x2a, },
508 {0xa1, 0xe8, 0x1c, 0x04, 0xf3, 0x0c, 0xe2, 0x01,
509 0xc7, 0xc9, 0xac, 0xe7, 0x85, 0xed, 0x44, 0xcc,
510 0x33, 0xb4, 0x55, 0xa0, 0x22, 0xf2, 0xac, 0xdb,
511 0xc6, 0xca, 0xe8, 0x3c, 0x23, 0x0e, 0x09, 0x3c,
512 0x24, 0xf6, 0x38, 0xf5, 0x33, 0xda, 0xc6, 0xe2,
513 0xb6, 0xd0, 0x1d, 0xa3, 0xb5, 0xe7, 0xf4, 0x54,
514 0x29, 0x31, 0x5c, 0xa9, 0x3f, 0xb8, 0xe6, 0x34,
515 },
516 },
517 {
518 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
519 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
520 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
521 0x5c, 0x5c, 0x2a, 0x2b, },
522 {0xc9, 0xff, 0x61, 0xb0, 0x40, 0x87, 0x4c, 0x05,
523 0x68, 0x47, 0x92, 0x16, 0x82, 0x4a, 0x15, 0xea,
524 0xb1, 0xa8, 0x38, 0xa7, 0x97, 0xd1, 0x89, 0x74,
525 0x62, 0x26, 0xe4, 0xcc, 0x15, 0x67, 0x29, 0xf1,
526 0xa0, 0x03, 0x64, 0x70, 0x30, 0x66, 0x60, 0x54,
527 0xe2, 0x08, 0x18, 0x0f, 0x8f, 0x7b, 0x0d, 0xf2,
528 0x24, 0x9e, 0x44, 0xfb, 0xa5, 0x93, 0x1f, 0xff,
529 },
530 },
531 {
532 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
533 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
534 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
535 0x5c, 0x5c, 0x2a, 0x2c, },
536 {0xb8, 0x35, 0x7c, 0x3a, 0x6c, 0xee, 0xf2, 0x88,
537 0x31, 0x0e, 0x17, 0xb8, 0xbf, 0xef, 0xf9, 0x20,
538 0x08, 0x46, 0xca, 0x8c, 0x19, 0x42, 0x49, 0x7c,
539 0x48, 0x44, 0x03, 0xbc, 0x00, 0xeb, 0x61, 0x05,
540 0x99, 0xf9, 0x59, 0x42, 0xdf, 0x10, 0x82, 0xe4,
541 0xf9, 0x42, 0x6d, 0x08, 0x6f, 0xb9, 0xc6, 0x23,
542 0x1a, 0xe8, 0xb2, 0x49, 0x33, 0xaa, 0xb5, 0xdb,
543 },
544 },
545 {
546 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
547 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
548 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
549 0x5c, 0x5c, 0x2a, 0x2d, },
550 {0x0b, 0x6e, 0xc4, 0xfe, 0x17, 0x77, 0x38, 0x24,
551 0x04, 0xef, 0x67, 0x99, 0x97, 0xba, 0x8d, 0x1c,
552 0xc5, 0xcd, 0x8e, 0x85, 0x34, 0x92, 0x59, 0xf5,
553 0x90, 0xc4, 0xc6, 0x6d, 0xcc, 0x66, 0x2b, 0x9b,
554 0xcb, 0xa6, 0xf9, 0x4e, 0xe4, 0xff, 0x1c, 0x9c,
555 0x10, 0xbd, 0x6d, 0xdd, 0x0d, 0x13, 0x8d, 0xf2,
556 0xd0, 0x99, 0xa2, 0x82, 0x15, 0x2a, 0x4b, 0x7f,
557 },
558 },
559 {
560 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
561 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
562 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
563 0x5c, 0x5c, 0x2a, 0x2e, },
564 {0xba, 0xa4, 0xd8, 0x63, 0x55, 0x11, 0xa7, 0xd2,
565 0x88, 0xae, 0xbe, 0xed, 0xd1, 0x2c, 0xe5, 0x29,
566 0xff, 0x10, 0x2c, 0x91, 0xf9, 0x7f, 0x86, 0x7e,
567 0x21, 0x91, 0x6b, 0xf9, 0x68, 0x65, 0xa0, 0xb8,
568 0xa6, 0x07, 0xf0, 0xb0, 0x4b, 0x13, 0xd1, 0xcb,
569 0x0a, 0xa9, 0x92, 0xa5, 0xa9, 0x7f, 0x5e, 0xe8,
570 0xca, 0x18, 0x49, 0xef, 0xb9, 0xed, 0x86, 0x78,
571 },
572 },
573 {
574 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
575 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
576 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
577 0x5c, 0x5c, 0x2a, 0x2f, },
578 {0xa5, 0x36, 0x40, 0xc8, 0x3d, 0xc2, 0x08, 0x60,
579 0x3d, 0xed, 0x83, 0xe4, 0xec, 0xf7, 0x58, 0xf2,
580 0x4c, 0x35, 0x7d, 0x7c, 0xf4, 0x80, 0x88, 0xb2,
581 0xce, 0x01, 0xe9, 0xfa, 0x2a, 0x7e, 0xb3, 0x28,
582 0xdb, 0xe6, 0x63, 0xb5, 0xa4, 0x68, 0xb5, 0xbc,
583 0x97, 0xa0, 0x40, 0xa3, 0x74, 0x53, 0x96, 0xba,
584 0x63, 0x6b, 0x96, 0x43, 0x70, 0xdc, 0x33, 0x52,
585 },
586 },
587 {
588 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
589 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
590 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
591 0x5c, 0x5c, 0x2a, 0x30, },
592 {0x34, 0xe8, 0xe1, 0x7a, 0x43, 0x0e, 0x43, 0x28,
593 0x97, 0x93, 0xc3, 0x83, 0xfa, 0xc9, 0x77, 0x42,
594 0x47, 0xb4, 0x0e, 0x9e, 0xbd, 0x33, 0x66, 0x98,
595 0x1f, 0xcf, 0xae, 0xca, 0xda, 0xd7, 0xe6, 0x08,
596 0xe3, 0x80, 0x48, 0x04, 0x34, 0xea, 0x64, 0x1c,
597 0xc8, 0x2c, 0x82, 0xcb, 0xc9, 0x28, 0x01, 0x46,
598 0x9c, 0x8d, 0xb0, 0x20, 0x4f, 0x13, 0x48, 0x9a,
599 },
600 },
601 {
602 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
603 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
604 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
605 0x5c, 0x5c, 0x2a, 0x31, },
606 {0x6e, 0x31, 0xee, 0x1d, 0xc1, 0x37, 0xf8, 0x1b,
607 0x05, 0x67, 0x52, 0xe4, 0xde, 0xab, 0x14, 0x43,
608 0xa4, 0x81, 0x03, 0x3e, 0x9b, 0x4c, 0x93, 0xa3,
609 0x04, 0x4f, 0x4f, 0x7a, 0xdf, 0x82, 0x22, 0x0f,
610 0xc7, 0xa4, 0x02, 0x15, 0x49, 0x16, 0x53, 0x25,
611 0x72, 0x5f, 0x94, 0xc3, 0x41, 0x0d, 0xdb, 0x56,
612 0xc5, 0x4e, 0x16, 0x1f, 0xc9, 0xef, 0x62, 0xee,
613 },
614 },
615 {
616 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
617 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
618 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
619 0x5c, 0x5c, 0x2a, 0x32, },
620 {0xef, 0x53, 0xb6, 0x29, 0x4a, 0xca, 0x43, 0x1f,
621 0x0f, 0x3c, 0x22, 0xdc, 0x82, 0xeb, 0x90, 0x50,
622 0x32, 0x4f, 0x1d, 0x88, 0xd3, 0x77, 0xe7, 0x16,
623 0x44, 0x8e, 0x50, 0x7c, 0xdf, 0x4a, 0xef, 0xff,
624 0xbf, 0x6d, 0x16, 0x99, 0xc9, 0x30, 0x48, 0x1c,
625 0xd1, 0x02, 0x12, 0x7c, 0x9a, 0x3d, 0x99, 0x20,
626 0x48, 0xab, 0x05, 0x92, 0x9b, 0x6e, 0x59, 0x27,
627 },
628 },
629 {
630 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
631 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
632 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
633 0x5c, 0x5c, 0x2a, 0x33, },
634 {0xae, 0xa9, 0xe1, 0x7a, 0x30, 0x65, 0x17, 0xeb,
635 0x89, 0x15, 0x2a, 0xa7, 0x09, 0x6d, 0x2c, 0x38,
636 0x1e, 0xc8, 0x13, 0xc5, 0x1a, 0xa8, 0x80, 0xe7,
637 0xbe, 0xe2, 0xc0, 0xfd, 0xc6, 0x44, 0xcf, 0x15,
638 0x4c, 0xc8, 0x1f, 0x5a, 0xde, 0x49, 0x34, 0x5e,
639 0x54, 0x1b, 0x4d, 0x4b, 0x5c, 0x1a, 0xdb, 0x3e,
640 0xb5, 0xc0, 0x1c, 0x14, 0xee, 0x94, 0x9a, 0xa2,
641 },
642 },
643 {
644 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
645 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
646 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
647 0x5c, 0x5c, 0x2a, 0x34, },
648 {0x2f, 0xdc, 0xcc, 0xfe, 0xe7, 0x20, 0xa7, 0x7e,
649 0xf6, 0xcb, 0x3b, 0xfb, 0xb4, 0x47, 0xf9, 0x38,
650 0x31, 0x17, 0xe3, 0xda, 0xa4, 0xa0, 0x7e, 0x36,
651 0xed, 0x15, 0xf7, 0x8d, 0xc8, 0xe8, 0xcd, 0x1b,
652 0x0b, 0xe4, 0x0b, 0x08, 0x77, 0xcf, 0xca, 0x19,
653 0x58, 0x60, 0x31, 0x22, 0xf1, 0xe6, 0x91, 0x4f,
654 0x84, 0xb7, 0xe8, 0xe9, 0x68, 0xae, 0x8b, 0x9e,
655 },
656 },
657 {
658 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
659 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
660 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
661 0x5c, 0x5c, 0x2a, 0x35, },
662 {0x85, 0x8e, 0x6f, 0x9c, 0xc6, 0xc1, 0x2c, 0x31,
663 0xf5, 0xdf, 0x12, 0x4a, 0xa7, 0x77, 0x67, 0xb0,
664 0x5c, 0x8b, 0xc0, 0x21, 0xbd, 0x68, 0x3d, 0x2b,
665 0x55, 0x57, 0x15, 0x50, 0xfb, 0x92, 0x32, 0xc1,
666 0x5a, 0x3b, 0xc7, 0x67, 0x3a, 0x3a, 0x03, 0xb0,
667 0x25, 0x38, 0x24, 0xc5, 0x3d, 0x0f, 0xd1, 0x41,
668 0x1b, 0x1c, 0xab, 0xe2, 0xe1, 0x87, 0xfb, 0x87,
669 },
670 },
671 {
672 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
673 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
674 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
675 0x5c, 0x5c, 0x2a, 0x36, },
676 {0xdb, 0x2f, 0x6b, 0xe6, 0x30, 0xe2, 0x46, 0xa5,
677 0xcf, 0x7d, 0x99, 0xb8, 0x51, 0x94, 0xb1, 0x23,
678 0xd4, 0x87, 0xe2, 0xd4, 0x66, 0xb9, 0x4b, 0x24,
679 0xa0, 0x3c, 0x3e, 0x28, 0xf0, 0xc5, 0xcf, 0xf7,
680 0xab, 0x68, 0x0d, 0x09, 0xee, 0x11, 0xda, 0xe8,
681 0x4e, 0x9c, 0x10, 0x72, 0xac, 0x48, 0xea, 0x2e,
682 0x74, 0x4b, 0x1b, 0x7f, 0x72, 0xfd, 0x46, 0x9e,
683 },
684 },
685 {
686 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
687 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
688 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
689 0x5c, 0x5c, 0x2a, 0x37, },
690 {0x1f, 0x24, 0x83, 0xf8, 0x25, 0x72, 0x25, 0x1f,
691 0xca, 0x97, 0x5f, 0xea, 0x40, 0xdb, 0x82, 0x1d,
692 0xf8, 0xad, 0x82, 0xa3, 0xc0, 0x02, 0xee, 0x6c,
693 0x57, 0x11, 0x24, 0x08, 0x76, 0x05, 0x0f, 0x33,
694 0x48, 0xaf, 0x26, 0x64, 0xaa, 0xc3, 0xa8, 0xb0,
695 0x52, 0x81, 0x30, 0x4e, 0xbc, 0x7a, 0x79, 0x14,
696 0xc6, 0xad, 0x50, 0xa4, 0xb4, 0xea, 0xc3, 0x83,
697 },
698 },
699 {
700 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
701 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
702 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
703 0x5c, 0x5c, 0x2a, 0x38, },
704 {0x31, 0xc4, 0x9a, 0xe7, 0x5b, 0xce, 0x78, 0x07,
705 0xcd, 0xff, 0x22, 0x05, 0x5d, 0x94, 0xee, 0x90,
706 0x21, 0xfe, 0xdb, 0xb5, 0xab, 0x51, 0xc5, 0x75,
707 0x26, 0xf0, 0x11, 0xaa, 0xd8, 0x17, 0x40, 0x0e,
708 0x8b, 0xa9, 0xca, 0x13, 0xa4, 0x5f, 0x36, 0x0e,
709 0x3d, 0x12, 0x1e, 0xaa, 0xeb, 0x39, 0xaf, 0x82,
710 0xd6, 0x00, 0x1c, 0x81, 0x86, 0xf5, 0xf8, 0x66,
711 },
712 },
713 {
714 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
715 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
716 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
717 0x5c, 0x5c, 0x2a, 0x39, },
718 {0xae, 0x99, 0xfe, 0xeb, 0xb5, 0xd2, 0x69, 0x45,
719 0xb5, 0x48, 0x92, 0x09, 0x2a, 0x8a, 0xee, 0x02,
720 0x91, 0x29, 0x30, 0xfa, 0x41, 0xcd, 0x11, 0x4e,
721 0x40, 0x44, 0x73, 0x01, 0xfb, 0x7d, 0xa7, 0xf5,
722 0xf1, 0x3a, 0x43, 0xb8, 0x17, 0x74, 0x37, 0x3c,
723 0x87, 0x9c, 0xd3, 0x2d, 0x69, 0x34, 0xc0, 0x5f,
724 0xa7, 0x58, 0xee, 0xb1, 0x4f, 0xcf, 0xab, 0x38,
725 },
726 },
727 {
728 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
729 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
730 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
731 0x5c, 0x5c, 0x2a, 0x3a, },
732 {0xdf, 0x1b, 0x1d, 0x66, 0xa5, 0x51, 0xd0, 0xd3,
733 0x1e, 0xff, 0x82, 0x25, 0x58, 0xb9, 0xd2, 0xcc,
734 0x75, 0xc2, 0x18, 0x02, 0x79, 0xfe, 0x0d, 0x08,
735 0xfd, 0x89, 0x6d, 0x04, 0x5c, 0x08, 0x0f, 0xc3,
736 0x52, 0x2f, 0x41, 0xbb, 0xb3, 0xf5, 0x5a, 0x97,
737 0xcf, 0xec, 0xf2, 0x1f, 0x88, 0x2c, 0xe8, 0xcb,
738 0xb1, 0xe5, 0x0c, 0xa6, 0xe6, 0x7e, 0x56, 0xdc,
739 },
740 },
741 {
742 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
743 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
744 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
745 0x5c, 0x5c, 0x2a, 0x3b, },
746 {0x70, 0x6a, 0x46, 0xdc, 0x76, 0xdc, 0xb7, 0x67,
747 0x98, 0xe6, 0x0e, 0x6d, 0x89, 0x47, 0x47, 0x88,
748 0xd1, 0x6d, 0xc1, 0x80, 0x32, 0xd2, 0x68, 0xfd,
749 0x1a, 0x70, 0x4f, 0xa6, 0xe3, 0xd4, 0x89, 0x58,
750 0x43, 0xda, 0x18, 0x8f, 0xd5, 0x8f, 0xb0, 0x56,
751 0x79, 0x76, 0xd7, 0xb5, 0x03, 0x59, 0xd6, 0xb7,
752 0x85, 0x30, 0xc8, 0xf6, 0x2d, 0x1b, 0x17, 0x46,
753 },
754 },
755 {
756 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
757 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x16, 0xa2,
758 0xe0, 0xb8, 0xf0, 0x3e, 0x13, 0xdd, 0x29, 0x45,
759 0x5c, 0x5c, 0x2a, 0x3c, },
760 {0xb7, 0x0e, 0x0c, 0xbd, 0x6b, 0xb4, 0xbf, 0x7f,
761 0x32, 0x13, 0x90, 0xb9, 0x4a, 0x03, 0xc1, 0xd3,
762 0x56, 0xc2, 0x11, 0x22, 0x34, 0x32, 0x80, 0xd6,
763 0x11, 0x5c, 0x1d, 0x21, 0x42, 0xc8, 0x9c, 0x77,
764 0x4a, 0x08, 0xdc, 0x04, 0xb3, 0xdd, 0x20, 0x19,
765 0x32, 0xbc, 0x8a, 0x5e, 0xa5, 0xf8, 0xb8, 0x9b,
766 0xbb, 0x2a, 0x7e, 0x66, 0x7a, 0xff, 0x81, 0xcd,
767 },
768 },
769 };
770
TEST(P224,ExternalToInternalAndBack)771 TEST(P224, ExternalToInternalAndBack) {
772 Point point;
773
774 EXPECT_TRUE(point.SetFromString(base::StringPiece(
775 reinterpret_cast<const char *>(kBasePointExternal),
776 sizeof(kBasePointExternal))));
777
778 const std::string external = point.ToString();
779
780 ASSERT_EQ(external.size(), 56u);
781 EXPECT_TRUE(memcmp(external.data(), kBasePointExternal,
782 sizeof(kBasePointExternal)) == 0);
783 }
784
TEST(P224,ScalarBaseMult)785 TEST(P224, ScalarBaseMult) {
786 Point point;
787
788 for (size_t i = 0; i < arraysize(kNISTTestVectors); i++) {
789 p224::ScalarBaseMult(kNISTTestVectors[i].scalar, &point);
790 const std::string external = point.ToString();
791 ASSERT_EQ(external.size(), 56u);
792 EXPECT_TRUE(memcmp(external.data(), kNISTTestVectors[i].affine,
793 external.size()) == 0);
794 }
795 }
796
TEST(P224,Addition)797 TEST(P224, Addition) {
798 Point a, b, minus_b, sum, a_again;
799
800 ASSERT_TRUE(a.SetFromString(base::StringPiece(
801 reinterpret_cast<const char *>(kNISTTestVectors[10].affine), 56)));
802 ASSERT_TRUE(b.SetFromString(base::StringPiece(
803 reinterpret_cast<const char *>(kNISTTestVectors[11].affine), 56)));
804
805 p224::Negate(b, &minus_b);
806 p224::Add(a, b, &sum);
807 EXPECT_TRUE(memcmp(&sum, &a, sizeof(sum)) != 0);
808 p224::Add(minus_b, sum, &a_again);
809 EXPECT_TRUE(a_again.ToString() == a.ToString());
810 }
811
TEST(P224,Infinity)812 TEST(P224, Infinity) {
813 char zeros[56];
814 memset(zeros, 0, sizeof(zeros));
815
816 // Test that x^0 = ∞.
817 Point a;
818 p224::ScalarBaseMult(reinterpret_cast<const uint8_t*>(zeros), &a);
819 EXPECT_TRUE(memcmp(zeros, a.ToString().data(), sizeof(zeros)) == 0);
820
821 // We shouldn't allow ∞ to be imported.
822 EXPECT_FALSE(a.SetFromString(std::string(zeros, sizeof(zeros))));
823 }
824
825 } // namespace crypto
826