-
Notifications
You must be signed in to change notification settings - Fork 4.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0e3648d
commit 8684b69
Showing
2 changed files
with
293 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
# http://cgit.openembedded.org/meta-openembedded/tree/meta-webserver/recipes-httpd/nginx/files/0001-Allow-the-overriding-of-the-endianness-via-the-confi.patch | ||
From be9970aa16c5142ef814531d74a07990a8e9eb14 Mon Sep 17 00:00:00 2001 | ||
From: Derek Straka <[email protected]> | ||
Date: Fri, 1 Dec 2017 10:32:29 -0500 | ||
Subject: [PATCH] Allow the overriding of the endianness via the configure flag | ||
--with-endian | ||
|
||
The existing configure options contain the --with-endian; however, the command | ||
line flag does not actually function. It does not set the endianness and it | ||
appears to do nothing. | ||
|
||
Upstream-Status: Pending | ||
|
||
Signed-off-by: Derek Straka <[email protected]> | ||
|
||
diff --git a/auto/endianness b/auto/endianness | ||
index 1b552b6..be84487 100644 | ||
--- a/bundle/nginx-1.19.9/endianness | ||
+++ b/bundle/nginx-1.19.9/auto/endianness | ||
@@ -13,7 +13,13 @@ checking for system byte ordering | ||
END | ||
|
||
|
||
-cat << END > $NGX_AUTOTEST.c | ||
+if [ ".$NGX_WITH_ENDIAN" = ".little" ]; then | ||
+ echo " little endian" | ||
+ have=NGX_HAVE_LITTLE_ENDIAN . auto/have | ||
+elif [ ".$NGX_WITH_ENDIAN" = ".big" ]; then | ||
+ echo " big endian" | ||
+else | ||
+ cat << END > $NGX_AUTOTEST.c | ||
|
||
int main(void) { | ||
int i = 0x11223344; | ||
@@ -26,25 +32,26 @@ int main(void) { | ||
|
||
END | ||
|
||
-ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ | ||
- -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" | ||
+ ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ | ||
+ -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" | ||
|
||
-eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" | ||
+ eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" | ||
|
||
-if [ -x $NGX_AUTOTEST ]; then | ||
- if $NGX_AUTOTEST >/dev/null 2>&1; then | ||
- echo " little endian" | ||
- have=NGX_HAVE_LITTLE_ENDIAN . auto/have | ||
- else | ||
- echo " big endian" | ||
- fi | ||
+ if [ -x $NGX_AUTOTEST ]; then | ||
+ if $NGX_AUTOTEST >/dev/null 2>&1; then | ||
+ echo " little endian" | ||
+ have=NGX_HAVE_LITTLE_ENDIAN . auto/have | ||
+ else | ||
+ echo " big endian" | ||
+ fi | ||
|
||
- rm -rf $NGX_AUTOTEST* | ||
+ rm -rf $NGX_AUTOTEST* | ||
|
||
-else | ||
- rm -rf $NGX_AUTOTEST* | ||
+ else | ||
+ rm -rf $NGX_AUTOTEST* | ||
|
||
- echo | ||
- echo "$0: error: cannot detect system byte ordering" | ||
- exit 1 | ||
+ echo | ||
+ echo "$0: error: cannot detect system byte ordering" | ||
+ exit 1 | ||
+ fi | ||
fi | ||
-- | ||
2.7.4 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,214 @@ | ||
Rebased from http://cgit.openembedded.org/meta-openembedded/tree/meta-webserver/recipes-httpd/nginx/files/nginx-cross.patch | ||
|
||
|
||
=================================================================== | ||
diff --git a/bundle/nginx-1.19.9/auto/feature b/bundle/nginx-1.19.9/auto/feature | ||
index 3561f59..d6a2889 100644 | ||
--- a/bundle/nginx-1.19.9/auto/feature | ||
+++ b/bundle/nginx-1.19.9/auto/feature | ||
@@ -49,12 +49,20 @@ eval "/bin/sh -c \"$ngx_test\" >> $NGX_AUTOCONF_ERR 2>&1" | ||
|
||
if [ -x $NGX_AUTOTEST ]; then | ||
|
||
+ if [ ".$NGX_CROSS_COMPILE" = ".yes" ]; then | ||
+ NGX_AUTOTEST_EXEC="true" | ||
+ NGX_FOUND_MSG=" (not tested, cross compiling)" | ||
+ else | ||
+ NGX_AUTOTEST_EXEC="$NGX_AUTOTEST" | ||
+ NGX_FOUND_MSG="" | ||
+ fi | ||
+ | ||
case "$ngx_feature_run" in | ||
|
||
yes) | ||
# /bin/sh is used to intercept "Killed" or "Abort trap" messages | ||
- if /bin/sh -c $NGX_AUTOTEST >> $NGX_AUTOCONF_ERR 2>&1; then | ||
- echo " found" | ||
+ if /bin/sh -c $NGX_AUTOTEST_EXEC >> $NGX_AUTOCONF_ERR 2>&1; then | ||
+ echo " found$NGX_FOUND_MSG" | ||
ngx_found=yes | ||
|
||
if test -n "$ngx_feature_name"; then | ||
@@ -68,17 +76,27 @@ if [ -x $NGX_AUTOTEST ]; then | ||
|
||
value) | ||
# /bin/sh is used to intercept "Killed" or "Abort trap" messages | ||
- if /bin/sh -c $NGX_AUTOTEST >> $NGX_AUTOCONF_ERR 2>&1; then | ||
- echo " found" | ||
+ if /bin/sh -c $NGX_AUTOTEST_EXEC >> $NGX_AUTOCONF_ERR 2>&1; then | ||
+ echo " found$NGX_FOUND_MSG" | ||
ngx_found=yes | ||
|
||
- cat << END >> $NGX_AUTO_CONFIG_H | ||
+ if [ ".$NGX_CROSS_COMPILE" = ".yes" ]; then | ||
+ cat << END >> $NGX_AUTO_CONFIG_H | ||
|
||
#ifndef $ngx_feature_name | ||
-#define $ngx_feature_name `$NGX_AUTOTEST` | ||
+#define $ngx_feature_name $(eval "echo \$NGX_WITH_${ngx_feature_name}") | ||
#endif | ||
|
||
END | ||
+ else | ||
+ cat << END >> $NGX_AUTO_CONFIG_H | ||
+ | ||
+#ifndef $ngx_feature_name | ||
+#define $ngx_feature_name `$NGX_AUTOTEST_EXEC` | ||
+#endif | ||
+ | ||
+END | ||
+ fi | ||
else | ||
echo " found but is not working" | ||
fi | ||
@@ -86,7 +104,7 @@ END | ||
|
||
bug) | ||
# /bin/sh is used to intercept "Killed" or "Abort trap" messages | ||
- if /bin/sh -c $NGX_AUTOTEST >> $NGX_AUTOCONF_ERR 2>&1; then | ||
+ if /bin/sh -c $NGX_AUTOTEST_EXEC >> $NGX_AUTOCONF_ERR 2>&1; then | ||
echo " not found" | ||
|
||
else | ||
diff --git a/bundle/nginx-1.19.9/auto/options b/bundle/nginx-1.19.9/auto/options | ||
index 182c799..e9eb7b8 100644 | ||
--- a/bundle/nginx-1.19.9/auto/options | ||
+++ b/bundle/nginx-1.19.9/auto/options | ||
@@ -400,6 +400,18 @@ $0: warning: the \"--with-sha1-asm\" option is deprecated" | ||
--test-build-epoll) NGX_TEST_BUILD_EPOLL=YES ;; | ||
--test-build-solaris-sendfilev) NGX_TEST_BUILD_SOLARIS_SENDFILEV=YES ;; | ||
|
||
+ # cross compile support | ||
+ --with-int=*) NGX_WITH_INT="$value" ;; | ||
+ --with-long=*) NGX_WITH_LONG="$value" ;; | ||
+ --with-long-long=*) NGX_WITH_LONG_LONG="$value" ;; | ||
+ --with-ptr-size=*) NGX_WITH_PTR_SIZE="$value" ;; | ||
+ --with-sig-atomic-t=*) NGX_WITH_SIG_ATOMIC_T="$value" ;; | ||
+ --with-size-t=*) NGX_WITH_SIZE_T="$value" ;; | ||
+ --with-off-t=*) NGX_WITH_OFF_T="$value" ;; | ||
+ --with-time-t=*) NGX_WITH_TIME_T="$value" ;; | ||
+ --with-sys-nerr=*) NGX_WITH_NGX_SYS_NERR="$value" ;; | ||
+ --with-endian=*) NGX_WITH_ENDIAN="$value" ;; | ||
+ | ||
*) | ||
echo "$0: error: invalid option \"$option\"" | ||
exit 1 | ||
@@ -590,6 +602,17 @@ cat << END | ||
|
||
--with-debug enable debug logging | ||
|
||
+ --with-int=VALUE force int size | ||
+ --with-long=VALUE force long size | ||
+ --with-long-long=VALUE force long long size | ||
+ --with-ptr-size=VALUE force pointer size | ||
+ --with-sig-atomic-t=VALUE force sig_atomic_t size | ||
+ --with-size-t=VALUE force size_t size | ||
+ --with-off-t=VALUE force off_t size | ||
+ --with-time-t=VALUE force time_t size | ||
+ --with-sys-nerr=VALUE force sys_nerr value | ||
+ --with-endian=VALUE force system endianess | ||
+ | ||
END | ||
|
||
exit 1 | ||
@@ -598,6 +621,8 @@ fi | ||
|
||
if [ ".$NGX_PLATFORM" = ".win32" ]; then | ||
NGX_WINE=$WINE | ||
+elif [ ! -z "$NGX_PLATFORM" ]; then | ||
+ NGX_CROSS_COMPILE="yes" | ||
fi | ||
|
||
|
||
diff --git a/bundle/nginx-1.19.9/auto/types/sizeof b/bundle/nginx-1.19.9/auto/types/sizeof | ||
index 480d8cf..23c5171 100644 | ||
--- a/bundle/nginx-1.19.9/auto/types/sizeof | ||
+++ b/bundle/nginx-1.19.9/auto/types/sizeof | ||
@@ -12,9 +12,12 @@ checking for $ngx_type size | ||
|
||
END | ||
|
||
-ngx_size= | ||
+ngx_size=$(eval "echo \$NGX_WITH_${ngx_param}") | ||
|
||
-cat << END > $NGX_AUTOTEST.c | ||
+if [ ".$ngx_size" != "." ]; then | ||
+ echo " $ngx_size bytes" | ||
+else | ||
+ cat << END > $NGX_AUTOTEST.c | ||
|
||
#include <sys/types.h> | ||
#include <sys/time.h> | ||
@@ -33,15 +36,16 @@ int main(void) { | ||
END | ||
|
||
|
||
-ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ | ||
- -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" | ||
+ ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ | ||
+ -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" | ||
|
||
-eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" | ||
+ eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" | ||
|
||
|
||
-if [ -x $NGX_AUTOTEST ]; then | ||
- ngx_size=`$NGX_AUTOTEST` | ||
- echo " $ngx_size bytes" | ||
+ if [ -x $NGX_AUTOTEST ]; then | ||
+ ngx_size=`$NGX_AUTOTEST` | ||
+ echo " $ngx_size bytes" | ||
+ fi | ||
fi | ||
|
||
|
||
diff --git a/bundle/nginx-1.19.9/auto/unix b/bundle/nginx-1.19.9/auto/unix | ||
index b41c70f..febbf3c 100644 | ||
--- a/bundle/nginx-1.19.9/auto/unix | ||
+++ b/bundle/nginx-1.19.9/auto/unix | ||
@@ -592,13 +592,13 @@ ngx_feature_libs= | ||
|
||
# C types | ||
|
||
-ngx_type="int"; . auto/types/sizeof | ||
+ngx_type="int"; ngx_param="INT"; . auto/types/sizeof | ||
|
||
-ngx_type="long"; . auto/types/sizeof | ||
+ngx_type="long"; ngx_param="LONG"; . auto/types/sizeof | ||
|
||
-ngx_type="long long"; . auto/types/sizeof | ||
+ngx_type="long long"; ngx_param="LONG_LONG"; . auto/types/sizeof | ||
|
||
-ngx_type="void *"; . auto/types/sizeof; ngx_ptr_size=$ngx_size | ||
+ngx_type="void *"; ngx_param="PTR_SIZE"; . auto/types/sizeof; ngx_ptr_size=$ngx_size | ||
ngx_param=NGX_PTR_SIZE; ngx_value=$ngx_size; . auto/types/value | ||
|
||
|
||
@@ -609,7 +609,7 @@ NGX_INCLUDE_AUTO_CONFIG_H="#include \"ngx_auto_config.h\"" | ||
ngx_type="uint32_t"; ngx_types="u_int32_t"; . auto/types/typedef | ||
ngx_type="uint64_t"; ngx_types="u_int64_t"; . auto/types/typedef | ||
|
||
-ngx_type="sig_atomic_t"; ngx_types="int"; . auto/types/typedef | ||
+ngx_type="sig_atomic_t"; ngx_param="SIG_ATOMIC_T"; ngx_types="int"; . auto/types/typedef | ||
. auto/types/sizeof | ||
ngx_param=NGX_SIG_ATOMIC_T_SIZE; ngx_value=$ngx_size; . auto/types/value | ||
|
||
@@ -625,15 +625,15 @@ ngx_type="rlim_t"; ngx_types="int"; . auto/types/typedef | ||
|
||
. auto/endianness | ||
|
||
-ngx_type="size_t"; . auto/types/sizeof | ||
+ngx_type="size_t"; ngx_param="SIZE_T"; . auto/types/sizeof | ||
ngx_param=NGX_MAX_SIZE_T_VALUE; ngx_value=$ngx_max_value; . auto/types/value | ||
ngx_param=NGX_SIZE_T_LEN; ngx_value=$ngx_max_len; . auto/types/value | ||
|
||
-ngx_type="off_t"; . auto/types/sizeof | ||
+ngx_type="off_t"; ngx_param="OFF_T"; . auto/types/sizeof | ||
ngx_param=NGX_MAX_OFF_T_VALUE; ngx_value=$ngx_max_value; . auto/types/value | ||
ngx_param=NGX_OFF_T_LEN; ngx_value=$ngx_max_len; . auto/types/value | ||
|
||
-ngx_type="time_t"; . auto/types/sizeof | ||
+ngx_type="time_t"; ngx_param="TIME_T"; . auto/types/sizeof | ||
ngx_param=NGX_TIME_T_SIZE; ngx_value=$ngx_size; . auto/types/value | ||
ngx_param=NGX_TIME_T_LEN; ngx_value=$ngx_max_len; . auto/types/value | ||
ngx_param=NGX_MAX_TIME_T_VALUE; ngx_value=$ngx_max_value; . auto/types/value |