diff options
author | James Almer <jamrial@gmail.com> | 2018-03-29 20:40:07 -0300 |
---|---|---|
committer | James Almer <jamrial@gmail.com> | 2018-03-29 20:40:07 -0300 |
commit | 23f447294487958e0c7e8c01b9f9abedb1c7ba78 (patch) | |
tree | df314cf10273607ab27ba3471643bfa22fdeb418 /configure | |
parent | b065c71e9d2ad3c5d65f924a4003e3a7ee595417 (diff) | |
parent | ea2f72a2c14c67a3b35dac6426d1e3c0fae33fd5 (diff) | |
download | ffmpeg-23f447294487958e0c7e8c01b9f9abedb1c7ba78.tar.gz |
Merge commit 'ea2f72a2c14c67a3b35dac6426d1e3c0fae33fd5'
* commit 'ea2f72a2c14c67a3b35dac6426d1e3c0fae33fd5':
configure: Don't assume a 16 byte aligned stack on BSDs on i386
Merged-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'configure')
-rwxr-xr-x | configure | 23 |
1 files changed, 21 insertions, 2 deletions
@@ -6522,16 +6522,35 @@ elif enabled gcc; then check_cflags -Wformat check_cflags -fdiagnostics-color=auto enabled extra_warnings || check_disable_warning -Wno-maybe-uninitialized + if enabled x86_32; then + case $target_os in + *bsd*) + # BSDs don't guarantee a 16 byte aligned stack, but we can + # request GCC to try to maintain 16 byte alignment throughout + # function calls. Library entry points that might call assembly + # functions align the stack. (The parameter means 2^4 bytes.) + check_cflags -mpreferred-stack-boundary=4 + ;; + esac + fi elif enabled llvm_gcc; then check_cflags -mllvm -stack-alignment=16 elif enabled clang; then - if [ "$target_os" = "mingw32" -o "$target_os" = "win32" ] && enabled x86_32; then + if enabled x86_32; then # Clang doesn't support maintaining alignment without assuming the # same alignment in every function. If 16 byte alignment would be # enabled, one would also have to either add attribute_align_arg on # every single entry point into the libraries or enable -mstackrealign # (doing stack realignment in every single function). - disable aligned_stack + case $target_os in + mingw32|win32|*bsd*) + disable aligned_stack + ;; + *) + check_cflags -mllvm -stack-alignment=16 + check_cflags -mstack-alignment=16 + ;; + esac else check_cflags -mllvm -stack-alignment=16 check_cflags -mstack-alignment=16 |