x25519 1.0.7 → 1.0.8

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5ea00bc17cec9c32323ee015dde866551a567815b91c38dc0da98588ce713ef9
4
- data.tar.gz: d06865bef0935a6d55d6a42c7ee33d90b62fd28e61b4fdd8006373afabb36a1d
3
+ metadata.gz: 6779cf27919288b5f0f4db01efaacb2e71f4f9e5a2c44bed21f8c8e503aa0940
4
+ data.tar.gz: 182ad455c8a95ee4d82e8c2c43ba3db0d7346d69bfd35ebff104e293cc81fc88
5
5
  SHA512:
6
- metadata.gz: f20cb225eb89014e805169f4a1293070a93261c1e05647b8d939c919f27646b11a6510aa38af370788b81315f5dd90c7979ac49ae84fe8185e2d8ff98c56bc2b
7
- data.tar.gz: 73906112646ccdb118d55067e5c274b8b8d769e74dbbf9b6eb72c30ba9c75da233a6099120fec3dd8765ed7ceb0487e3909cfba796abfcc0ff5a6411bdacdd97
6
+ metadata.gz: c06874bfe2e22d8af950b763af1ffc2cc6c2ef68cd88ff1de37254faa4565265d28b7462825d4449dcc48888e8bccc9e54c281458a56f3b62827abc7c3f7505b
7
+ data.tar.gz: 5d05cf0e2f57667d6068cc85a98eb8f2cc5afee1a088ebca070f1c7ff09dd95415f7f84d17b9e45f9201d528fc0f630124581b92d5a49bbef17e018803e60757
data/CHANGES.md CHANGED
@@ -1,74 +1,81 @@
1
- # [1.0.7] (2018-02-26)
1
+ ## [1.0.8] (2018-11-08)
2
+
3
+ [1.0.8]: https://github.com/crypto-rb/x25519/compare/v1.0.7...v1.0.8
4
+
5
+ - [#20](https://github.com/crypto-rb/x25519/pull/19)
6
+ Change license to BSD-3-clause.
7
+
8
+ ## [1.0.7] (2018-02-26)
2
9
 
3
10
  [1.0.7]: https://github.com/crypto-rb/x25519/compare/v1.0.6...v1.0.7
4
11
 
5
- * [#19](https://github.com/crypto-rb/x25519/pull/19)
6
- Incorporate upstream carry propagation bugfix and LICENSE changes
12
+ - [#19](https://github.com/crypto-rb/x25519/pull/19)
13
+ Incorporate upstream carry propagation bugfix and LICENSE changes.
7
14
 
8
- # [1.0.6] (2018-01-04)
15
+ ## [1.0.6] (2018-01-04)
9
16
 
10
17
  [1.0.6]: https://github.com/crypto-rb/x25519/compare/v1.0.5...v1.0.6
11
18
 
12
- * Use correct (LGPLv3) license in gemspec
19
+ - Use correct (LGPLv3) license in gemspec
13
20
 
14
- # [1.0.5] (2017-12-31)
21
+ ## [1.0.5] (2017-12-31)
15
22
 
16
23
  [1.0.5]: https://github.com/crypto-rb/x25519/compare/v1.0.4...v1.0.5
17
24
 
18
- * [#15](https://github.com/crypto-rb/x25519/pull/15)
25
+ - [#15](https://github.com/crypto-rb/x25519/pull/15)
19
26
  RuboCop 0.52.1
20
27
 
21
- * [#14](https://github.com/crypto-rb/x25519/pull/14)
22
- `ext/x25519_ref10`: Consolidate all field element code into fe.c
28
+ - [#14](https://github.com/crypto-rb/x25519/pull/14)
29
+ `ext/x25519_ref10`: Consolidate all field element code into `fe.c`.
23
30
 
24
- # [1.0.4] (2017-12-31)
31
+ ## [1.0.4] (2017-12-31)
25
32
 
26
33
  [1.0.4]: https://github.com/crypto-rb/x25519/compare/v1.0.3...v1.0.4
27
34
 
28
- * [#13](https://github.com/crypto-rb/x25519/pull/13)
35
+ - [#13](https://github.com/crypto-rb/x25519/pull/13)
29
36
  Test against Ruby 2.5.0
30
37
 
31
- * [#12](https://github.com/crypto-rb/x25519/pull/12)
38
+ - [#12](https://github.com/crypto-rb/x25519/pull/12)
32
39
  Move project to the crypto-rb GitHub organization
33
40
 
34
- # [1.0.3] (2017-12-13)
41
+ ## [1.0.3] (2017-12-13)
35
42
 
36
43
  [1.0.3]: https://github.com/crypto-rb/x25519/compare/v1.0.2...v1.0.3
37
44
 
38
- * [#10](https://github.com/crypto-rb/x25519/pull/10)
45
+ - [#10](https://github.com/crypto-rb/x25519/pull/10)
39
46
  Detect degenerate (i.e. all-zero) public keys (fixes #6)
40
47
 
41
- # [1.0.2] (2017-12-13)
48
+ ## [1.0.2] (2017-12-13)
42
49
 
43
50
  [1.0.2]: https://github.com/crypto-rb/x25519/compare/v1.0.1...v1.0.2
44
51
 
45
- * [#9](https://github.com/crypto-rb/x25519/pull/9)
52
+ - [#9](https://github.com/crypto-rb/x25519/pull/9)
46
53
  Make `X25519.provider` an `attr_accessor`
47
- * Raise `X25519::SelfTestFailure` when self-test fails
54
+ - Raise `X25519::SelfTestFailure` when self-test fails
48
55
 
49
- # [1.0.1] (2017-12-12)
56
+ ## [1.0.1] (2017-12-12)
50
57
 
51
58
  [1.0.1]: https://github.com/crypto-rb/x25519/compare/v1.0.0...v1.0.1
52
59
 
53
- * Have `X25519.self_test` return true on success
60
+ - Have `X25519.self_test` return true on success
54
61
 
55
- # [1.0.0] (2017-12-12)
62
+ ## [1.0.0] (2017-12-12)
56
63
 
57
64
  [1.0.0]: https://github.com/crypto-rb/x25519/compare/v0.2.0...v1.0.0
58
65
 
59
- * [#8](https://github.com/crypto-rb/x25519/pull/8)
66
+ - [#8](https://github.com/crypto-rb/x25519/pull/8)
60
67
  Add self-test
61
68
 
62
- * [#7](https://github.com/crypto-rb/x25519/pull/7)
69
+ - [#7](https://github.com/crypto-rb/x25519/pull/7)
63
70
  Factor providers into the `X25519::Provider` namespace
64
71
 
65
- # [0.2.0] (2017-12-12)
72
+ ## [0.2.0] (2017-12-12)
66
73
 
67
74
  [0.2.0]: https://github.com/crypto-rb/x25519/compare/v0.1.0...v0.2.0
68
75
 
69
- * [#5](https://github.com/crypto-rb/x25519/pull/5)
76
+ - [#5](https://github.com/crypto-rb/x25519/pull/5)
70
77
  Rewrite gem in Ruby with minimal native extensions
71
78
 
72
- # 0.1.0 (2017-12-11)
79
+ ## 0.1.0 (2017-12-11)
73
80
 
74
- * Initial release
81
+ - Initial release
data/LICENSE CHANGED
@@ -1,504 +1,32 @@
1
- GNU LESSER GENERAL PUBLIC LICENSE
2
- Version 2.1, February 1999
3
-
4
- Copyright (C) 1991, 1999 Free Software Foundation, Inc.
5
- 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
6
- Everyone is permitted to copy and distribute verbatim copies
7
- of this license document, but changing it is not allowed.
8
-
9
- [This is the first released version of the Lesser GPL. It also counts
10
- as the successor of the GNU Library Public License, version 2, hence
11
- the version number 2.1.]
12
-
13
- Preamble
14
-
15
- The licenses for most software are designed to take away your
16
- freedom to share and change it. By contrast, the GNU General Public
17
- Licenses are intended to guarantee your freedom to share and change
18
- free software--to make sure the software is free for all its users.
19
-
20
- This license, the Lesser General Public License, applies to some
21
- specially designated software packages--typically libraries--of the
22
- Free Software Foundation and other authors who decide to use it. You
23
- can use it too, but we suggest you first think carefully about whether
24
- this license or the ordinary General Public License is the better
25
- strategy to use in any particular case, based on the explanations below.
26
-
27
- When we speak of free software, we are referring to freedom of use,
28
- not price. Our General Public Licenses are designed to make sure that
29
- you have the freedom to distribute copies of free software (and charge
30
- for this service if you wish); that you receive source code or can get
31
- it if you want it; that you can change the software and use pieces of
32
- it in new free programs; and that you are informed that you can do
33
- these things.
34
-
35
- To protect your rights, we need to make restrictions that forbid
36
- distributors to deny you these rights or to ask you to surrender these
37
- rights. These restrictions translate to certain responsibilities for
38
- you if you distribute copies of the library or if you modify it.
39
-
40
- For example, if you distribute copies of the library, whether gratis
41
- or for a fee, you must give the recipients all the rights that we gave
42
- you. You must make sure that they, too, receive or can get the source
43
- code. If you link other code with the library, you must provide
44
- complete object files to the recipients, so that they can relink them
45
- with the library after making changes to the library and recompiling
46
- it. And you must show them these terms so they know their rights.
47
-
48
- We protect your rights with a two-step method: (1) we copyright the
49
- library, and (2) we offer you this license, which gives you legal
50
- permission to copy, distribute and/or modify the library.
51
-
52
- To protect each distributor, we want to make it very clear that
53
- there is no warranty for the free library. Also, if the library is
54
- modified by someone else and passed on, the recipients should know
55
- that what they have is not the original version, so that the original
56
- author's reputation will not be affected by problems that might be
57
- introduced by others.
58
-
59
- Finally, software patents pose a constant threat to the existence of
60
- any free program. We wish to make sure that a company cannot
61
- effectively restrict the users of a free program by obtaining a
62
- restrictive license from a patent holder. Therefore, we insist that
63
- any patent license obtained for a version of the library must be
64
- consistent with the full freedom of use specified in this license.
65
-
66
- Most GNU software, including some libraries, is covered by the
67
- ordinary GNU General Public License. This license, the GNU Lesser
68
- General Public License, applies to certain designated libraries, and
69
- is quite different from the ordinary General Public License. We use
70
- this license for certain libraries in order to permit linking those
71
- libraries into non-free programs.
72
-
73
- When a program is linked with a library, whether statically or using
74
- a shared library, the combination of the two is legally speaking a
75
- combined work, a derivative of the original library. The ordinary
76
- General Public License therefore permits such linking only if the
77
- entire combination fits its criteria of freedom. The Lesser General
78
- Public License permits more lax criteria for linking other code with
79
- the library.
80
-
81
- We call this license the "Lesser" General Public License because it
82
- does Less to protect the user's freedom than the ordinary General
83
- Public License. It also provides other free software developers Less
84
- of an advantage over competing non-free programs. These disadvantages
85
- are the reason we use the ordinary General Public License for many
86
- libraries. However, the Lesser license provides advantages in certain
87
- special circumstances.
88
-
89
- For example, on rare occasions, there may be a special need to
90
- encourage the widest possible use of a certain library, so that it becomes
91
- a de-facto standard. To achieve this, non-free programs must be
92
- allowed to use the library. A more frequent case is that a free
93
- library does the same job as widely used non-free libraries. In this
94
- case, there is little to gain by limiting the free library to free
95
- software only, so we use the Lesser General Public License.
96
-
97
- In other cases, permission to use a particular library in non-free
98
- programs enables a greater number of people to use a large body of
99
- free software. For example, permission to use the GNU C Library in
100
- non-free programs enables many more people to use the whole GNU
101
- operating system, as well as its variant, the GNU/Linux operating
102
- system.
103
-
104
- Although the Lesser General Public License is Less protective of the
105
- users' freedom, it does ensure that the user of a program that is
106
- linked with the Library has the freedom and the wherewithal to run
107
- that program using a modified version of the Library.
108
-
109
- The precise terms and conditions for copying, distribution and
110
- modification follow. Pay close attention to the difference between a
111
- "work based on the library" and a "work that uses the library". The
112
- former contains code derived from the library, whereas the latter must
113
- be combined with the library in order to run.
114
-
115
- GNU LESSER GENERAL PUBLIC LICENSE
116
- TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
117
-
118
- 0. This License Agreement applies to any software library or other
119
- program which contains a notice placed by the copyright holder or
120
- other authorized party saying it may be distributed under the terms of
121
- this Lesser General Public License (also called "this License").
122
- Each licensee is addressed as "you".
123
-
124
- A "library" means a collection of software functions and/or data
125
- prepared so as to be conveniently linked with application programs
126
- (which use some of those functions and data) to form executables.
127
-
128
- The "Library", below, refers to any such software library or work
129
- which has been distributed under these terms. A "work based on the
130
- Library" means either the Library or any derivative work under
131
- copyright law: that is to say, a work containing the Library or a
132
- portion of it, either verbatim or with modifications and/or translated
133
- straightforwardly into another language. (Hereinafter, translation is
134
- included without limitation in the term "modification".)
135
-
136
- "Source code" for a work means the preferred form of the work for
137
- making modifications to it. For a library, complete source code means
138
- all the source code for all modules it contains, plus any associated
139
- interface definition files, plus the scripts used to control compilation
140
- and installation of the library.
141
-
142
- Activities other than copying, distribution and modification are not
143
- covered by this License; they are outside its scope. The act of
144
- running a program using the Library is not restricted, and output from
145
- such a program is covered only if its contents constitute a work based
146
- on the Library (independent of the use of the Library in a tool for
147
- writing it). Whether that is true depends on what the Library does
148
- and what the program that uses the Library does.
149
-
150
- 1. You may copy and distribute verbatim copies of the Library's
151
- complete source code as you receive it, in any medium, provided that
152
- you conspicuously and appropriately publish on each copy an
153
- appropriate copyright notice and disclaimer of warranty; keep intact
154
- all the notices that refer to this License and to the absence of any
155
- warranty; and distribute a copy of this License along with the
156
- Library.
157
-
158
- You may charge a fee for the physical act of transferring a copy,
159
- and you may at your option offer warranty protection in exchange for a
160
- fee.
161
-
162
- 2. You may modify your copy or copies of the Library or any portion
163
- of it, thus forming a work based on the Library, and copy and
164
- distribute such modifications or work under the terms of Section 1
165
- above, provided that you also meet all of these conditions:
166
-
167
- a) The modified work must itself be a software library.
168
-
169
- b) You must cause the files modified to carry prominent notices
170
- stating that you changed the files and the date of any change.
171
-
172
- c) You must cause the whole of the work to be licensed at no
173
- charge to all third parties under the terms of this License.
174
-
175
- d) If a facility in the modified Library refers to a function or a
176
- table of data to be supplied by an application program that uses
177
- the facility, other than as an argument passed when the facility
178
- is invoked, then you must make a good faith effort to ensure that,
179
- in the event an application does not supply such function or
180
- table, the facility still operates, and performs whatever part of
181
- its purpose remains meaningful.
182
-
183
- (For example, a function in a library to compute square roots has
184
- a purpose that is entirely well-defined independent of the
185
- application. Therefore, Subsection 2d requires that any
186
- application-supplied function or table used by this function must
187
- be optional: if the application does not supply it, the square
188
- root function must still compute square roots.)
189
-
190
- These requirements apply to the modified work as a whole. If
191
- identifiable sections of that work are not derived from the Library,
192
- and can be reasonably considered independent and separate works in
193
- themselves, then this License, and its terms, do not apply to those
194
- sections when you distribute them as separate works. But when you
195
- distribute the same sections as part of a whole which is a work based
196
- on the Library, the distribution of the whole must be on the terms of
197
- this License, whose permissions for other licensees extend to the
198
- entire whole, and thus to each and every part regardless of who wrote
199
- it.
200
-
201
- Thus, it is not the intent of this section to claim rights or contest
202
- your rights to work written entirely by you; rather, the intent is to
203
- exercise the right to control the distribution of derivative or
204
- collective works based on the Library.
205
-
206
- In addition, mere aggregation of another work not based on the Library
207
- with the Library (or with a work based on the Library) on a volume of
208
- a storage or distribution medium does not bring the other work under
209
- the scope of this License.
210
-
211
- 3. You may opt to apply the terms of the ordinary GNU General Public
212
- License instead of this License to a given copy of the Library. To do
213
- this, you must alter all the notices that refer to this License, so
214
- that they refer to the ordinary GNU General Public License, version 2,
215
- instead of to this License. (If a newer version than version 2 of the
216
- ordinary GNU General Public License has appeared, then you can specify
217
- that version instead if you wish.) Do not make any other change in
218
- these notices.
219
-
220
- Once this change is made in a given copy, it is irreversible for
221
- that copy, so the ordinary GNU General Public License applies to all
222
- subsequent copies and derivative works made from that copy.
223
-
224
- This option is useful when you wish to copy part of the code of
225
- the Library into a program that is not a library.
226
-
227
- 4. You may copy and distribute the Library (or a portion or
228
- derivative of it, under Section 2) in object code or executable form
229
- under the terms of Sections 1 and 2 above provided that you accompany
230
- it with the complete corresponding machine-readable source code, which
231
- must be distributed under the terms of Sections 1 and 2 above on a
232
- medium customarily used for software interchange.
233
-
234
- If distribution of object code is made by offering access to copy
235
- from a designated place, then offering equivalent access to copy the
236
- source code from the same place satisfies the requirement to
237
- distribute the source code, even though third parties are not
238
- compelled to copy the source along with the object code.
239
-
240
- 5. A program that contains no derivative of any portion of the
241
- Library, but is designed to work with the Library by being compiled or
242
- linked with it, is called a "work that uses the Library". Such a
243
- work, in isolation, is not a derivative work of the Library, and
244
- therefore falls outside the scope of this License.
245
-
246
- However, linking a "work that uses the Library" with the Library
247
- creates an executable that is a derivative of the Library (because it
248
- contains portions of the Library), rather than a "work that uses the
249
- library". The executable is therefore covered by this License.
250
- Section 6 states terms for distribution of such executables.
251
-
252
- When a "work that uses the Library" uses material from a header file
253
- that is part of the Library, the object code for the work may be a
254
- derivative work of the Library even though the source code is not.
255
- Whether this is true is especially significant if the work can be
256
- linked without the Library, or if the work is itself a library. The
257
- threshold for this to be true is not precisely defined by law.
258
-
259
- If such an object file uses only numerical parameters, data
260
- structure layouts and accessors, and small macros and small inline
261
- functions (ten lines or less in length), then the use of the object
262
- file is unrestricted, regardless of whether it is legally a derivative
263
- work. (Executables containing this object code plus portions of the
264
- Library will still fall under Section 6.)
265
-
266
- Otherwise, if the work is a derivative of the Library, you may
267
- distribute the object code for the work under the terms of Section 6.
268
- Any executables containing that work also fall under Section 6,
269
- whether or not they are linked directly with the Library itself.
270
-
271
- 6. As an exception to the Sections above, you may also combine or
272
- link a "work that uses the Library" with the Library to produce a
273
- work containing portions of the Library, and distribute that work
274
- under terms of your choice, provided that the terms permit
275
- modification of the work for the customer's own use and reverse
276
- engineering for debugging such modifications.
277
-
278
- You must give prominent notice with each copy of the work that the
279
- Library is used in it and that the Library and its use are covered by
280
- this License. You must supply a copy of this License. If the work
281
- during execution displays copyright notices, you must include the
282
- copyright notice for the Library among them, as well as a reference
283
- directing the user to the copy of this License. Also, you must do one
284
- of these things:
285
-
286
- a) Accompany the work with the complete corresponding
287
- machine-readable source code for the Library including whatever
288
- changes were used in the work (which must be distributed under
289
- Sections 1 and 2 above); and, if the work is an executable linked
290
- with the Library, with the complete machine-readable "work that
291
- uses the Library", as object code and/or source code, so that the
292
- user can modify the Library and then relink to produce a modified
293
- executable containing the modified Library. (It is understood
294
- that the user who changes the contents of definitions files in the
295
- Library will not necessarily be able to recompile the application
296
- to use the modified definitions.)
297
-
298
- b) Use a suitable shared library mechanism for linking with the
299
- Library. A suitable mechanism is one that (1) uses at run time a
300
- copy of the library already present on the user's computer system,
301
- rather than copying library functions into the executable, and (2)
302
- will operate properly with a modified version of the library, if
303
- the user installs one, as long as the modified version is
304
- interface-compatible with the version that the work was made with.
305
-
306
- c) Accompany the work with a written offer, valid for at
307
- least three years, to give the same user the materials
308
- specified in Subsection 6a, above, for a charge no more
309
- than the cost of performing this distribution.
310
-
311
- d) If distribution of the work is made by offering access to copy
312
- from a designated place, offer equivalent access to copy the above
313
- specified materials from the same place.
314
-
315
- e) Verify that the user has already received a copy of these
316
- materials or that you have already sent this user a copy.
317
-
318
- For an executable, the required form of the "work that uses the
319
- Library" must include any data and utility programs needed for
320
- reproducing the executable from it. However, as a special exception,
321
- the materials to be distributed need not include anything that is
322
- normally distributed (in either source or binary form) with the major
323
- components (compiler, kernel, and so on) of the operating system on
324
- which the executable runs, unless that component itself accompanies
325
- the executable.
326
-
327
- It may happen that this requirement contradicts the license
328
- restrictions of other proprietary libraries that do not normally
329
- accompany the operating system. Such a contradiction means you cannot
330
- use both them and the Library together in an executable that you
331
- distribute.
332
-
333
- 7. You may place library facilities that are a work based on the
334
- Library side-by-side in a single library together with other library
335
- facilities not covered by this License, and distribute such a combined
336
- library, provided that the separate distribution of the work based on
337
- the Library and of the other library facilities is otherwise
338
- permitted, and provided that you do these two things:
339
-
340
- a) Accompany the combined library with a copy of the same work
341
- based on the Library, uncombined with any other library
342
- facilities. This must be distributed under the terms of the
343
- Sections above.
344
-
345
- b) Give prominent notice with the combined library of the fact
346
- that part of it is a work based on the Library, and explaining
347
- where to find the accompanying uncombined form of the same work.
348
-
349
- 8. You may not copy, modify, sublicense, link with, or distribute
350
- the Library except as expressly provided under this License. Any
351
- attempt otherwise to copy, modify, sublicense, link with, or
352
- distribute the Library is void, and will automatically terminate your
353
- rights under this License. However, parties who have received copies,
354
- or rights, from you under this License will not have their licenses
355
- terminated so long as such parties remain in full compliance.
356
-
357
- 9. You are not required to accept this License, since you have not
358
- signed it. However, nothing else grants you permission to modify or
359
- distribute the Library or its derivative works. These actions are
360
- prohibited by law if you do not accept this License. Therefore, by
361
- modifying or distributing the Library (or any work based on the
362
- Library), you indicate your acceptance of this License to do so, and
363
- all its terms and conditions for copying, distributing or modifying
364
- the Library or works based on it.
365
-
366
- 10. Each time you redistribute the Library (or any work based on the
367
- Library), the recipient automatically receives a license from the
368
- original licensor to copy, distribute, link with or modify the Library
369
- subject to these terms and conditions. You may not impose any further
370
- restrictions on the recipients' exercise of the rights granted herein.
371
- You are not responsible for enforcing compliance by third parties with
372
- this License.
373
-
374
- 11. If, as a consequence of a court judgment or allegation of patent
375
- infringement or for any other reason (not limited to patent issues),
376
- conditions are imposed on you (whether by court order, agreement or
377
- otherwise) that contradict the conditions of this License, they do not
378
- excuse you from the conditions of this License. If you cannot
379
- distribute so as to satisfy simultaneously your obligations under this
380
- License and any other pertinent obligations, then as a consequence you
381
- may not distribute the Library at all. For example, if a patent
382
- license would not permit royalty-free redistribution of the Library by
383
- all those who receive copies directly or indirectly through you, then
384
- the only way you could satisfy both it and this License would be to
385
- refrain entirely from distribution of the Library.
386
-
387
- If any portion of this section is held invalid or unenforceable under any
388
- particular circumstance, the balance of the section is intended to apply,
389
- and the section as a whole is intended to apply in other circumstances.
390
-
391
- It is not the purpose of this section to induce you to infringe any
392
- patents or other property right claims or to contest validity of any
393
- such claims; this section has the sole purpose of protecting the
394
- integrity of the free software distribution system which is
395
- implemented by public license practices. Many people have made
396
- generous contributions to the wide range of software distributed
397
- through that system in reliance on consistent application of that
398
- system; it is up to the author/donor to decide if he or she is willing
399
- to distribute software through any other system and a licensee cannot
400
- impose that choice.
401
-
402
- This section is intended to make thoroughly clear what is believed to
403
- be a consequence of the rest of this License.
404
-
405
- 12. If the distribution and/or use of the Library is restricted in
406
- certain countries either by patents or by copyrighted interfaces, the
407
- original copyright holder who places the Library under this License may add
408
- an explicit geographical distribution limitation excluding those countries,
409
- so that distribution is permitted only in or among countries not thus
410
- excluded. In such case, this License incorporates the limitation as if
411
- written in the body of this License.
412
-
413
- 13. The Free Software Foundation may publish revised and/or new
414
- versions of the Lesser General Public License from time to time.
415
- Such new versions will be similar in spirit to the present version,
416
- but may differ in detail to address new problems or concerns.
417
-
418
- Each version is given a distinguishing version number. If the Library
419
- specifies a version number of this License which applies to it and
420
- "any later version", you have the option of following the terms and
421
- conditions either of that version or of any later version published by
422
- the Free Software Foundation. If the Library does not specify a
423
- license version number, you may choose any version ever published by
424
- the Free Software Foundation.
425
-
426
- 14. If you wish to incorporate parts of the Library into other free
427
- programs whose distribution conditions are incompatible with these,
428
- write to the author to ask for permission. For software which is
429
- copyrighted by the Free Software Foundation, write to the Free
430
- Software Foundation; we sometimes make exceptions for this. Our
431
- decision will be guided by the two goals of preserving the free status
432
- of all derivatives of our free software and of promoting the sharing
433
- and reuse of software generally.
434
-
435
- NO WARRANTY
436
-
437
- 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
438
- WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
439
- EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
440
- OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
441
- KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
442
- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
443
- PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
444
- LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
445
- THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
446
-
447
- 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
448
- WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
449
- AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
450
- FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
451
- CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
452
- LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
453
- RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
454
- FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
455
- SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
456
- DAMAGES.
457
-
458
- END OF TERMS AND CONDITIONS
459
-
460
- How to Apply These Terms to Your New Libraries
461
-
462
- If you develop a new library, and you want it to be of the greatest
463
- possible use to the public, we recommend making it free software that
464
- everyone can redistribute and change. You can do so by permitting
465
- redistribution under these terms (or, alternatively, under the terms of the
466
- ordinary General Public License).
467
-
468
- To apply these terms, attach the following notices to the library. It is
469
- safest to attach them to the start of each source file to most effectively
470
- convey the exclusion of warranty; and each file should have at least the
471
- "copyright" line and a pointer to where the full notice is found.
472
-
473
- <one line to give the library's name and a brief idea of what it does.>
474
- Copyright (C) <year> <name of author>
475
-
476
- This library is free software; you can redistribute it and/or
477
- modify it under the terms of the GNU Lesser General Public
478
- License as published by the Free Software Foundation; either
479
- version 2.1 of the License, or (at your option) any later version.
480
-
481
- This library is distributed in the hope that it will be useful,
482
- but WITHOUT ANY WARRANTY; without even the implied warranty of
483
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
484
- Lesser General Public License for more details.
485
-
486
- You should have received a copy of the GNU Lesser General Public
487
- License along with this library; if not, write to the Free Software
488
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
489
- USA
490
-
491
- Also add information on how to contact you by electronic and paper mail.
492
-
493
- You should also get your employer (if you work as a programmer) or your
494
- school, if any, to sign a "copyright disclaimer" for the library, if
495
- necessary. Here is a sample; alter the names:
496
-
497
- Yoyodyne, Inc., hereby disclaims all copyright interest in the
498
- library `Frob' (a library for tweaking knobs) written by James Random
499
- Hacker.
500
-
501
- <signature of Ty Coon>, 1 April 1990
502
- Ty Coon, President of Vice
503
-
504
- That's all there is to it!
1
+ BSD-3 License.
2
+
3
+ Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
4
+ Institute of Computing.
5
+ University of Campinas, Brazil.
6
+
7
+ Redistribution and use in source and binary forms, with or without
8
+ modification, are permitted provided that the following conditions
9
+ are met:
10
+
11
+ * Redistributions of source code must retain the above copyright
12
+ notice, this list of conditions and the following disclaimer.
13
+ * Redistributions in binary form must reproduce the above
14
+ copyright notice, this list of conditions and the following
15
+ disclaimer in the documentation and/or other materials provided
16
+ with the distribution.
17
+ * Neither the name of University of Campinas nor the names of its
18
+ contributors may be used to endorse or promote products derived
19
+ from this software without specific prior written permission.
20
+
21
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
+ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
+ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
+ FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
+ COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26
+ INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
27
+ (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28
+ SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29
+ HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
30
+ STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31
+ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
32
+ OF THE POSSIBILITY OF SUCH DAMAGE.
data/README.md CHANGED
@@ -1,4 +1,4 @@
1
- # x25519.rb [![Latest Version][gem-shield]][gem-link] [![Build Status][build-image]][build-link] [![Appveyor CI Status][appveyor-image]][appveyor-link] [![Yard Docs][docs-image]][docs-link] [![License: LGPL v3][license-image]][license-link] [![Gitter Chat][gitter-image]][gitter-link]
1
+ # x25519.rb [![Latest Version][gem-shield]][gem-link] [![Build Status][build-image]][build-link] [![Appveyor CI Status][appveyor-image]][appveyor-link] [![Yard Docs][docs-image]][docs-link] [![License: BSD 3-Clause][license-image]][license-link] [![Gitter Chat][gitter-image]][gitter-link]
2
2
 
3
3
  [gem-shield]: https://badge.fury.io/rb/x25519.svg
4
4
  [gem-link]: https://rubygems.org/gems/x25519
@@ -8,8 +8,8 @@
8
8
  [appveyor-link]: https://ci.appveyor.com/project/tarcieri/x25519
9
9
  [docs-image]: https://img.shields.io/badge/yard-docs-blue.svg
10
10
  [docs-link]: http://www.rubydoc.info/gems/x25519/1.0.6
11
- [license-image]: https://img.shields.io/badge/License-LGPL%20v2.1-blue.svg
12
- [license-link]: https://www.gnu.org/licenses/lgpl-2.1
11
+ [license-image]: https://img.shields.io/badge/License-BSD%203--Clause-blue.svg
12
+ [license-link]: https://spdx.org/licenses/BSD-3-Clause.html
13
13
  [gitter-image]: https://badges.gitter.im/badge.svg
14
14
  [gitter-link]: https://gitter.im/crypto-rb/Lobby
15
15
 
@@ -248,7 +248,7 @@ Returns a `String` containing a 32-byte compressed Montgomery-u coordinate
248
248
 
249
249
  Bug reports and pull requests are welcome on GitHub at https://github.com/crypto-rb/x25519.
250
250
  This project is intended to be a safe, welcoming space for collaboration,
251
- and contributors areexpected to adhere to the [Contributor Covenant](http://contributor-covenant.org)
251
+ and contributors are expected to adhere to the [Contributor Covenant](https://contributor-covenant.org)
252
252
  code of conduct.
253
253
 
254
254
  ## Implementation Details
@@ -259,7 +259,8 @@ based on available CPU features.
259
259
 
260
260
  ### [rfc7748_precomputed]: optimized assembly implementation
261
261
 
262
- * Prime field arithmetic is optimized for the 4th and 6th generation of Intel Core processors (Haswell and Skylake micro-architectures).
262
+ * Prime field arithmetic is optimized for the 4th and 6th generation of Intel Core processors
263
+ (Haswell and Skylake micro-architectures).
263
264
  * Efficient integer multiplication using MULX instruction.
264
265
  * Integer additions accelerated with ADCX/ADOX instructions.
265
266
  * Key generation uses a read-only table of 8 KB for X25519.
@@ -285,12 +286,12 @@ The optimized [rfc7748_precomputed] implementation was designed by:
285
286
  * Armando Faz-Hernández, University of Campinas, Brazil.
286
287
  * Francisco Rodríguez-Henríquez, Computer Science Department, Cinvestav-IPN, Mexico.
287
288
 
288
- ## Copyright and License
289
+ ## License
289
290
 
290
291
  Copyright (c) 2017-2018 Armando Faz, Tony Arcieri
291
292
 
292
293
  This gem is available as open source under the terms of the
293
- GNU Lesser General Public License v2.1 ([LICENSE](https://www.gnu.org/licenses/lgpl-2.1.txt))
294
+ BSD-3 Clause License ([LICENSE](./LICENSE))
294
295
 
295
296
  ## Code of Conduct
296
297
 
@@ -1,23 +1,39 @@
1
1
  /**
2
- * Copyright (c) 2017 Armando Faz <armfazh@ic.unicamp.br>. All Rights Reserved.
2
+ * Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
3
3
  * Institute of Computing.
4
4
  * University of Campinas, Brazil.
5
5
  *
6
6
  * Copyright (C) 2018 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
7
7
  * Copyright (C) 2018 Samuel Neves <sneves@dei.uc.pt>. All Rights Reserved.
8
- *
9
- * This program is free software: you can redistribute it and/or modify
10
- * it under the terms of the GNU Lesser General Public License as
11
- * published by the Free Software Foundation, version 2 or greater.
12
8
  *
13
- * This program is distributed in the hope that it will be useful, but
14
- * WITHOUT ANY WARRANTY; without even the implied warranty of
15
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
- * Lesser General Public License for more details.
9
+ * Redistribution and use in source and binary forms, with or without
10
+ * modification, are permitted provided that the following conditions
11
+ * are met:
17
12
  *
18
- * You should have received a copy of the GNU Lesser General Public License
19
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
20
- */
13
+ * * Redistributions of source code must retain the above copyright
14
+ * notice, this list of conditions and the following disclaimer.
15
+ * * Redistributions in binary form must reproduce the above
16
+ * copyright notice, this list of conditions and the following
17
+ * disclaimer in the documentation and/or other materials provided
18
+ * with the distribution.
19
+ * * Neither the name of University of Campinas nor the names of its
20
+ * contributors may be used to endorse or promote products derived
21
+ * from this software without specific prior written permission.
22
+ *
23
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
32
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
34
+ * OF THE POSSIBILITY OF SUCH DAMAGE.
35
+ */
36
+
21
37
  #include "fp25519_x64.h"
22
38
 
23
39
  /**
@@ -32,19 +48,19 @@ void mul2_256x256_integer_x64(uint64_t *const c, uint64_t *const a,
32
48
  #ifdef __ADX__
33
49
  __asm__ __volatile__(
34
50
  "xorl %%r14d, %%r14d ;"
35
- "movq (%1), %%rdx; " /* A[0] */
51
+ "movq (%1), %%rdx; " /* A[0] */
36
52
  "mulx (%2), %%r8, %%r12; " /* A[0]*B[0] */ "xorl %%r10d, %%r10d ;" "movq %%r8, (%0) ;"
37
- "mulx 8(%2), %%r10, %%rax; " /* A[0]*B[1] */ "adox %%r10, %%r12 ;"
38
- "mulx 16(%2), %%r8, %%rbx; " /* A[0]*B[2] */ "adox %%r8, %%rax ;"
39
- "mulx 24(%2), %%r10, %%rcx; " /* A[0]*B[3] */ "adox %%r10, %%rbx ;"
40
- /*******************************************/ "adox %%r14, %%rcx ;"
41
-
42
- "movq 8(%1), %%rdx; " /* A[1] */
43
- "mulx (%2), %%r8, %%r9; " /* A[1]*B[0] */ "adox %%r12, %%r8 ;" "movq %%r8, 8(%0) ;"
44
- "mulx 8(%2), %%r10, %%r11; " /* A[1]*B[1] */ "adox %%r10, %%r9 ;" "adcx %%r9, %%rax ;"
45
- "mulx 16(%2), %%r8, %%r13; " /* A[1]*B[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%rbx ;"
46
- "mulx 24(%2), %%r10, %%r12; " /* A[1]*B[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rcx ;"
47
- /*******************************************/ "adox %%r14, %%r12 ;" "adcx %%r14, %%r12 ;"
53
+ "mulx 8(%2), %%r10, %%rax; " /* A[0]*B[1] */ "adox %%r10, %%r12 ;"
54
+ "mulx 16(%2), %%r8, %%rbx; " /* A[0]*B[2] */ "adox %%r8, %%rax ;"
55
+ "mulx 24(%2), %%r10, %%rcx; " /* A[0]*B[3] */ "adox %%r10, %%rbx ;"
56
+ /*******************************************/ "adox %%r14, %%rcx ;"
57
+
58
+ "movq 8(%1), %%rdx; " /* A[1] */
59
+ "mulx (%2), %%r8, %%r9; " /* A[1]*B[0] */ "adox %%r12, %%r8 ;" "movq %%r8, 8(%0) ;"
60
+ "mulx 8(%2), %%r10, %%r11; " /* A[1]*B[1] */ "adox %%r10, %%r9 ;" "adcx %%r9, %%rax ;"
61
+ "mulx 16(%2), %%r8, %%r13; " /* A[1]*B[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%rbx ;"
62
+ "mulx 24(%2), %%r10, %%r12; " /* A[1]*B[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rcx ;"
63
+ /*******************************************/ "adox %%r14, %%r12 ;" "adcx %%r14, %%r12 ;"
48
64
 
49
65
  "movq 16(%1), %%rdx; " /* A[2] */ "xorl %%r10d, %%r10d ;"
50
66
  "mulx (%2), %%r8, %%r9; " /* A[2]*B[0] */ "adox %%rax, %%r8 ;" "movq %%r8, 16(%0) ;"
@@ -59,20 +75,20 @@ void mul2_256x256_integer_x64(uint64_t *const c, uint64_t *const a,
59
75
  "mulx 16(%2), %%r8, %%r13; " /* A[3]*B[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%r12 ;" "movq %%r12, 40(%0) ;"
60
76
  "mulx 24(%2), %%r10, %%rbx; " /* A[3]*B[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rax ;" "movq %%rax, 48(%0) ;"
61
77
  /*******************************************/ "adox %%r14, %%rbx ;" "adcx %%r14, %%rbx ;" "movq %%rbx, 56(%0) ;"
62
-
63
- "movq 32(%1), %%rdx; " /* C[0] */
78
+
79
+ "movq 32(%1), %%rdx; " /* C[0] */
64
80
  "mulx 32(%2), %%r8, %%r12; " /* C[0]*D[0] */ "xorl %%r10d, %%r10d ;" "movq %%r8, 64(%0);"
65
- "mulx 40(%2), %%r10, %%rax; " /* C[0]*D[1] */ "adox %%r10, %%r12 ;"
66
- "mulx 48(%2), %%r8, %%rbx; " /* C[0]*D[2] */ "adox %%r8, %%rax ;"
67
- "mulx 56(%2), %%r10, %%rcx; " /* C[0]*D[3] */ "adox %%r10, %%rbx ;"
68
- /*******************************************/ "adox %%r14, %%rcx ;"
81
+ "mulx 40(%2), %%r10, %%rax; " /* C[0]*D[1] */ "adox %%r10, %%r12 ;"
82
+ "mulx 48(%2), %%r8, %%rbx; " /* C[0]*D[2] */ "adox %%r8, %%rax ;"
83
+ "mulx 56(%2), %%r10, %%rcx; " /* C[0]*D[3] */ "adox %%r10, %%rbx ;"
84
+ /*******************************************/ "adox %%r14, %%rcx ;"
69
85
 
70
86
  "movq 40(%1), %%rdx; " /* C[1] */ "xorl %%r10d, %%r10d ;"
71
- "mulx 32(%2), %%r8, %%r9; " /* C[1]*D[0] */ "adox %%r12, %%r8 ;" "movq %%r8, 72(%0);"
72
- "mulx 40(%2), %%r10, %%r11; " /* C[1]*D[1] */ "adox %%r10, %%r9 ;" "adcx %%r9, %%rax ;"
73
- "mulx 48(%2), %%r8, %%r13; " /* C[1]*D[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%rbx ;"
74
- "mulx 56(%2), %%r10, %%r12; " /* C[1]*D[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rcx ;"
75
- /*******************************************/ "adox %%r14, %%r12 ;" "adcx %%r14, %%r12 ;"
87
+ "mulx 32(%2), %%r8, %%r9; " /* C[1]*D[0] */ "adox %%r12, %%r8 ;" "movq %%r8, 72(%0);"
88
+ "mulx 40(%2), %%r10, %%r11; " /* C[1]*D[1] */ "adox %%r10, %%r9 ;" "adcx %%r9, %%rax ;"
89
+ "mulx 48(%2), %%r8, %%r13; " /* C[1]*D[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%rbx ;"
90
+ "mulx 56(%2), %%r10, %%r12; " /* C[1]*D[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rcx ;"
91
+ /*******************************************/ "adox %%r14, %%r12 ;" "adcx %%r14, %%r12 ;"
76
92
 
77
93
  "movq 48(%1), %%rdx; " /* C[2] */ "xorl %%r10d, %%r10d ;"
78
94
  "mulx 32(%2), %%r8, %%r9; " /* C[2]*D[0] */ "adox %%rax, %%r8 ;" "movq %%r8, 80(%0);"
@@ -82,7 +98,7 @@ void mul2_256x256_integer_x64(uint64_t *const c, uint64_t *const a,
82
98
  /*******************************************/ "adox %%r14, %%rax ;" "adcx %%r14, %%rax ;"
83
99
 
84
100
  "movq 56(%1), %%rdx; " /* C[3] */ "xorl %%r10d, %%r10d ;"
85
- "mulx 32(%2), %%r8, %%r9; " /* C[3]*D[0] */ "adox %%rbx, %%r8 ;" "movq %%r8, 88(%0);"
101
+ "mulx 32(%2), %%r8, %%r9; " /* C[3]*D[0] */ "adox %%rbx, %%r8 ;" "movq %%r8, 88(%0);"
86
102
  "mulx 40(%2), %%r10, %%r11; " /* C[3]*D[1] */ "adox %%r10, %%r9 ;" "adcx %%r9, %%rcx ;" "movq %%rcx, 96(%0) ;"
87
103
  "mulx 48(%2), %%r8, %%r13; " /* C[3]*D[2] */ "adox %%r8, %%r11 ;" "adcx %%r11, %%r12 ;" "movq %%r12, 104(%0) ;"
88
104
  "mulx 56(%2), %%r10, %%rbx; " /* C[3]*D[3] */ "adox %%r10, %%r13 ;" "adcx %%r13, %%rax ;" "movq %%rax, 112(%0) ;"
@@ -233,8 +249,8 @@ void sqr2_256x256_integer_x64(uint64_t *const c, uint64_t *const a) {
233
249
  "movq 24(%1), %%rdx ;" "mulx %%rdx, %%rax, %%rcx ;" /* A[3]^2 */
234
250
  "adcq %%rax, %%r13 ;" "movq %%r13, 48(%0) ;"
235
251
  "adcq %%rcx, %%r14 ;" "movq %%r14, 56(%0) ;"
236
-
237
-
252
+
253
+
238
254
  "movq 32(%1), %%rdx ;" /* B[0] */
239
255
  "mulx 40(%1), %%r8, %%r14 ;" /* B[1]*B[0] */ "xorl %%r15d, %%r15d;"
240
256
  "mulx 48(%1), %%r9, %%r10 ;" /* B[2]*B[0] */ "adcx %%r14, %%r9 ;"
@@ -401,8 +417,8 @@ void red_EltFp25519_2w_x64(uint64_t *const c, uint64_t *const a) {
401
417
  "adcx %%rcx, %%r9 ;" "movq %%r9, 8(%0) ;"
402
418
  "adcx %%rbx, %%r10 ;" "movq %%r10, 16(%0) ;"
403
419
  "adcx %%rbx, %%r11 ;" "movq %%r11, 24(%0) ;"
404
- "mov $0, %%ecx ;"
405
- "cmovc %%edx, %%ecx ;"
420
+ "mov $0, %%ecx ;"
421
+ "cmovc %%edx, %%ecx ;"
406
422
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
407
423
 
408
424
  "mulx 96(%1), %%r8, %%r10; " /* c*C[4] */ "xorl %%ebx, %%ebx ;" "adox 64(%1), %%r8 ;"
@@ -416,8 +432,8 @@ void red_EltFp25519_2w_x64(uint64_t *const c, uint64_t *const a) {
416
432
  "adcx %%rcx, %%r9 ;" "movq %%r9, 40(%0) ;"
417
433
  "adcx %%rbx, %%r10 ;" "movq %%r10, 48(%0) ;"
418
434
  "adcx %%rbx, %%r11 ;" "movq %%r11, 56(%0) ;"
419
- "mov $0, %%ecx ;"
420
- "cmovc %%edx, %%ecx ;"
435
+ "mov $0, %%ecx ;"
436
+ "cmovc %%edx, %%ecx ;"
421
437
  "addq %%rcx, %%r8 ;" "movq %%r8, 32(%0) ;"
422
438
  :
423
439
  : "r" (c), "r" (a)
@@ -441,8 +457,8 @@ void red_EltFp25519_2w_x64(uint64_t *const c, uint64_t *const a) {
441
457
  "adcq %%rcx, %%r9 ;" "movq %%r9, 8(%0) ;"
442
458
  "adcq $0, %%r10 ;" "movq %%r10, 16(%0) ;"
443
459
  "adcq $0, %%r11 ;" "movq %%r11, 24(%0) ;"
444
- "mov $0, %%ecx ;"
445
- "cmovc %%edx, %%ecx ;"
460
+ "mov $0, %%ecx ;"
461
+ "cmovc %%edx, %%ecx ;"
446
462
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
447
463
 
448
464
  "mulx 96(%1), %%r8, %%r10 ;" /* c*C[4] */
@@ -460,8 +476,8 @@ void red_EltFp25519_2w_x64(uint64_t *const c, uint64_t *const a) {
460
476
  "adcq %%rcx, %%r9 ;" "movq %%r9, 40(%0) ;"
461
477
  "adcq $0, %%r10 ;" "movq %%r10, 48(%0) ;"
462
478
  "adcq $0, %%r11 ;" "movq %%r11, 56(%0) ;"
463
- "mov $0, %%ecx ;"
464
- "cmovc %%edx, %%ecx ;"
479
+ "mov $0, %%ecx ;"
480
+ "cmovc %%edx, %%ecx ;"
465
481
  "addq %%rcx, %%r8 ;" "movq %%r8, 32(%0) ;"
466
482
  :
467
483
  : "r" (c), "r" (a)
@@ -555,7 +571,7 @@ void mul_256x256_integer_x64(uint64_t *const c, uint64_t *const a, uint64_t *con
555
571
  "adcq $0, %%rbx ;" "movq %%rbx, 56(%0) ;"
556
572
  :
557
573
  : "r" (c), "r" (a), "r" (b)
558
- : "memory", "cc", "%rax", "%rbx", "%rcx", "%rdx",
574
+ : "memory", "cc", "%rax", "%rbx", "%rcx", "%rdx",
559
575
  "%r8", "%r9", "%r10", "%r11", "%r12", "%r13"
560
576
  );
561
577
  #endif
@@ -684,8 +700,8 @@ void red_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a) {
684
700
  "adcx %%rcx, %%r9 ;" "movq %%r9, 8(%0) ;"
685
701
  "adcx %%rbx, %%r10 ;" "movq %%r10, 16(%0) ;"
686
702
  "adcx %%rbx, %%r11 ;" "movq %%r11, 24(%0) ;"
687
- "mov $0, %%ecx ;"
688
- "cmovc %%edx, %%ecx ;"
703
+ "mov $0, %%ecx ;"
704
+ "cmovc %%edx, %%ecx ;"
689
705
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
690
706
  :
691
707
  : "r" (c), "r" (a)
@@ -709,8 +725,8 @@ void red_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a) {
709
725
  "adcq %%rcx, %%r9 ;" "movq %%r9, 8(%0) ;"
710
726
  "adcq $0, %%r10 ;" "movq %%r10, 16(%0) ;"
711
727
  "adcq $0, %%r11 ;" "movq %%r11, 24(%0) ;"
712
- "mov $0, %%ecx ;"
713
- "cmovc %%edx, %%ecx ;"
728
+ "mov $0, %%ecx ;"
729
+ "cmovc %%edx, %%ecx ;"
714
730
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
715
731
  :
716
732
  : "r" (c), "r" (a)
@@ -727,20 +743,20 @@ void red_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a) {
727
743
  inline void add_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a, uint64_t *const b) {
728
744
  #ifdef __ADX__
729
745
  __asm__ __volatile__(
730
- "mov $38, %%eax ;"
731
- "xorl %%ecx, %%ecx ;"
746
+ "mov $38, %%eax ;"
747
+ "xorl %%ecx, %%ecx ;"
732
748
  "movq (%2), %%r8 ;" "adcx (%1), %%r8 ;"
733
749
  "movq 8(%2), %%r9 ;" "adcx 8(%1), %%r9 ;"
734
750
  "movq 16(%2), %%r10 ;" "adcx 16(%1), %%r10 ;"
735
751
  "movq 24(%2), %%r11 ;" "adcx 24(%1), %%r11 ;"
736
- "cmovc %%eax, %%ecx ;"
752
+ "cmovc %%eax, %%ecx ;"
737
753
  "xorl %%eax, %%eax ;"
738
754
  "adcx %%rcx, %%r8 ;"
739
755
  "adcx %%rax, %%r9 ;" "movq %%r9, 8(%0) ;"
740
756
  "adcx %%rax, %%r10 ;" "movq %%r10, 16(%0) ;"
741
757
  "adcx %%rax, %%r11 ;" "movq %%r11, 24(%0) ;"
742
- "mov $38, %%ecx ;"
743
- "cmovc %%ecx, %%eax ;"
758
+ "mov $38, %%ecx ;"
759
+ "cmovc %%ecx, %%eax ;"
744
760
  "addq %%rax, %%r8 ;" "movq %%r8, (%0) ;"
745
761
  :
746
762
  : "r" (c), "r" (a), "r" (b)
@@ -748,19 +764,19 @@ inline void add_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a, uint64_t
748
764
  );
749
765
  #else
750
766
  __asm__ __volatile__(
751
- "mov $38, %%eax ;"
767
+ "mov $38, %%eax ;"
752
768
  "movq (%2), %%r8 ;" "addq (%1), %%r8 ;"
753
769
  "movq 8(%2), %%r9 ;" "adcq 8(%1), %%r9 ;"
754
770
  "movq 16(%2), %%r10 ;" "adcq 16(%1), %%r10 ;"
755
771
  "movq 24(%2), %%r11 ;" "adcq 24(%1), %%r11 ;"
756
- "mov $0, %%ecx ;"
757
- "cmovc %%eax, %%ecx ;"
772
+ "mov $0, %%ecx ;"
773
+ "cmovc %%eax, %%ecx ;"
758
774
  "addq %%rcx, %%r8 ;"
759
775
  "adcq $0, %%r9 ;" "movq %%r9, 8(%0) ;"
760
776
  "adcq $0, %%r10 ;" "movq %%r10, 16(%0) ;"
761
777
  "adcq $0, %%r11 ;" "movq %%r11, 24(%0) ;"
762
- "mov $0, %%ecx ;"
763
- "cmovc %%eax, %%ecx ;"
778
+ "mov $0, %%ecx ;"
779
+ "cmovc %%eax, %%ecx ;"
764
780
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
765
781
  :
766
782
  : "r" (c), "r" (a), "r" (b)
@@ -771,19 +787,19 @@ inline void add_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a, uint64_t
771
787
 
772
788
  inline void sub_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a, uint64_t *const b) {
773
789
  __asm__ __volatile__(
774
- "mov $38, %%eax ;"
790
+ "mov $38, %%eax ;"
775
791
  "movq (%1), %%r8 ;" "subq (%2), %%r8 ;"
776
792
  "movq 8(%1), %%r9 ;" "sbbq 8(%2), %%r9 ;"
777
793
  "movq 16(%1), %%r10 ;" "sbbq 16(%2), %%r10 ;"
778
794
  "movq 24(%1), %%r11 ;" "sbbq 24(%2), %%r11 ;"
779
- "mov $0, %%ecx ;"
780
- "cmovc %%eax, %%ecx ;"
795
+ "mov $0, %%ecx ;"
796
+ "cmovc %%eax, %%ecx ;"
781
797
  "subq %%rcx, %%r8 ;"
782
798
  "sbbq $0, %%r9 ;" "movq %%r9, 8(%0) ;"
783
799
  "sbbq $0, %%r10 ;" "movq %%r10, 16(%0) ;"
784
800
  "sbbq $0, %%r11 ;" "movq %%r11, 24(%0) ;"
785
- "mov $0, %%ecx ;"
786
- "cmovc %%eax, %%ecx ;"
801
+ "mov $0, %%ecx ;"
802
+ "cmovc %%eax, %%ecx ;"
787
803
  "subq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
788
804
  :
789
805
  : "r" (c), "r" (a), "r" (b)
@@ -810,8 +826,8 @@ inline void mul_a24_EltFp25519_1w_x64(uint64_t *const c, uint64_t *const a) {
810
826
  "adcq %%rcx, %%r9 ;" "movq %%r9, 8(%0) ;"
811
827
  "adcq $0, %%r10 ;" "movq %%r10, 16(%0) ;"
812
828
  "adcq $0, %%r11 ;" "movq %%r11, 24(%0) ;"
813
- "mov $0, %%ecx ;"
814
- "cmovc %%edx, %%ecx ;"
829
+ "mov $0, %%ecx ;"
830
+ "cmovc %%edx, %%ecx ;"
815
831
  "addq %%rcx, %%r8 ;" "movq %%r8, (%0) ;"
816
832
  :
817
833
  : "r" (c), "r" (a), "r" (a24)
@@ -1,20 +1,36 @@
1
1
  /**
2
- * Copyright (c) 2017 Armando Faz <armfazh@ic.unicamp.br>. All Rights Reserved.
2
+ * Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
3
3
  * Institute of Computing.
4
4
  * University of Campinas, Brazil.
5
5
  *
6
- * This program is free software: you can redistribute it and/or modify
7
- * it under the terms of the GNU Lesser General Public License as
8
- * published by the Free Software Foundation, version 2 or greater.
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions
8
+ * are met:
9
9
  *
10
- * This program is distributed in the hope that it will be useful, but
11
- * WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
- * Lesser General Public License for more details.
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following
14
+ * disclaimer in the documentation and/or other materials provided
15
+ * with the distribution.
16
+ * * Neither the name of University of Campinas nor the names of its
17
+ * contributors may be used to endorse or promote products derived
18
+ * from this software without specific prior written permission.
14
19
  *
15
- * You should have received a copy of the GNU Lesser General Public License
16
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31
+ * OF THE POSSIBILITY OF SUCH DAMAGE.
32
+ */
33
+
18
34
  #ifndef FP25519_X64_H
19
35
  #define FP25519_X64_H
20
36
 
@@ -1,20 +1,36 @@
1
1
  /**
2
- * Copyright (c) 2017 Armando Faz <armfazh@ic.unicamp.br>. All Rights Reserved.
2
+ * Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
3
3
  * Institute of Computing.
4
4
  * University of Campinas, Brazil.
5
5
  *
6
- * This program is free software: you can redistribute it and/or modify
7
- * it under the terms of the GNU Lesser General Public License as
8
- * published by the Free Software Foundation, version 2 or greater.
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions
8
+ * are met:
9
9
  *
10
- * This program is distributed in the hope that it will be useful, but
11
- * WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
- * Lesser General Public License for more details.
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following
14
+ * disclaimer in the documentation and/or other materials provided
15
+ * with the distribution.
16
+ * * Neither the name of University of Campinas nor the names of its
17
+ * contributors may be used to endorse or promote products derived
18
+ * from this software without specific prior written permission.
14
19
  *
15
- * You should have received a copy of the GNU Lesser General Public License
16
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31
+ * OF THE POSSIBILITY OF SUCH DAMAGE.
32
+ */
33
+
18
34
  #ifndef TABLE_LADDER_8K_H
19
35
  #define TABLE_LADDER_8K_H
20
36
  #include <stdint.h>
@@ -1,20 +1,36 @@
1
1
  /**
2
- * Copyright (c) 2017 Armando Faz <armfazh@ic.unicamp.br>.
2
+ * Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
3
3
  * Institute of Computing.
4
4
  * University of Campinas, Brazil.
5
5
  *
6
- * This program is free software: you can redistribute it and/or modify
7
- * it under the terms of the GNU Lesser General Public License as
8
- * published by the Free Software Foundation, version 3.
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions
8
+ * are met:
9
9
  *
10
- * This program is distributed in the hope that it will be useful, but
11
- * WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
- * Lesser General Public License for more details.
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following
14
+ * disclaimer in the documentation and/or other materials provided
15
+ * with the distribution.
16
+ * * Neither the name of University of Campinas nor the names of its
17
+ * contributors may be used to endorse or promote products derived
18
+ * from this software without specific prior written permission.
14
19
  *
15
- * You should have received a copy of the GNU Lesser General Public License
16
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31
+ * OF THE POSSIBILITY OF SUCH DAMAGE.
32
+ */
33
+
18
34
  #ifndef X25519_PRECOMPUTED_H
19
35
  #define X25519_PRECOMPUTED_H
20
36
 
@@ -1,20 +1,38 @@
1
1
  /**
2
- * Copyright (c) 2017 Armando Faz <armfazh@ic.unicamp.br>. All Rights Reserved.
2
+ * Copyright (c) 2017, Armando Faz <armfazh@ic.unicamp.br>. All rights reserved.
3
3
  * Institute of Computing.
4
4
  * University of Campinas, Brazil.
5
5
  *
6
- * This program is free software: you can redistribute it and/or modify
7
- * it under the terms of the GNU Lesser General Public License as
8
- * published by the Free Software Foundation, version 2 or greater.
6
+ * Copyright (C) 2018 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
9
7
  *
10
- * This program is distributed in the hope that it will be useful, but
11
- * WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
- * Lesser General Public License for more details.
8
+ * Redistribution and use in source and binary forms, with or without
9
+ * modification, are permitted provided that the following conditions
10
+ * are met:
14
11
  *
15
- * You should have received a copy of the GNU Lesser General Public License
16
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
12
+ * * Redistributions of source code must retain the above copyright
13
+ * notice, this list of conditions and the following disclaimer.
14
+ * * Redistributions in binary form must reproduce the above
15
+ * copyright notice, this list of conditions and the following
16
+ * disclaimer in the documentation and/or other materials provided
17
+ * with the distribution.
18
+ * * Neither the name of University of Campinas nor the names of its
19
+ * contributors may be used to endorse or promote products derived
20
+ * from this software without specific prior written permission.
21
+ *
22
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
29
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
31
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
33
+ * OF THE POSSIBILITY OF SUCH DAMAGE.
34
+ */
35
+
18
36
  #include <string.h>
19
37
  #include "fp25519_x64.h"
20
38
  #include "x25519_precomputed.h"
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module X25519
4
- VERSION = "1.0.7".freeze
4
+ VERSION = "1.0.8".freeze
5
5
  end
@@ -14,7 +14,7 @@ Gem::Specification.new do |spec|
14
14
  Diffie-Hellman function as described in RFC 7748.
15
15
  DESCRIPTION
16
16
  spec.homepage = "https://github.com/crypto-rb/x25519"
17
- spec.license = "LGPL-2.1-or-later"
17
+ spec.license = "BSD-3-Clause" # https://spdx.org/licenses/BSD-3-Clause.html
18
18
  spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
19
19
  spec.bindir = "exe"
20
20
  spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: x25519
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.7
4
+ version: 1.0.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tony Arcieri
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2018-02-26 00:00:00.000000000 Z
11
+ date: 2018-11-08 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -72,7 +72,7 @@ files:
72
72
  - x25519.gemspec
73
73
  homepage: https://github.com/crypto-rb/x25519
74
74
  licenses:
75
- - LGPL-2.1-or-later
75
+ - BSD-3-Clause
76
76
  metadata: {}
77
77
  post_install_message:
78
78
  rdoc_options: []