Workaround for use of GetTickCount64() in nghttp2 library.
This commit is contained in:
parent
eacdcf6cd9
commit
21517a7517
1
build.sh
1
build.sh
@ -172,6 +172,7 @@ readonly NGH2_DIR="${BASE_DIR}/nghttp2-${MY_CPU}"
|
|||||||
rm -rf "${NGH2_DIR}" && mkdir "${NGH2_DIR}"
|
rm -rf "${NGH2_DIR}" && mkdir "${NGH2_DIR}"
|
||||||
tar -xvf "${LIBS_DIR}/.pkg/nghttp2.tar.gz" --strip-components=1 -C "${NGH2_DIR}"
|
tar -xvf "${LIBS_DIR}/.pkg/nghttp2.tar.gz" --strip-components=1 -C "${NGH2_DIR}"
|
||||||
pushd "${NGH2_DIR}"
|
pushd "${NGH2_DIR}"
|
||||||
|
patch -p1 -b < "${BASE_DIR}/patch/nghttp2_time.diff"
|
||||||
CFLAGS="-march=${MY_MARCH} -mtune=${MY_MTUNE} -DNDEBUG -D_WIN32_WINNT=0x0501 -I${LIBS_DIR}/include" LDFLAGS="-L${LIBS_DIR}/lib" OPENSSL_CFLAGS="-I${LIBS_DIR}/include" OPENSSL_LIBS="-L${LIBS_DIR}/lib -lssl -lcrypto" ZLIB_CFLAGS="-I${LIBS_DIR}/include" ZLIB_LIBS="-L${LIBS_DIR}/lib -lz" ./configure --prefix="${LIBS_DIR}" --enable-lib-only --disable-threads --disable-shared
|
CFLAGS="-march=${MY_MARCH} -mtune=${MY_MTUNE} -DNDEBUG -D_WIN32_WINNT=0x0501 -I${LIBS_DIR}/include" LDFLAGS="-L${LIBS_DIR}/lib" OPENSSL_CFLAGS="-I${LIBS_DIR}/include" OPENSSL_LIBS="-L${LIBS_DIR}/lib -lssl -lcrypto" ZLIB_CFLAGS="-I${LIBS_DIR}/include" ZLIB_LIBS="-L${LIBS_DIR}/lib -lz" ./configure --prefix="${LIBS_DIR}" --enable-lib-only --disable-threads --disable-shared
|
||||||
make && make install
|
make && make install
|
||||||
popd
|
popd
|
||||||
|
45
patch/nghttp2_time.diff
Normal file
45
patch/nghttp2_time.diff
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
diff --git "a/lib/nghttp2_time.c" "b/lib/nghttp2_time.c"
|
||||||
|
index 897556f..ab06684 100644
|
||||||
|
--- "a/lib/nghttp2_time.c"
|
||||||
|
+++ "b/lib/nghttp2_time.c"
|
||||||
|
@@ -32,31 +32,15 @@
|
||||||
|
# include <sysinfoapi.h>
|
||||||
|
#endif /* HAVE_SYSINFOAPI_H */
|
||||||
|
|
||||||
|
-#if !defined(HAVE_GETTICKCOUNT64) || defined(__CYGWIN__)
|
||||||
|
-static uint64_t time_now_sec(void) {
|
||||||
|
- time_t t = time(NULL);
|
||||||
|
+uint64_t nghttp2_time_now_sec(void)
|
||||||
|
+{
|
||||||
|
+ FILETIME file_time;
|
||||||
|
+ ULARGE_INTEGER time_value;
|
||||||
|
+
|
||||||
|
+ GetSystemTimeAsFileTime(&file_time);
|
||||||
|
|
||||||
|
- if (t == -1) {
|
||||||
|
- return 0;
|
||||||
|
- }
|
||||||
|
+ time_value.LowPart = file_time.dwLowDateTime;
|
||||||
|
+ time_value.HighPart = file_time.dwHighDateTime;
|
||||||
|
|
||||||
|
- return (uint64_t)t;
|
||||||
|
+ return time_value.QuadPart / 10000000ULL;
|
||||||
|
}
|
||||||
|
-#endif /* !HAVE_GETTICKCOUNT64 || __CYGWIN__ */
|
||||||
|
-
|
||||||
|
-#if defined(HAVE_GETTICKCOUNT64) && !defined(__CYGWIN__)
|
||||||
|
-uint64_t nghttp2_time_now_sec(void) { return GetTickCount64() / 1000; }
|
||||||
|
-#elif defined(HAVE_CLOCK_GETTIME)
|
||||||
|
-uint64_t nghttp2_time_now_sec(void) {
|
||||||
|
- struct timespec tp;
|
||||||
|
- int rv = clock_gettime(CLOCK_MONOTONIC, &tp);
|
||||||
|
-
|
||||||
|
- if (rv == -1) {
|
||||||
|
- return time_now_sec();
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- return (uint64_t)tp.tv_sec;
|
||||||
|
-}
|
||||||
|
-#else /* (!HAVE_CLOCK_GETTIME || __CYGWIN__) && !HAVE_GETTICKCOUNT64 */
|
||||||
|
-uint64_t nghttp2_time_now_sec(void) { return time_now_sec(); }
|
||||||
|
-#endif /* (!HAVE_CLOCK_GETTIME || __CYGWIN__) && !HAVE_GETTICKCOUNT64 */
|
Loading…
Reference in New Issue
Block a user