patches/gcc/4.4.4/400-pr42289-fix-libffi-build-on-arm-oabi.patch
author |
"Yann E. MORIN" <yann.morin.1998@free.fr> |
|
Tue Oct 16 20:57:44 2012 +0200 (2012-10-16) |
changeset 3079 |
37831a33e07e |
permissions |
-rw-r--r-- |
kernel/linux: fix using custom location
Currently, extract and patch are skipped as thus:
- using a custom directory of pre-installed headers
- a correctly named directory already exists
Otherwise, extract and patch are done.
The current second condition is wrong, because it allows the following
sequence to happen:
- a non-custom kernel is used
- a previous build only partially extracted the non-custom sources
- that p[revious build broke during extraction (eg. incomplete tarball...)
- a subsequent build will find a properly named directory, and will
thus skip extract and patch, which is wrong
Fix that by following the conditions in this table:
Type | Extract | Patch
----------------------+---------+-------
Pre-installed headers | N | N
custom directory | N | N
custom tarball | Y | N
mainstream tarball | Y | Y
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Cc: David Holsgrove <david.holsgrove@xilinx.com>
yann@2202
|
1 |
--- gcc-4.3.4/libffi/src/arm/sysv.S
|
yann@2202
|
2 |
+++ gcc-4.3.4/libffi/src/arm/sysv.S
|
yann@2202
|
3 |
@@ -235,7 +235,7 @@ ARM_FUNC_START ffi_closure_SYSV
|
yann@2202
|
4 |
stmfd sp!, {ip, lr}
|
yann@2202
|
5 |
UNWIND .save {r0, lr}
|
yann@2202
|
6 |
add r2, sp, #8
|
yann@2202
|
7 |
- .pad #16
|
yann@2202
|
8 |
+ UNWIND .pad #16
|
yann@2202
|
9 |
sub sp, sp, #16
|
yann@2202
|
10 |
str sp, [sp, #8]
|
yann@2202
|
11 |
add r1, sp, #8
|