summaryrefslogtreecommitdiffstats
path: root/third_party/boringssl
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/boringssl')
-rw-r--r--third_party/boringssl/BUILD.gn9
-rw-r--r--third_party/boringssl/boringssl.gyp4
-rw-r--r--third_party/boringssl/boringssl.gypi3
-rw-r--r--third_party/boringssl/boringssl_nacl.gyp4
-rw-r--r--third_party/boringssl/boringssl_tests.gypi15
-rw-r--r--third_party/boringssl/boringssl_unittest.cc4
-rw-r--r--third_party/boringssl/err_data.c436
-rw-r--r--third_party/boringssl/linux-aarch64/crypto/aes/aesv8-armx64.S2
-rw-r--r--third_party/boringssl/linux-aarch64/crypto/modes/ghashv8-armx64.S2
-rw-r--r--third_party/boringssl/linux-aarch64/crypto/sha/sha1-armv8.S2
-rw-r--r--third_party/boringssl/linux-aarch64/crypto/sha/sha256-armv8.S2
-rw-r--r--third_party/boringssl/linux-aarch64/crypto/sha/sha512-armv8.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/aes/aes-armv4.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/aes/aesv8-armx32.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/aes/bsaes-armv7.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/bn/armv4-mont.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/modes/ghash-armv4.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/modes/ghashv8-armx32.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/sha/sha1-armv4-large.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/sha/sha256-armv4.S2
-rw-r--r--third_party/boringssl/linux-arm/crypto/sha/sha512-armv4.S2
-rwxr-xr-xthird_party/boringssl/roll_boringssl.py124
22 files changed, 380 insertions, 247 deletions
diff --git a/third_party/boringssl/BUILD.gn b/third_party/boringssl/BUILD.gn
index a8fe16e..dba6a11 100644
--- a/third_party/boringssl/BUILD.gn
+++ b/third_party/boringssl/BUILD.gn
@@ -62,14 +62,7 @@ component("boringssl") {
]
# Also gets the include dirs from :openssl_config
- include_dirs = [
- "src/include",
-
- # This is for arm_arch.h, which is needed by some asm files. Since the
- # asm files are generated and kept in a different directory, they
- # cannot use relative paths to find this file.
- "src/crypto",
- ]
+ include_dirs = [ "src/include" ]
if (is_msan) {
defines += [ "OPENSSL_NO_ASM" ]
diff --git a/third_party/boringssl/boringssl.gyp b/third_party/boringssl/boringssl.gyp
index 5118fc7..653a70d 100644
--- a/third_party/boringssl/boringssl.gyp
+++ b/third_party/boringssl/boringssl.gyp
@@ -99,10 +99,6 @@
],
'include_dirs': [
'src/include',
- # This is for arm_arch.h, which is needed by some asm files. Since the
- # asm files are generated and kept in a different directory, they
- # cannot use relative paths to find this file.
- 'src/crypto',
],
'direct_dependent_settings': {
'include_dirs': [
diff --git a/third_party/boringssl/boringssl.gypi b/third_party/boringssl/boringssl.gypi
index 2c311c2..7ae8461 100644
--- a/third_party/boringssl/boringssl.gypi
+++ b/third_party/boringssl/boringssl.gypi
@@ -15,6 +15,7 @@
'src/ssl/d1_pkt.c',
'src/ssl/d1_srtp.c',
'src/ssl/d1_srvr.c',
+ 'src/ssl/dtls_record.c',
'src/ssl/pqueue/pqueue.c',
'src/ssl/s3_both.c',
'src/ssl/s3_clnt.c',
@@ -26,6 +27,7 @@
'src/ssl/ssl_aead_ctx.c',
'src/ssl/ssl_algs.c',
'src/ssl/ssl_asn1.c',
+ 'src/ssl/ssl_buffer.c',
'src/ssl/ssl_cert.c',
'src/ssl/ssl_cipher.c',
'src/ssl/ssl_lib.c',
@@ -35,6 +37,7 @@
'src/ssl/ssl_txt.c',
'src/ssl/t1_enc.c',
'src/ssl/t1_lib.c',
+ 'src/ssl/tls_record.c',
],
'boringssl_crypto_sources': [
'err_data.c',
diff --git a/third_party/boringssl/boringssl_nacl.gyp b/third_party/boringssl/boringssl_nacl.gyp
index e560c29..b99e002 100644
--- a/third_party/boringssl/boringssl_nacl.gyp
+++ b/third_party/boringssl/boringssl_nacl.gyp
@@ -31,10 +31,6 @@
],
'include_dirs': [
'src/include',
- # This is for arm_arch.h, which is needed by some asm files. Since the
- # asm files are generated and kept in a different directory, they
- # cannot use relative paths to find this file.
- 'src/crypto',
],
'direct_dependent_settings': {
'include_dirs': [
diff --git a/third_party/boringssl/boringssl_tests.gypi b/third_party/boringssl/boringssl_tests.gypi
index f9e919b..a864247 100644
--- a/third_party/boringssl/boringssl_tests.gypi
+++ b/third_party/boringssl/boringssl_tests.gypi
@@ -343,6 +343,20 @@
'msvs_disabled_warnings': [ 4267, ],
},
{
+ 'target_name': 'boringssl_pkcs8_test',
+ 'type': 'executable',
+ 'dependencies': [
+ 'boringssl.gyp:boringssl',
+ ],
+ 'sources': [
+ 'src/crypto/pkcs8/pkcs8_test.cc',
+ '<@(boringssl_test_support_sources)',
+ ],
+ # TODO(davidben): Fix size_t truncations in BoringSSL.
+ # https://crbug.com/429039
+ 'msvs_disabled_warnings': [ 4267, ],
+ },
+ {
'target_name': 'boringssl_poly1305_test',
'type': 'executable',
'dependencies': [
@@ -501,6 +515,7 @@
'boringssl_pbkdf_test',
'boringssl_pkcs12_test',
'boringssl_pkcs7_test',
+ 'boringssl_pkcs8_test',
'boringssl_poly1305_test',
'boringssl_pqueue_test',
'boringssl_refcount_test',
diff --git a/third_party/boringssl/boringssl_unittest.cc b/third_party/boringssl/boringssl_unittest.cc
index 75b9db8..8538c69 100644
--- a/third_party/boringssl/boringssl_unittest.cc
+++ b/third_party/boringssl/boringssl_unittest.cc
@@ -271,6 +271,10 @@ TEST(BoringSSL, PKCS7) {
TestSimple("pkcs7_test");
}
+TEST(BoringSSL, PKCS8) {
+ TestSimple("pkcs8_test");
+}
+
TEST(BoringSSL, PKCS12) {
TestSimple("pkcs12_test");
}
diff --git a/third_party/boringssl/err_data.c b/third_party/boringssl/err_data.c
index 9317cd1..258a5c3 100644
--- a/third_party/boringssl/err_data.c
+++ b/third_party/boringssl/err_data.c
@@ -189,43 +189,43 @@ const uint32_t kOpenSSLReasonValues[] = {
0x28328b9b,
0x28330b6c,
0x28338bae,
- 0x2c322be0,
- 0x2c32abee,
- 0x2c332c00,
- 0x2c33ac12,
- 0x2c342c26,
- 0x2c34ac38,
- 0x2c352c53,
- 0x2c35ac65,
- 0x2c362c78,
+ 0x2c322bfd,
+ 0x2c32ac0b,
+ 0x2c332c1d,
+ 0x2c33ac2f,
+ 0x2c342c43,
+ 0x2c34ac55,
+ 0x2c352c70,
+ 0x2c35ac82,
+ 0x2c362c95,
0x2c3682f3,
- 0x2c372c85,
- 0x2c37ac97,
- 0x2c382caa,
- 0x2c38acb8,
- 0x2c392cc8,
- 0x2c39acda,
- 0x2c3a2cee,
- 0x2c3aacff,
+ 0x2c372ca2,
+ 0x2c37acb4,
+ 0x2c382cc7,
+ 0x2c38acd5,
+ 0x2c392ce5,
+ 0x2c39acf7,
+ 0x2c3a2d0b,
+ 0x2c3aad1c,
0x2c3b1359,
- 0x2c3bad10,
- 0x2c3c2d24,
- 0x2c3cad3a,
- 0x2c3d2d53,
- 0x2c3dad81,
- 0x2c3e2d8f,
- 0x2c3eada7,
- 0x2c3f2dbf,
- 0x2c3fadcc,
- 0x2c402def,
- 0x2c40ae0e,
+ 0x2c3bad2d,
+ 0x2c3c2d41,
+ 0x2c3cad57,
+ 0x2c3d2d70,
+ 0x2c3dad9e,
+ 0x2c3e2dac,
+ 0x2c3eadc4,
+ 0x2c3f2ddc,
+ 0x2c3fade9,
+ 0x2c402e0c,
+ 0x2c40ae2b,
0x2c4111c3,
- 0x2c41ae1f,
- 0x2c422e32,
+ 0x2c41ae3c,
+ 0x2c422e4f,
0x2c429135,
- 0x2c432e43,
+ 0x2c432e60,
0x2c4386a2,
- 0x2c442d70,
+ 0x2c442d8d,
0x30320000,
0x30328015,
0x3033001f,
@@ -427,143 +427,144 @@ const uint32_t kOpenSSLReasonValues[] = {
0x40581eda,
0x40589eef,
0x40591f12,
- 0x40599f20,
- 0x405a1f2d,
- 0x405a9f46,
- 0x405b1f5e,
- 0x405b9f71,
- 0x405c1f86,
- 0x405c9f98,
- 0x405d1fad,
- 0x405d9fbd,
- 0x405e1fd6,
- 0x405e9fea,
- 0x405f1ffa,
- 0x405fa012,
- 0x40602023,
- 0x4060a036,
- 0x40612047,
- 0x4061a065,
- 0x40622076,
- 0x4062a083,
- 0x4063209a,
- 0x4063a0db,
- 0x406420f2,
- 0x4064a0ff,
- 0x4065210d,
- 0x4065a12f,
- 0x40662157,
- 0x4066a16c,
- 0x40672183,
- 0x4067a194,
- 0x406821a5,
- 0x4068a1b6,
- 0x406921cb,
- 0x4069a1e2,
- 0x406a21f3,
- 0x406aa20c,
- 0x406b2227,
- 0x406ba23e,
- 0x406c22ab,
- 0x406ca2cc,
- 0x406d22df,
- 0x406da300,
- 0x406e231b,
- 0x406ea364,
- 0x406f2385,
- 0x406fa3ab,
- 0x407023cb,
- 0x4070a3e7,
- 0x40712574,
- 0x4071a597,
- 0x407225ad,
- 0x4072a5cc,
- 0x407325e4,
- 0x4073a604,
- 0x4074282e,
- 0x4074a853,
- 0x4075286e,
- 0x4075a88d,
- 0x407628bc,
- 0x4076a8e4,
- 0x40772915,
- 0x4077a934,
- 0x4078296e,
- 0x4078a985,
- 0x40792998,
- 0x4079a9b5,
+ 0x40599f3d,
+ 0x405a1f4a,
+ 0x405a9f63,
+ 0x405b1f7b,
+ 0x405b9f8e,
+ 0x405c1fa3,
+ 0x405c9fb5,
+ 0x405d1fca,
+ 0x405d9fda,
+ 0x405e1ff3,
+ 0x405ea007,
+ 0x405f2017,
+ 0x405fa02f,
+ 0x40602040,
+ 0x4060a053,
+ 0x40612064,
+ 0x4061a082,
+ 0x40622093,
+ 0x4062a0a0,
+ 0x406320b7,
+ 0x4063a0f8,
+ 0x4064210f,
+ 0x4064a11c,
+ 0x4065212a,
+ 0x4065a14c,
+ 0x40662174,
+ 0x4066a189,
+ 0x406721a0,
+ 0x4067a1b1,
+ 0x406821c2,
+ 0x4068a1d3,
+ 0x406921e8,
+ 0x4069a1ff,
+ 0x406a2210,
+ 0x406aa229,
+ 0x406b2244,
+ 0x406ba25b,
+ 0x406c22c8,
+ 0x406ca2e9,
+ 0x406d22fc,
+ 0x406da31d,
+ 0x406e2338,
+ 0x406ea381,
+ 0x406f23a2,
+ 0x406fa3c8,
+ 0x407023e8,
+ 0x4070a404,
+ 0x40712591,
+ 0x4071a5b4,
+ 0x407225ca,
+ 0x4072a5e9,
+ 0x40732601,
+ 0x4073a621,
+ 0x4074284b,
+ 0x4074a870,
+ 0x4075288b,
+ 0x4075a8aa,
+ 0x407628d9,
+ 0x4076a901,
+ 0x40772932,
+ 0x4077a951,
+ 0x4078298b,
+ 0x4078a9a2,
+ 0x407929b5,
+ 0x4079a9d2,
0x407a0782,
- 0x407aa9c7,
- 0x407b29da,
- 0x407ba9f3,
- 0x407c2a0b,
+ 0x407aa9e4,
+ 0x407b29f7,
+ 0x407baa10,
+ 0x407c2a28,
0x407c90bd,
- 0x407d2a1f,
- 0x407daa39,
- 0x407e2a4a,
- 0x407eaa5e,
- 0x407f2a6c,
- 0x407faa87,
+ 0x407d2a3c,
+ 0x407daa56,
+ 0x407e2a67,
+ 0x407eaa7b,
+ 0x407f2a89,
+ 0x407faaa4,
0x40801286,
- 0x4080aaac,
- 0x40812ace,
- 0x4081aae9,
- 0x40822afe,
- 0x4082ab16,
- 0x40832b2e,
- 0x4083ab45,
- 0x40842b5b,
- 0x4084ab67,
- 0x40852b7a,
- 0x4085ab8f,
- 0x40862ba1,
- 0x4086abb6,
- 0x40872bbf,
+ 0x4080aac9,
+ 0x40812aeb,
+ 0x4081ab06,
+ 0x40822b1b,
+ 0x4082ab33,
+ 0x40832b4b,
+ 0x4083ab62,
+ 0x40842b78,
+ 0x4084ab84,
+ 0x40852b97,
+ 0x4085abac,
+ 0x40862bbe,
+ 0x4086abd3,
+ 0x40872bdc,
0x40879cd0,
0x40880083,
- 0x4088a0ba,
+ 0x4088a0d7,
0x40890a17,
- 0x4089a256,
+ 0x4089a273,
0x408a1bf0,
- 0x408aa280,
- 0x408b28fd,
- 0x408ba959,
- 0x408c2336,
+ 0x408aa29d,
+ 0x408b291a,
+ 0x408ba976,
+ 0x408c2353,
0x408c9c21,
0x408d1c56,
0x408d9e68,
0x408e1ab9,
0x408e9add,
- 0x41f4249f,
- 0x41f92531,
- 0x41fe2424,
- 0x41fea655,
- 0x41ff2746,
- 0x420324b8,
- 0x420824da,
- 0x4208a516,
- 0x42092408,
- 0x4209a550,
- 0x420a245f,
- 0x420aa43f,
- 0x420b247f,
- 0x420ba4f8,
- 0x420c2762,
- 0x420ca622,
- 0x420d263c,
- 0x420da673,
- 0x4212268d,
- 0x42172729,
- 0x4217a6cf,
- 0x421c26f1,
- 0x421f26ac,
- 0x42212779,
- 0x4226270c,
- 0x422b2812,
- 0x422ba7db,
- 0x422c27fa,
- 0x422ca7b5,
- 0x422d2794,
+ 0x408f1f20,
+ 0x41f424bc,
+ 0x41f9254e,
+ 0x41fe2441,
+ 0x41fea672,
+ 0x41ff2763,
+ 0x420324d5,
+ 0x420824f7,
+ 0x4208a533,
+ 0x42092425,
+ 0x4209a56d,
+ 0x420a247c,
+ 0x420aa45c,
+ 0x420b249c,
+ 0x420ba515,
+ 0x420c277f,
+ 0x420ca63f,
+ 0x420d2659,
+ 0x420da690,
+ 0x421226aa,
+ 0x42172746,
+ 0x4217a6ec,
+ 0x421c270e,
+ 0x421f26c9,
+ 0x42212796,
+ 0x42262729,
+ 0x422b282f,
+ 0x422ba7f8,
+ 0x422c2817,
+ 0x422ca7d2,
+ 0x422d27b1,
0x443206ad,
0x443286bc,
0x443306c8,
@@ -606,69 +607,69 @@ const uint32_t kOpenSSLReasonValues[] = {
0x4c3d10bd,
0x4c3d9449,
0x4c3e1456,
- 0x50322e55,
- 0x5032ae64,
- 0x50332e6f,
- 0x5033ae7f,
- 0x50342e98,
- 0x5034aeb2,
- 0x50352ec0,
- 0x5035aed6,
- 0x50362ee8,
- 0x5036aefe,
- 0x50372f17,
- 0x5037af2a,
- 0x50382f42,
- 0x5038af53,
- 0x50392f68,
- 0x5039af7c,
- 0x503a2f9c,
- 0x503aafb2,
- 0x503b2fca,
- 0x503bafdc,
- 0x503c2ff8,
- 0x503cb00f,
- 0x503d3028,
- 0x503db03e,
- 0x503e304b,
- 0x503eb061,
- 0x503f3073,
+ 0x50322e72,
+ 0x5032ae81,
+ 0x50332e8c,
+ 0x5033ae9c,
+ 0x50342eb5,
+ 0x5034aecf,
+ 0x50352edd,
+ 0x5035aef3,
+ 0x50362f05,
+ 0x5036af1b,
+ 0x50372f34,
+ 0x5037af47,
+ 0x50382f5f,
+ 0x5038af70,
+ 0x50392f85,
+ 0x5039af99,
+ 0x503a2fb9,
+ 0x503aafcf,
+ 0x503b2fe7,
+ 0x503baff9,
+ 0x503c3015,
+ 0x503cb02c,
+ 0x503d3045,
+ 0x503db05b,
+ 0x503e3068,
+ 0x503eb07e,
+ 0x503f3090,
0x503f8348,
- 0x50403086,
- 0x5040b096,
- 0x504130b0,
- 0x5041b0bf,
- 0x504230d9,
- 0x5042b0f6,
- 0x50433106,
- 0x5043b116,
- 0x50443125,
+ 0x504030a3,
+ 0x5040b0b3,
+ 0x504130cd,
+ 0x5041b0dc,
+ 0x504230f6,
+ 0x5042b113,
+ 0x50433123,
+ 0x5043b133,
+ 0x50443142,
0x50448414,
- 0x50453139,
- 0x5045b157,
- 0x5046316a,
- 0x5046b180,
- 0x50473192,
- 0x5047b1a7,
- 0x504831cd,
- 0x5048b1db,
- 0x504931ee,
- 0x5049b203,
- 0x504a3219,
- 0x504ab229,
- 0x504b3249,
- 0x504bb25c,
- 0x504c327f,
- 0x504cb2ad,
- 0x504d32bf,
- 0x504db2dc,
- 0x504e32f7,
- 0x504eb313,
- 0x504f3325,
- 0x504fb33c,
- 0x5050334b,
+ 0x50453156,
+ 0x5045b174,
+ 0x50463187,
+ 0x5046b19d,
+ 0x504731af,
+ 0x5047b1c4,
+ 0x504831ea,
+ 0x5048b1f8,
+ 0x5049320b,
+ 0x5049b220,
+ 0x504a3236,
+ 0x504ab246,
+ 0x504b3266,
+ 0x504bb279,
+ 0x504c329c,
+ 0x504cb2ca,
+ 0x504d32dc,
+ 0x504db2f9,
+ 0x504e3314,
+ 0x504eb330,
+ 0x504f3342,
+ 0x504fb359,
+ 0x50503368,
0x50508687,
- 0x5051335e,
+ 0x5051337b,
0x58320e1f,
0x68320de1,
0x68328b9b,
@@ -1103,6 +1104,7 @@ const char kOpenSSLReasonStringData[] =
"MISSING_TMP_ECDH_KEY\0"
"MIXED_SPECIAL_OPERATOR_WITH_GROUPS\0"
"MTU_TOO_SMALL\0"
+ "NEGOTIATED_BOTH_NPN_AND_ALPN\0"
"NESTED_GROUP\0"
"NO_CERTIFICATES_RETURNED\0"
"NO_CERTIFICATE_ASSIGNED\0"
diff --git a/third_party/boringssl/linux-aarch64/crypto/aes/aesv8-armx64.S b/third_party/boringssl/linux-aarch64/crypto/aes/aesv8-armx64.S
index c414476..fa2abbc 100644
--- a/third_party/boringssl/linux-aarch64/crypto/aes/aesv8-armx64.S
+++ b/third_party/boringssl/linux-aarch64/crypto/aes/aesv8-armx64.S
@@ -1,5 +1,5 @@
#if defined(__aarch64__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
#if __ARM_MAX_ARCH__>=7
.text
diff --git a/third_party/boringssl/linux-aarch64/crypto/modes/ghashv8-armx64.S b/third_party/boringssl/linux-aarch64/crypto/modes/ghashv8-armx64.S
index bc9a156..8d44667 100644
--- a/third_party/boringssl/linux-aarch64/crypto/modes/ghashv8-armx64.S
+++ b/third_party/boringssl/linux-aarch64/crypto/modes/ghashv8-armx64.S
@@ -1,5 +1,5 @@
#if defined(__aarch64__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
#if !defined(__clang__)
diff --git a/third_party/boringssl/linux-aarch64/crypto/sha/sha1-armv8.S b/third_party/boringssl/linux-aarch64/crypto/sha/sha1-armv8.S
index 487a497..6cf9877e 100644
--- a/third_party/boringssl/linux-aarch64/crypto/sha/sha1-armv8.S
+++ b/third_party/boringssl/linux-aarch64/crypto/sha/sha1-armv8.S
@@ -1,5 +1,5 @@
#if defined(__aarch64__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
diff --git a/third_party/boringssl/linux-aarch64/crypto/sha/sha256-armv8.S b/third_party/boringssl/linux-aarch64/crypto/sha/sha256-armv8.S
index 4834553..0fad009 100644
--- a/third_party/boringssl/linux-aarch64/crypto/sha/sha256-armv8.S
+++ b/third_party/boringssl/linux-aarch64/crypto/sha/sha256-armv8.S
@@ -1,5 +1,5 @@
#if defined(__aarch64__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
diff --git a/third_party/boringssl/linux-aarch64/crypto/sha/sha512-armv8.S b/third_party/boringssl/linux-aarch64/crypto/sha/sha512-armv8.S
index 654c473..517c033 100644
--- a/third_party/boringssl/linux-aarch64/crypto/sha/sha512-armv8.S
+++ b/third_party/boringssl/linux-aarch64/crypto/sha/sha512-armv8.S
@@ -1,5 +1,5 @@
#if defined(__aarch64__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
diff --git a/third_party/boringssl/linux-arm/crypto/aes/aes-armv4.S b/third_party/boringssl/linux-arm/crypto/aes/aes-armv4.S
index cb94841..c4d7065 100644
--- a/third_party/boringssl/linux-arm/crypto/aes/aes-armv4.S
+++ b/third_party/boringssl/linux-arm/crypto/aes/aes-armv4.S
@@ -34,7 +34,7 @@
#if defined(__arm__)
#ifndef __KERNEL__
-# include "arm_arch.h"
+# include <openssl/arm_arch.h>
#else
# define __ARM_ARCH__ __LINUX_ARM_ARCH__
#endif
diff --git a/third_party/boringssl/linux-arm/crypto/aes/aesv8-armx32.S b/third_party/boringssl/linux-arm/crypto/aes/aesv8-armx32.S
index 6f0ee7d..6012b0c 100644
--- a/third_party/boringssl/linux-arm/crypto/aes/aesv8-armx32.S
+++ b/third_party/boringssl/linux-arm/crypto/aes/aesv8-armx32.S
@@ -1,5 +1,5 @@
#if defined(__arm__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
#if __ARM_MAX_ARCH__>=7
.text
diff --git a/third_party/boringssl/linux-arm/crypto/aes/bsaes-armv7.S b/third_party/boringssl/linux-arm/crypto/aes/bsaes-armv7.S
index dd84f35..85262d5 100644
--- a/third_party/boringssl/linux-arm/crypto/aes/bsaes-armv7.S
+++ b/third_party/boringssl/linux-arm/crypto/aes/bsaes-armv7.S
@@ -49,7 +49,7 @@
#if defined(__arm__)
#ifndef __KERNEL__
-# include "arm_arch.h"
+# include <openssl/arm_arch.h>
# define VFP_ABI_PUSH vstmdb sp!,{d8-d15}
# define VFP_ABI_POP vldmia sp!,{d8-d15}
diff --git a/third_party/boringssl/linux-arm/crypto/bn/armv4-mont.S b/third_party/boringssl/linux-arm/crypto/bn/armv4-mont.S
index 68dfb2c..fc671e8 100644
--- a/third_party/boringssl/linux-arm/crypto/bn/armv4-mont.S
+++ b/third_party/boringssl/linux-arm/crypto/bn/armv4-mont.S
@@ -1,5 +1,5 @@
#if defined(__arm__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
.code 32
diff --git a/third_party/boringssl/linux-arm/crypto/modes/ghash-armv4.S b/third_party/boringssl/linux-arm/crypto/modes/ghash-armv4.S
index c6f025d..f868c2d 100644
--- a/third_party/boringssl/linux-arm/crypto/modes/ghash-armv4.S
+++ b/third_party/boringssl/linux-arm/crypto/modes/ghash-armv4.S
@@ -1,6 +1,6 @@
#if defined(__arm__)
#if defined(__arm__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.syntax unified
diff --git a/third_party/boringssl/linux-arm/crypto/modes/ghashv8-armx32.S b/third_party/boringssl/linux-arm/crypto/modes/ghashv8-armx32.S
index ea177b6..9a38ded 100644
--- a/third_party/boringssl/linux-arm/crypto/modes/ghashv8-armx32.S
+++ b/third_party/boringssl/linux-arm/crypto/modes/ghashv8-armx32.S
@@ -1,5 +1,5 @@
#if defined(__arm__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
.fpu neon
diff --git a/third_party/boringssl/linux-arm/crypto/sha/sha1-armv4-large.S b/third_party/boringssl/linux-arm/crypto/sha/sha1-armv4-large.S
index 4911458..66d0ef3 100644
--- a/third_party/boringssl/linux-arm/crypto/sha/sha1-armv4-large.S
+++ b/third_party/boringssl/linux-arm/crypto/sha/sha1-armv4-large.S
@@ -1,5 +1,5 @@
#if defined(__arm__)
-#include "arm_arch.h"
+#include <openssl/arm_arch.h>
.text
.code 32
diff --git a/third_party/boringssl/linux-arm/crypto/sha/sha256-armv4.S b/third_party/boringssl/linux-arm/crypto/sha/sha256-armv4.S
index ac9f2f1..9fc3e0b 100644
--- a/third_party/boringssl/linux-arm/crypto/sha/sha256-armv4.S
+++ b/third_party/boringssl/linux-arm/crypto/sha/sha256-armv4.S
@@ -38,7 +38,7 @@
@ Add ARMv8 code path performing at 2.0 cpb on Apple A7.
#ifndef __KERNEL__
-# include "arm_arch.h"
+# include <openssl/arm_arch.h>
#else
# define __ARM_ARCH__ __LINUX_ARM_ARCH__
# define __ARM_MAX_ARCH__ 7
diff --git a/third_party/boringssl/linux-arm/crypto/sha/sha512-armv4.S b/third_party/boringssl/linux-arm/crypto/sha/sha512-armv4.S
index c794f87..834ede9 100644
--- a/third_party/boringssl/linux-arm/crypto/sha/sha512-armv4.S
+++ b/third_party/boringssl/linux-arm/crypto/sha/sha512-armv4.S
@@ -47,7 +47,7 @@
@ was reflected in below two parameters as 0 and 4. Now caller is
@ expected to maintain native byte order for whole 64-bit values.
#ifndef __KERNEL__
-# include "arm_arch.h"
+# include <openssl/arm_arch.h>
# define VFP_ABI_PUSH vstmdb sp!,{d8-d15}
# define VFP_ABI_POP vldmia sp!,{d8-d15}
#else
diff --git a/third_party/boringssl/roll_boringssl.py b/third_party/boringssl/roll_boringssl.py
new file mode 100755
index 0000000..884df5b
--- /dev/null
+++ b/third_party/boringssl/roll_boringssl.py
@@ -0,0 +1,124 @@
+#!/usr/bin/env python
+# Copyright 2015 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+"""Rolls third_party/boringssl/src in DEPS and updates generated build files."""
+
+import os
+import os.path
+import shutil
+import subprocess
+import sys
+
+
+SCRIPT_PATH = os.path.abspath(__file__)
+SRC_PATH = os.path.dirname(os.path.dirname(os.path.dirname(SCRIPT_PATH)))
+DEPS_PATH = os.path.join(SRC_PATH, 'DEPS')
+BORINGSSL_PATH = os.path.join(SRC_PATH, 'third_party', 'boringssl')
+BORINGSSL_SRC_PATH = os.path.join(BORINGSSL_PATH, 'src')
+
+if not os.path.isfile(DEPS_PATH) or not os.path.isdir(BORINGSSL_SRC_PATH):
+ raise Exception('Could not find Chromium checkout')
+
+# Pull OS_ARCH_COMBOS out of the BoringSSL script.
+sys.path.append(os.path.join(BORINGSSL_SRC_PATH, 'util'))
+import generate_build_files
+
+GENERATED_FILES = [
+ 'boringssl.gypi',
+ 'boringssl_tests.gypi',
+ 'err_data.c',
+]
+
+
+def IsPristine(repo):
+ """Returns True if a git checkout is pristine."""
+ cmd = ['git', 'diff', '--ignore-submodules']
+ return not (subprocess.check_output(cmd, cwd=repo).strip() or
+ subprocess.check_output(cmd + ['--cached'], cwd=repo).strip())
+
+
+def RevParse(repo, rev):
+ """Resolves a string to a git commit."""
+ return subprocess.check_output(['git', 'rev-parse', rev], cwd=repo).strip()
+
+
+def UpdateDEPS(deps, from_hash, to_hash):
+ """Updates all references of |from_hash| to |to_hash| in |deps|."""
+ with open(deps, 'rb') as f:
+ contents = f.read()
+ if from_hash not in contents:
+ raise Exception('%s not in DEPS' % from_hash)
+ contents = contents.replace(from_hash, to_hash)
+ with open(deps, 'wb') as f:
+ f.write(contents)
+
+
+def main():
+ if len(sys.argv) > 2:
+ sys.stderr.write('Usage: %s [COMMIT]' % sys.argv[0])
+ return 1
+
+ if not IsPristine(SRC_PATH):
+ print >>sys.stderr, 'Chromium checkout not pristine.'
+ return 0
+ if not IsPristine(BORINGSSL_SRC_PATH):
+ print >>sys.stderr, 'BoringSSL checkout not pristine.'
+ return 0
+
+ if len(sys.argv) > 1:
+ commit = RevParse(BORINGSSL_SRC_PATH, sys.argv[1])
+ else:
+ subprocess.check_call(['git', 'fetch', 'origin'], cwd=BORINGSSL_SRC_PATH)
+ commit = RevParse(BORINGSSL_SRC_PATH, 'origin/master')
+
+ head = RevParse(BORINGSSL_SRC_PATH, 'HEAD')
+ if head == commit:
+ print 'BoringSSL already up-to-date.'
+ return 0
+
+ print 'Rolling BoringSSL from %s to %s...' % (head, commit)
+
+ UpdateDEPS(DEPS_PATH, head, commit)
+
+ # Checkout third_party/boringssl/src to generate new files.
+ subprocess.check_call(['git', 'checkout', commit], cwd=BORINGSSL_SRC_PATH)
+
+ # Clear the old generated files.
+ for (osname, arch, _, _, _) in generate_build_files.OS_ARCH_COMBOS:
+ path = os.path.join(BORINGSSL_PATH, osname + '-' + arch)
+ shutil.rmtree(path)
+ for file in GENERATED_FILES:
+ path = os.path.join(BORINGSSL_PATH, file)
+ os.unlink(path)
+
+ # Generate new ones.
+ subprocess.check_call(['python',
+ os.path.join(BORINGSSL_SRC_PATH, 'util',
+ 'generate_build_files.py'),
+ 'gyp'],
+ cwd=BORINGSSL_PATH)
+
+ # Commit everything.
+ subprocess.check_call(['git', 'add', DEPS_PATH], cwd=SRC_PATH)
+ for (osname, arch, _, _, _) in generate_build_files.OS_ARCH_COMBOS:
+ path = os.path.join(BORINGSSL_PATH, osname + '-' + arch)
+ subprocess.check_call(['git', 'add', path], cwd=SRC_PATH)
+ for file in GENERATED_FILES:
+ path = os.path.join(BORINGSSL_PATH, file)
+ subprocess.check_call(['git', 'add', path], cwd=SRC_PATH)
+
+ message = """Roll src/third_party/boringssl/src %s..%s
+
+https://boringssl.googlesource.com/boringssl/+log/%s..%s
+
+BUG=none
+""" % (head[:9], commit[:9], head, commit)
+ subprocess.check_call(['git', 'commit', '-m', message], cwd=SRC_PATH)
+
+ return 0
+
+
+if __name__ == '__main__':
+ sys.exit(main())