[clisp] Fix build for new libdb4-devel package. Fix ARM assembly (bz 812928). Add gnulib Provides (bz 821747

Jerry James jjames at fedoraproject.org
Thu Jul 26 03:08:31 UTC 2012


commit 07cfecd89d269381663576db7f8d98d882ec386a
Author: Jerry James <loganjerry at gmail.com>
Date:   Wed Jul 25 21:07:57 2012 -0600

    Fix build for new libdb4-devel package.
    Fix ARM assembly (bz 812928).
    Add gnulib Provides (bz 821747).
    Disable the pari module for now; it does not compile against pari 2.5.

 clisp-arm.patch   |  856 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 clisp-linux.patch |   20 ++
 clisp.spec        |   48 ++-
 3 files changed, 907 insertions(+), 17 deletions(-)
---
diff --git a/clisp-arm.patch b/clisp-arm.patch
new file mode 100644
index 0000000..2eb5373
--- /dev/null
+++ b/clisp-arm.patch
@@ -0,0 +1,856 @@
+--- src/ariarm.d.orig	Fri May 04 01:04:01 2012 -0400
++++ src/ariarm.d	Thu May 24 16:48:47 2012 -0600
+@@ -86,7 +86,7 @@
+ 
+ #define C(x) x
+ #define EXPORT(x) .global x
+-#define GLABEL(x)  x:
++#define GLABEL(x) .type x STT_FUNC; x:
+ #define LABEL(x)  x:
+ #define RRX rrx
+ #define END
+@@ -187,7 +187,7 @@
+         LDR     a3,[pc,#ptr_mulu32_high-.-8]
+         STR     a2,[a3,#0]
+ #endif
+-        MOVS    pc,lr
++        BX      lr
+ 
+ /* extern uint16 divu_3216_1616_ (uint32 x, uint16 y);
+        entry
+@@ -243,7 +243,7 @@
+         LDR     a3,[pc,#ptr_divu_16_rest-.-8] /* save rest so can be picked up later */
+         STR     a2,[a3,#0]      /* the result is 16 bits */
+ #endif
+-        MOVS    pc, lr
++        BX      lr
+ 
+ /* extern uint32 divu_6432_3232_ (uint32 xhi, uint32 xlo, uint32 y); | -> Quotient q
+  extern uint32 divu_32_rest;                                       | -> Rest r
+@@ -278,7 +278,7 @@
+         LDR     a4,[pc,#ptr_divu_32_rest-.-8]
+         STR     a2,[a4,#0]      /* divu_32_rest = remainder */
+ #endif
+-        LDMFD   sp!, {v1,v2,v3,v4,v5,v6,pc}^
++        LDMFD   sp!, {v1,v2,v3,v4,v5,v6,pc}
+ 
+ LABEL(divu_6432_3232_l1)
+         MOV     v3, #0          /* s = 0 */
+@@ -346,7 +346,7 @@
+         LDR     a3,[pc,#ptr_divu_32_rest-.-8]
+         STR     a2,[a3,#0]          /* divu_32_rest = remainder */
+ #endif
+-        LDMFD   sp!, {v1,v2,v3,v4,v5,v6,pc}^
++        LDMFD   sp!, {v1,v2,v3,v4,v5,v6,pc}
+ 
+ /* extern uintD* copy_loop_up (uintD* sourceptr, uintD* destptr, uintC count);
+        entry
+@@ -370,7 +370,7 @@
+ LABEL(copy_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,a2           /* return addr of last word stored */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+ LABEL(copy_loop_up_l2)
+         LDMIA   a1!,{a3,v1,ip,lr} /* copy 4 words in one go */
+@@ -380,7 +380,7 @@
+         STMGEIA a2!,{a3,v1,ip,lr} /* 4 more words */
+         BGT     copy_loop_up_l2   /* and loop */
+         MOV     a1,a2             /* return addr of last word stored */
+-        LDMFD   sp!,{v1,pc}^      /* restore work regs and return */
++        LDMFD   sp!,{v1,pc}       /* restore work regs and return */
+ 
+ /* extern uintD* copy_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
+        entry
+@@ -404,7 +404,7 @@
+ LABEL(copy_loop_down_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,a2           /* return addr of last word stored */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+ LABEL(copy_loop_down_l2)
+         LDMDB   a1!,{a3,v1,ip,lr} /* copy 4 words in one go */
+@@ -414,7 +414,7 @@
+         STMGEDB a2!,{a3,v1,ip,lr} /* 4 more words */
+         BGT     copy_loop_down_l2 /* and loop */
+         MOV     a1,a2             /* return addr of last word stored */
+-        LDMFD   sp!,{v1,pc}^      /* restore work regs and return */
++        LDMFD   sp!,{v1,pc}       /* restore work regs and return */
+ 
+ /* extern uintD* clear_loop_up (uintD* destptr, uintC count);
+        entry
+@@ -446,7 +446,7 @@
+         STRGT   a3,[a1],#4
+ LABEL(fill_loop_up_l1)
+         BICS    a4,a2,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+         MOV     v1,a3           /* copy filler to three other */
+         MOV     ip,a3           /* registers */
+@@ -456,7 +456,7 @@
+         SUBS    a4,a4,#8          /* decrement counter by 8 */
+         STMGEIA a1!,{a3,v1,ip,lr} /* if count still positive then store 4 */
+         BGT     fill_loop_up_l2   /* more and loop */
+-        LDMFD   sp!,{v1,pc}^      /* restore work regs and return */
++        LDMFD   sp!,{v1,pc}       /* restore work regs and return */
+ 
+ 
+ /* extern uintD* clear_loop_down (uintD* destptr, uintC count);
+@@ -489,7 +489,7 @@
+         STRGT   a3,[a1,#-4]!
+ LABEL(fill_loop_down_l1)
+         BICS    a4,a2,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+         MOV     v1,a3           /* copy filler to three other */
+         MOV     ip,a3           /* registers */
+@@ -499,7 +499,7 @@
+         SUBS    a4,a4,#8          /* decrement counter by 8 */
+         STMGEDB a1!,{a3,v1,ip,lr} /* if count still positive then store 4 */
+         BGT     fill_loop_down_l2 /* more and loop */
+-        LDMFD   sp!,{v1,pc}^      /* restore work regs and return */
++        LDMFD   sp!,{v1,pc}       /* restore work regs and return */
+ 
+ /* extern void or_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -529,7 +529,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(or_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(or_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -541,7 +541,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     or_loop_up_l2   /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void xor_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -571,7 +571,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(xor_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(xor_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -583,7 +583,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     xor_loop_up_l2  /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void and_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -613,7 +613,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(and_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(and_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -625,7 +625,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     and_loop_up_l2  /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void eqv_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -659,7 +659,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(eqv_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(eqv_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -675,7 +675,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     eqv_loop_up_l2  /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void nand_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -709,7 +709,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(nand_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(nand_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -725,7 +725,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     nand_loop_up_l2 /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void nor_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -759,7 +759,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(nor_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(nor_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -775,7 +775,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     nor_loop_up_l2  /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void andc2_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -805,7 +805,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(andc2_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(andc2_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -817,7 +817,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     andc2_loop_up_l2 /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^  /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}   /* restore work regs and return */
+ 
+ /* extern void orc2_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -851,7 +851,7 @@
+         STRGT   ip,[a1],#4
+ LABEL(orc2_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(orc2_loop_up_l2)
+         LDMIA   a2!,{a3,v1,v2,ip} /* load 4 words in one go */
+@@ -867,7 +867,7 @@
+         STMIA   a1!,{v3,v4,v5,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     orc2_loop_up_l2 /* if count still positive then loop */
+-        LDMFD   sp!,{v1-v5,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}  /* restore work regs and return */
+ 
+ /* extern void not_loop_up (uintD* xptr, uintC count);
+        entry
+@@ -893,7 +893,7 @@
+         STRGT   a3,[a1],#4
+ LABEL(not_loop_up_l1)
+         BICS    a4,a2,#3        /* set counter to multiple of 4 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{lr}        /* save work regs */
+ LABEL(not_loop_up_l2)
+         LDMIA   a1,{a2,a3,ip,lr} /* load 4 words in one go,NO writeback */
+@@ -904,7 +904,7 @@
+         STMIA   a1!,{a2,a3,ip,lr} /* store 4 results */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     not_loop_up_l2  /* if count still positive then loop */
+-        LDMFD   sp!,{pc}^       /* restore work regs and return */
++        LDMFD   sp!,{pc}        /* restore work regs and return */
+ 
+ /* extern void and_test_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -923,13 +923,13 @@
+         LDR     ip,[a1],#4      /* to align the total to a multiple */
+         TST     ip,a4           /* of 4 words */
+         MOVNE   a1,#1           /* return true if AND_TEST ok */
+-        MOVNES  pc,lr
++        BXNE    lr
+         BCC     and_test_loop_up_l1 /* better to branch than skip instrs. */
+         LDRGE   a4,[a2],#4
+         LDRGE   ip,[a1],#4
+         TSTGE   ip,a4
+         MOVNE   a1,#1
+-        MOVNES  pc,lr
++        BXNE    lr
+         ANDS    a4,a3,#3
+         CMP     a4,#2
+         BLE     and_test_loop_up_l1 /* better to branch than skip instrs. */
+@@ -937,11 +937,11 @@
+         LDRGT   ip,[a1],#4
+         TSTGT   ip,a4
+         MOVNE   a1,#1
+-        MOVNES  pc,lr
++        BXNE    lr
+ LABEL(and_test_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* return false */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr           /* if zero then we're done */
+         STMFD   sp!,{v1-v6,lr}  /* save work regs */
+         MOV     v6,a1           /* move xptr to v6 */
+         MOV     a1,#1           /* set result to true */
+@@ -952,11 +952,11 @@
+         TSTEQ   v4,v1
+         TSTEQ   v5,v2
+         TSTEQ   lr,ip
+-        LDMNEFD sp!,{v1-v6,pc}^
++        LDMNEFD sp!,{v1-v6,pc}
+         SUBS    a4,a4,#4            /* decrement counter by 4 */
+         BGT     and_test_loop_up_l2 /* if count still positive then loop */
+         MOV     a1,#0
+-        LDMFD   sp!,{v1-v6,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v6,pc}  /* restore work regs and return */
+ 
+ /* extern void test_loop_up (uintD* xptr, uintC count);
+        entry
+@@ -973,21 +973,21 @@
+         BEQ     test_loop_up_l1 /* yup, so branch */
+         LDR     a4,[ip],#4      /* TEST the first 1-3 words */
+         TEQ     a4,#0           /* align the total to a multiple of 4 */
+-        MOVNES  pc,lr           /* return true if AND_TEST ok */
++        BXNE    lr              /* return true if AND_TEST ok */
+         CMP     a3,#2
+         BLT     test_loop_up_l1 /* need to branch 'cos PSR set */
+         LDRGE   a4,[ip],#4      /* when checking against zero */
+         TEQGE   a4,#0
+-        MOVNES  pc,lr
++        BXNE    lr
+         CMP     a3,#2
+         BLE     test_loop_up_l1 /* need to branch 'cos PSR set */
+         LDRGT   a4,[ip],#4      /* when checking against zero */
+         TEQGT   a4,#0
+-        MOVNES  pc,lr
++        BXNE    lr
+ LABEL(test_loop_up_l1)
+         BICS    a4,a2,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* return false */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+ LABEL(test_loop_up_l2)
+         LDMIA   ip!,{a2,a3,v1,lr} /* load 4 words in one go */
+@@ -995,11 +995,11 @@
+         TEQEQ   a3,#0
+         TEQEQ   v1,#0
+         TEQEQ   lr,#0
+-        LDMNEFD sp!,{v1,pc}^
++        LDMNEFD sp!,{v1,pc}
+         SUBS    a4,a4,#4        /* decrement counter by 4 */
+         BGT     test_loop_up_l2 /* if count still positive then loop */
+         MOV     a1,#0
+-        LDMFD   sp!,{v1,pc}^    /* restore work regs and return */
++        LDMFD   sp!,{v1,pc}     /* restore work regs and return */
+ 
+ /* extern void compare_loop_up (uintD* xptr, uintD* yptr, uintC count);
+        entry
+@@ -1021,7 +1021,7 @@
+         CMP     ip,a4           /* of 4 words */
+         MVNLO   a1,#0           /* x < y -> -1 */
+         MOVHI   a1,#1           /* x > y -> +1 */
+-        MOVNES  pc,lr           /* and return result if not equal */
++        BXNE    lr              /* and return result if not equal */
+         ANDS    a4,a3,#3
+         CMP     a4,#2
+         BLT     compare_loop_up_l1 /* need to branch 'cos PSR used */
+@@ -1030,7 +1030,7 @@
+         CMP     ip,a4
+         MVNLO   a1,#0
+         MOVHI   a1,#1
+-        MOVNES  pc,lr
++        BXNE    lr
+         ANDS    a4,a3,#3
+         CMP     a4,#2
+         BLE     compare_loop_up_l1 /* need to branch 'cos PSR used */
+@@ -1039,11 +1039,11 @@
+         CMP     ip,a4
+         MVNLO   a1,#0
+         MOVHI   a1,#1
+-        MOVNES  pc,lr
++        BXNE    lr
+ LABEL(compare_loop_up_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* xptr[] == yptr[] -> 0 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v6,lr}  /* save work regs */
+         MOV     v6,a1           /* move xptr to v6 */
+         MOV     a1,#1           /* set result to +1 */
+@@ -1055,11 +1055,11 @@
+         CMPEQ   v5,v2
+         CMPEQ   lr,ip
+         MVNLO   a1,#0           /* x < y -> -1 (a1 already holds +1) */
+-        LDMNEFD sp!,{v1-v6,pc}^
++        LDMNEFD sp!,{v1-v6,pc}
+         SUBS    a4,a4,#4           /* decrement counter by 4 */
+         BGT     compare_loop_up_l2 /* if count still positive then loop */
+         MOV     a1,#0
+-        LDMFD   sp!,{v1-v6,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v6,pc}  /* restore work regs and return */
+ 
+ /* extern uintD addto_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
+        entry
+@@ -1111,11 +1111,11 @@
+         BICS    a4,a4,#3         /* set counter to multiple of 4 */
+         BNE     add_loop_down_l3 /* branch if more adds to do */
+         ADCEQ   a1,a4,a4         /* set result to Carry (a4 is 0) */
+-        LDMEQFD sp!,{v6,pc}^     /* and return */
++        LDMEQFD sp!,{v6,pc}      /* and return */
+ LABEL(add_loop_down_l1)
+         BICS    a4,a4,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* no adds, so C = 0 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr             /* if zero then we're done */
+         CMN     a4,#0           /* clear carry bit */
+         STMFD   sp!,{v6,lr}
+ LABEL(add_loop_down_l3)
+@@ -1132,7 +1132,7 @@
+         TEQ     a4,#0           /* are we done ? */
+         BNE     add_loop_down_l2 /* if count non-zero then loop */
+         ADC     a1,a4,a4         /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{v1-v6,pc}^  /* restore work regs and return */
++        LDMFD   sp!,{v1-v6,pc}   /* restore work regs and return */
+ 
+ /* extern uintD inc_loop_down (uintD* ptr, uintC count);
+        entry
+@@ -1150,11 +1150,11 @@
+         ADDS    a4,a4,#1        /* align the total to a multiple of 2 */
+         STR     a4,[a1]
+         MOVNE   a1,#0           /* set result to 0 */
+-        MOVNES  pc,lr           /* return 0 if non-zero result */
++        BXNE    lr              /* return 0 if non-zero result */
+ LABEL(inc_loop_down_l1)
+         BICS    a4,a2,#1        /* set counter to multiple of 2 */
+         MOVEQ   a1,#1           /* return 1 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         MOV     ip,a1           /* move ptr to ip */
+         MOV     a1,#0           /* set result to 0 */
+         ANDS    a3,a4,#3
+@@ -1163,10 +1163,10 @@
+         ADDS    a3,a3,#1        /* INC the two words */
+         ADDEQS  a2,a2,#1        /* stopping when first word non-zero */
+         STMDB   ip!,{a2,a3}     /* store 2 results */
+-        MOVNES  pc,lr           /* return 0 if any result non-zero */
++        BXNE    lr              /* return 0 if any result non-zero */
+         SUBS    a4,a4,#2        /* decrement counter by 2 */
+         MOVEQ   a1,#1           /* if finished loop then */
+-        MOVEQS  pc,lr           /* return 1 */
++        BXEQ    lr              /* return 1 */
+ LABEL(inc_loop_down_l3)         /* now a multiple of 4 words */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+ LABEL(inc_loop_down_l2)
+@@ -1176,11 +1176,11 @@
+         ADDEQS  a3,a3,#1
+         ADDEQS  a2,a2,#1
+         STMDB   ip!,{a2,a3,v1,lr} /* store 4 results */
+-        LDMNEFD sp!,{v1,pc}^      /* return 0 if any result non-zero */
++        LDMNEFD sp!,{v1,pc}       /* return 0 if any result non-zero */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     inc_loop_down_l2 /* if count still positive then loop */
+         MOV     a1,#1
+-        LDMFD   sp!,{v1,pc}^    /* restore work regs and return 1 */
++        LDMFD   sp!,{v1,pc}     /* restore work regs and return 1 */
+ 
+ /* extern uintD sub_loop_down (uintD* sourceptr1, uintD* sourceptr2, uintD* destptr, uintC count);
+        entry
+@@ -1206,7 +1206,7 @@
+ LABEL(sub_loop_down_l4)     /* drop through for better instr. timings */
+         BICS    a4,a4,#3    /* set counter to multiple of 4 */
+         SBCEQ   a1,a4,a4    /* set result to Carry (a4 is 0) */
+-        LDMEQFD sp!,{v6,pc}^     /* and return */
++        LDMEQFD sp!,{v6,pc}      /* and return */
+         STMFD   sp!,{v1-v5}      /* save work regs */
+         B       sub_loop_down_l2 /* branch if more subtracts to do */
+ LABEL(sub_loop_down_l0)
+@@ -1224,7 +1224,7 @@
+ LABEL(sub_loop_down_l1)
+         BICS    a4,a4,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* no subtracts, so C = 0 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         CMP     a4,#0           /* set carry bit, since a4 > 0 */
+         STMFD   sp!,{v1-v6,lr}  /* save work regs */
+ LABEL(sub_loop_down_l2)
+@@ -1239,7 +1239,7 @@
+         TEQ     a4,#0           /* are we done ? */
+         BNE     sub_loop_down_l2 /* if count non-zero then loop */
+         SBC     a1,a4,a4         /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{v1-v6,pc}^  /* restore work regs and return */
++        LDMFD   sp!,{v1-v6,pc}   /* restore work regs and return */
+ 
+ /* extern uintD subx_loop_down (uintD* sourceptr1, uintD* sourceptr2, uintD* destptr, uintC count, uintD carry);
+        entry
+@@ -1269,7 +1269,7 @@
+ LABEL(subx_loop_down_l4)    /* drop through for better instr. timings */
+         BICS    a4,a4,#3    /* set counter to multiple of 4 */
+         SBCEQ   a1,a4,a4    /* set result to Carry (a4 is 0) */
+-        LDMEQFD sp!,{v6,pc}^      /* and return */
++        LDMEQFD sp!,{v6,pc}       /* and return */
+         STMFD   sp!,{v1-v5}       /* save work regs */
+         B       subx_loop_down_l2 /* branch if more subtracts to do */
+ LABEL(subx_loop_down_l0)
+@@ -1287,7 +1287,7 @@
+ LABEL(subx_loop_down_l1)
+         BICS    a4,a4,#3        /* set counter to multiple of 4 */
+         SBCEQ   a1,a4,a4        /* set result to Carry (a4 is 0) */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{v1-v6,lr}  /* save work regs */
+ LABEL(subx_loop_down_l2)
+         LDMDB   a2!,{v1,v2,v3,ip} /* load 4 words in one go */
+@@ -1301,7 +1301,7 @@
+         TEQ     a4,#0           /* are we done ? */
+         BNE     subx_loop_down_l2 /* if count non-zero then loop */
+         SBC     a1,a4,a4          /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{v1-v6,pc}^   /* restore work regs and return */
++        LDMFD   sp!,{v1-v6,pc}    /* restore work regs and return */
+ 
+ /* extern uintD subfrom_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
+        entry
+@@ -1326,7 +1326,7 @@
+ LABEL(subfrom_loop_down_l4) /* drop through for better instr. timings */
+         BICS    a4,a3,#3    /* set counter to multiple of 4 */
+         SBCEQ   a1,a4,a4    /* set result to Carry (a4 is 0) */
+-        LDMEQFD sp!,{pc}^   /* and return */
++        LDMEQFD sp!,{pc}    /* and return */
+         STMFD   sp!,{v1-v5} /* save work regs */
+         B       subfrom_loop_down_l2 /* branch if more subtracts to do */
+ LABEL(subfrom_loop_down_l0)
+@@ -1344,7 +1344,7 @@
+ LABEL(subfrom_loop_down_l1)
+         BICS    a4,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,#0           /* no subtracts, so C = 0 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         CMP     a4,#0           /* set carry bit, since a4 > 0 */
+         STMFD   sp!,{v1-v5,lr}  /* save work regs */
+ LABEL(subfrom_loop_down_l2)
+@@ -1359,7 +1359,7 @@
+         TEQ     a4,#0           /* are we done ? */
+         BNE     subfrom_loop_down_l2 /* if count non-zero then loop */
+         SBC     a1,a4,a4             /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{v1-v5,pc}^      /* restore work regs and return */
++        LDMFD   sp!,{v1-v5,pc}       /* restore work regs and return */
+ 
+ /* extern uintD dec_loop_down (uintD* ptr, uintC count);
+        entry
+@@ -1377,11 +1377,11 @@
+         SUBS    a4,a4,#1        /* align the total to a multiple of 2 */
+         STR     a4,[a1]
+         MOVCS   a1,#0           /* set result to 0 */
+-        MOVCSS  pc,lr           /* return 0 if non-zero result */
++        BXCS    lr              /* return 0 if non-zero result */
+ LABEL(dec_loop_down_l1)
+         BICS    a4,a2,#1        /* set counter to multiple of 2 */
+         MVNEQ   a1,#0           /* return -1 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         MOV     ip,a1           /* move ptr to ip */
+         MOV     a1,#0           /* set result to 0 */
+         ANDS    a3,a4,#3
+@@ -1390,10 +1390,10 @@
+         SUBS    a3,a3,#1        /* DEC the two words */
+         SUBCCS  a2,a2,#1        /* stopping when first word non-zero */
+         STMDB   ip!,{a2,a3}     /* store 2 results */
+-        MOVCSS  pc,lr           /* return 0 if any result non-zero */
++        BXCS    lr              /* return 0 if any result non-zero */
+         SUBS    a4,a4,#2        /* decrement counter by 2 */
+         MVNEQ   a1,#0           /* if finished loop then */
+-        MOVEQS  pc,lr           /* return -1 */
++        BXEQ    lr              /* return -1 */
+ LABEL(dec_loop_down_l3)         /* now a multiple of 4 words */
+         STMFD   sp!,{v1,lr}     /* save work regs */
+ LABEL(dec_loop_down_l2)
+@@ -1403,11 +1403,11 @@
+         SUBCCS  a3,a3,#1
+         SUBCCS  a2,a2,#1
+         STMDB   ip!,{a2,a3,v1,lr} /* store 4 results */
+-        LDMCSFD sp!,{v1,pc}^      /* return 0 if any carry */
++        LDMCSFD sp!,{v1,pc}       /* return 0 if any carry */
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     dec_loop_down_l2 /* if count still positive then loop */
+         MVN     a1,#0
+-        LDMFD   sp!,{v1,pc}^    /* restore work regs and return -1 */
++        LDMFD   sp!,{v1,pc}     /* restore work regs and return -1 */
+ 
+ /* extern void neg_loop_down (uintD* ptr, uintC count);
+        entry
+@@ -1421,7 +1421,7 @@
+ GLABEL(neg_loop_down)
+         CMPS    a2,#0           /* count = 0 ? */
+         MOVEQ   a1,#0           /* yup, so return 0 */
+-        MOVEQS  pc,lr
++        BXEQ    lr
+ LABEL(neg_loop_down_l1)          /* skip all the zero words first */
+         LDR     a3,[a1,#-4]!     /* compare words against zero */
+         CMPS    a3,#0            /* downwards in memory */
+@@ -1429,13 +1429,13 @@
+         SUBS    a2,a2,#1         /* reduce count of words */
+         BNE     neg_loop_down_l1 /* more ?, so loop */
+         MOV     a1,#0            /* return 0 */
+-        MOVS    pc,lr
++        BX      lr
+ LABEL(neg_loop_down_l2)
+         RSB     a3,a3,#0        /* first non-zero word = -word */
+         STR     a3,[a1]
+         SUBS    a2,a2,#1
+         MVNEQ   a1,#0           /* done ? -> return -1 */
+-        MOVEQS  pc,lr
++        BXEQ    lr
+                                         /* now NOT rest of the words */
+         ANDS    a3,a2,#3                /* multiple of 4 words ? */
+         BEQ     neg_loop_down_l3        /* yup, so branch */
+@@ -1453,7 +1453,7 @@
+ LABEL(neg_loop_down_l3)
+         BICS    a4,a2,#3        /* set counter to multiple of 4 */
+         MVNEQ   a1,#0           /* set result to -1 */
+-        MOVEQS  pc,lr           /* if zero then we're done */
++        BXEQ    lr              /* if zero then we're done */
+         STMFD   sp!,{lr}        /* save work regs */
+ LABEL(neg_loop_down_l4)
+         LDMDB   a1,{a2,a3,ip,lr} /* load 4 words in one go,NO writeback */
+@@ -1465,7 +1465,7 @@
+         SUBS    a4,a4,#4          /* decrement counter by 4 */
+         BGT     neg_loop_down_l4 /* if count still positive then loop */
+         MVN     a1,#0            /* set result to -1 */
+-        LDMFD   sp!,{pc}^        /* restore work regs and return -1 */
++        LDMFD   sp!,{pc}         /* restore work regs and return -1 */
+ 
+ /* extern uintD shift1left_loop_down (uintD* ptr, uintC count);
+        entry
+@@ -1485,7 +1485,7 @@
+ LABEL(shift1left_loop_down_l1)
+         BICS    a4,a2,#1        /* set counter to multiple of 2 */
+         ADCEQ   a1,a4,a4        /* if zero set result to C (a4 is 0) */
+-        MOVEQS  pc,lr           /* and return */
++        BXEQ    lr              /* and return */
+         ANDS    a3,a4,#3        /* multiple of 4 words ? */
+         BEQ     shift1left_loop_down_l3 /* yup, so branch */
+         LDMDB   a1,{a2,a3}              /* load 2 words in one go */
+@@ -1494,7 +1494,7 @@
+         STMDB   a1!,{a2,a3}     /* store 2 results */
+         BICS    a4,a4,#2        /* decrement counter by 2 */
+         ADCEQ   a1,a4,a4        /* set result to Carry (a4 is 0) */
+-        MOVEQS  pc,lr           /* and return */
++        BXEQ    lr              /* and return */
+ LABEL(shift1left_loop_down_l3)  /* now a multiple of 4 words */
+         STMFD   sp!,{lr}        /* save work regs */
+ LABEL(shift1left_loop_down_l2)
+@@ -1508,7 +1508,7 @@
+         TEQ     a4,#0                   /* are we done ? */
+         BNE     shift1left_loop_down_l2 /* if count non-zero then loop */
+         ADC     a1,a4,a4        /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{pc}^       /* restore work regs and return 1 */
++        LDMFD   sp!,{pc}        /* restore work regs and return 1 */
+ 
+ /* extern uintD shiftleft_loop_down (uintD* ptr, uintC count, uintC i, uintD carry);
+        entry
+@@ -1542,7 +1542,7 @@
+ LABEL(shiftleft_loop_down_l1)
+         BICS    ip,a2,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,a4           /* if zero then we're done */
+-        LDMEQFD sp!,{v6,pc}^    /* so return last shift out */
++        LDMEQFD sp!,{v6,pc}     /* so return last shift out */
+         STMFD   sp!,{v1-v3}     /* save work regs */
+ LABEL(shiftleft_loop_down_l2)
+         LDMDB   a1,{a2,v1,v2,v3} /* load 4 words in one go */
+@@ -1558,7 +1558,7 @@
+         SUBS    ip,ip,#4               /* decrement counter by 4 */
+         BGT     shiftleft_loop_down_l2 /* if count still positive then loop */
+         MOV     a1,a4                  /* result = last shift out */
+-        LDMFD   sp!,{v1-v3,v6,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v3,v6,pc}  /* restore work regs and return */
+ 
+ /* extern uintD shiftleftcopy_loop_down (uintD* sourceptr, uintD* destptr, uintC count, uintC i);
+        entry
+@@ -1593,7 +1593,7 @@
+ LABEL(shiftleftcopy_loop_down_l1)
+         BICS    ip,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,v5           /* if zero then we're done */
+-        LDMEQFD sp!,{v5,v6,pc}^ /* so return last shift out */
++        LDMEQFD sp!,{v5,v6,pc}  /* so return last shift out */
+         STMFD   sp!,{v1-v3}     /* save work regs */
+ LABEL(shiftleftcopy_loop_down_l2)
+         LDMDB   a1!,{a3,v1,v2,v3} /* load 4 words in one go */
+@@ -1609,7 +1609,7 @@
+         SUBS    ip,ip,#4                   /* decrement counter by 4 */
+         BGT     shiftleftcopy_loop_down_l2 /* if count still positive then loop */
+         MOV     a1,v5                      /* result = last shift out */
+-        LDMFD   sp!,{v1-v3,v5,v6,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v3,v5,v6,pc}  /* restore work regs and return */
+ 
+ /* extern uintD shift1right_loop_up (uintD* ptr, uintC count, uintD carry);
+        entry
+@@ -1630,7 +1630,7 @@
+ LABEL(shift1right_loop_up_l1)
+         BICS    a4,a2,#1        /* set counter to multiple of 2 */
+         MOVEQ   a1,a4,RRX       /* if zero set result to C (a4 is 0) */
+-        MOVEQS  pc,lr           /* and return */
++        BXEQ    lr              /* and return */
+         ANDS    a3,a4,#3        /* multiple of 4 words ? */
+         BEQ     shift1right_loop_up_l3 /* yup, so branch */
+         LDMIA   a1,{a2,a3}             /* load 2 words in one go */
+@@ -1639,7 +1639,7 @@
+         STMIA   a1!,{a2,a3}     /* store 2 results */
+         BICS    a4,a4,#2        /* decrement counter by 2 */
+         ADCEQ   a1,a4,a4        /* set result to Carry (a4 is 0) */
+-        MOVEQS  pc,lr           /* and return */
++        BXEQ    lr              /* and return */
+ LABEL(shift1right_loop_up_l3)   /* now a multiple of 4 words */
+         STMFD   sp!,{lr}        /* save work regs */
+ LABEL(shift1right_loop_up_l2)
+@@ -1653,7 +1653,7 @@
+         TEQ     a4,#0                  /* are we done ? */
+         BNE     shift1right_loop_up_l2 /* if count non-zero then loop */
+         MOV     a1,a4,RRX       /* set result to Carry (a4 is 0) */
+-        LDMFD   sp!,{pc}^       /* restore work regs and return 1 */
++        LDMFD   sp!,{pc}        /* restore work regs and return 1 */
+ 
+ /* extern uintD shiftright_loop_up (uintD* ptr, uintC count, uintC i);
+        entry
+@@ -1688,7 +1688,7 @@
+ LABEL(shiftright_loop_up_l1)
+         BICS    ip,a2,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,a4           /* if zero then we're done */
+-        LDMEQFD sp!,{v6,pc}^    /* so return last shift out */
++        LDMEQFD sp!,{v6,pc}     /* so return last shift out */
+         STMFD   sp!,{v1-v3}     /* save work regs */
+ LABEL(shiftright_loop_up_l2)
+         LDMIA   a1,{v1,v2,v3,lr} /* load 4 words in one go */
+@@ -1704,7 +1704,7 @@
+         SUBS    ip,ip,#4              /* decrement counter by 4 */
+         BGT     shiftright_loop_up_l2 /* if count still positive then loop */
+         MOV     a1,a4                 /* result = last shift out */
+-        LDMFD   sp!,{v1-v3,v6,pc}^    /* restore work regs and return */
++        LDMFD   sp!,{v1-v3,v6,pc}     /* restore work regs and return */
+ 
+ /* extern uintD shiftrightsigned_loop_up (uintD* ptr, uintC count, uintC i);
+        entry
+@@ -1759,7 +1759,7 @@
+ LABEL(shiftrightcopy_loop_up_l1)
+         BICS    ip,a3,#3        /* set counter to multiple of 4 */
+         MOVEQ   a1,v5           /* if zero then we're done */
+-        LDMEQFD sp!,{v5,v6,pc}^ /* so return last shift out */
++        LDMEQFD sp!,{v5,v6,pc}  /* so return last shift out */
+         STMFD   sp!,{v1-v3}     /* save work regs */
+ LABEL(shiftrightcopy_loop_up_l2)
+         LDMIA   a1!,{v1,v2,v3,lr} /* load 4 words in one go */
+@@ -1775,7 +1775,7 @@
+         SUBS    ip,ip,#4                  /* decrement counter by 4 */
+         BGT     shiftrightcopy_loop_up_l2 /* if count still positive then loop */
+         MOV     a1,v5                     /* result = last shift out */
+-        LDMFD   sp!,{v1-v3,v5,v6,pc}^ /* restore work regs and return */
++        LDMFD   sp!,{v1-v3,v5,v6,pc}  /* restore work regs and return */
+ 
+ #ifndef HAVE_umull
+ /* mulu32_64_vregs
+@@ -1800,7 +1800,7 @@
+         ADDCS   v2,v2,#0x10000   /* carry from above add */
+         ADDS    v1,v4,ip,LSL #16 /* x is now bottom 32 bits of result */
+         ADC     ip,v2,ip,LSR #16 /* hi is top 32 bits */
+-        MOVS    pc,lr
++        BX      lr
+ #endif  /* HAVE_umull */
+ 
+ /* extern uintD mulusmall_loop_down (uintD digit, uintD* ptr, uintC len, uintD newdigit);
+@@ -1816,7 +1816,7 @@
+ GLABEL(mulusmall_loop_down)
+         CMP     a3,#0
+         MOVEQ   a1,a4
+-        MOVEQS  pc,lr
++        BXEQ    lr
+ #ifdef HAVE_umull
+         STMFD   sp!,{v1,lr}
+ LABEL(mulusmall_loop_down_l1)
+@@ -1828,7 +1828,7 @@
+         SUBS    a3,a3,#1       /* len-- */
+         BNE     mulusmall_loop_down_l1 /* until len==0 */
+         MOV     a1,a4                  /* return carry */
+-        LDMFD   sp!,{v1,pc}^
++        LDMFD   sp!,{v1,pc}
+ #else
+         STMFD   sp!,{v1-v2,lr}
+ LABEL(mulusmall_loop_down_l1)
+@@ -1850,7 +1850,7 @@
+         SUBS    a3,a3,#1       /* len-- */
+         BNE     mulusmall_loop_down_l1 /* until len==0 */
+         MOV     a1,a4                  /* return carry */
+-        LDMFD   sp!,{v1-v2,pc}^
++        LDMFD   sp!,{v1-v2,pc}
+ #endif
+ 
+ /* extern void mulu_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
+@@ -1875,7 +1875,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     mulu_loop_down_l1 /* until len==0 */
+         STR     v5,[a3,#-4]!      /* *--destptr = carry */
+-        LDMFD   sp!,{v1,v5,pc}^
++        LDMFD   sp!,{v1,v5,pc}
+ #else
+         STMFD   sp!,{v1-v5,lr}
+         MOV     v5,#0
+@@ -1888,7 +1888,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     mulu_loop_down_l1 /* until len==0 */
+         STR     v5,[a3,#-4]!      /* *--destptr = carry */
+-        LDMFD   sp!,{v1-v5,pc}^
++        LDMFD   sp!,{v1-v5,pc}
+ #endif
+ 
+ /* extern void muluadd_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
+@@ -1916,7 +1916,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     muluadd_loop_down_l1 /* until len==0 */
+         MOV     a1,v5                /* return carry */
+-        LDMFD   sp!,{v1,v5,pc}^
++        LDMFD   sp!,{v1,v5,pc}
+ #else
+         STMFD   sp!,{v1-v5,lr}
+         MOV     v5,#0
+@@ -1932,7 +1932,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     muluadd_loop_down_l1 /* until len==0 */
+         MOV     a1,v5                /* return carry */
+-        LDMFD   sp!,{v1-v5,pc}^
++        LDMFD   sp!,{v1-v5,pc}
+ #endif
+ 
+ /* extern void mulusub_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
+@@ -1960,7 +1960,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     mulusub_loop_down_l1 /* until len==0 */
+         MOV     a1,v5                /* return carry */
+-        LDMFD   sp!,{v1,v5,pc}^
++        LDMFD   sp!,{v1,v5,pc}
+ #else
+         STMFD   sp!,{v1-v5,lr}
+         MOV     v5,#0
+@@ -1976,7 +1976,7 @@
+         SUBS    a4,a4,#1       /* len-- */
+         BNE     mulusub_loop_down_l1 /* until len==0 */
+         MOV     a1,v5                /* return carry */
+-        LDMFD   sp!,{v1-v5,pc}^
++        LDMFD   sp!,{v1-v5,pc}
+ #endif
+ 
+         END
diff --git a/clisp-linux.patch b/clisp-linux.patch
new file mode 100644
index 0000000..c5ae1a2
--- /dev/null
+++ b/clisp-linux.patch
@@ -0,0 +1,20 @@
+--- ./modules/bindings/glibc/linux.lisp.orig	2008-10-08 10:36:19.000000000 -0600
++++ ./modules/bindings/glibc/linux.lisp	2012-07-25 19:05:07.014592097 -0600
+@@ -86,7 +86,7 @@
+ 
+ (def-c-type __key_t)            ; int
+ 
+-(c-lines "#include <bits/ipctypes.h>~%")
++(c-lines "#include <sys/ipc.h>~%")
+ (def-c-type __ipc_pid_t)        ; ushort
+ 
+ ; --------------------------- <sys/types.h> -----------------------------------
+@@ -293,6 +293,8 @@
+ ;; for robust mutexes
+ (def-c-const EOWNERDEAD (:documentation "Owner died")) ; 130
+ (def-c-const ENOTRECOVERABLE (:documentation "State not recoverable")) ; 131
++(def-c-const ERFKILL (:documentation "Operation not possible due to RF-kill")) ; 132
++(def-c-const EHWPOISON (:documentation "Memory page has hardware error")) ; 133
+ 
+ ; -------------------------- <bits/errno.h> -----------------------------------
+ 
diff --git a/clisp.spec b/clisp.spec
index e185049..71b3221 100644
--- a/clisp.spec
+++ b/clisp.spec
@@ -1,18 +1,22 @@
 Name:		clisp
 Summary:	ANSI Common Lisp implementation
 Version:	2.49
-Release:	7%{?dist}
+Release:	8%{?dist}
 
 Group:		Development/Languages
 License:	GPLv2
 URL:		http://www.clisp.org/
 Source0:	http://downloads.sourceforge.net/clisp/clisp-%{version}.tar.bz2
-# Adapt to libsvm 3.1.  Sent upstream 23 Jun 2011.
+# Adapt to libsvm 3.1.  Applied upstream.
 Patch0:		clisp-libsvm.patch
-# Fix an illegal C construct that allows GCC 4.7 to produce bad code.
+# Fix an illegal C construct that allows GCC 4.7 to produce bad code.  Applied
+# upstream.
 Patch1:		clisp-hostname.patch
+# Fix old ARM assembly that is invalid for newer platforms.  Sent upstream.
+Patch2:		clisp-arm.patch
+# Linux-specific fixes.  Sent upstream 25 Jul 2012.
+Patch3:		clisp-linux.patch
 BuildRequires:	compat-readline5-devel
-BuildRequires:	db4-devel
 BuildRequires:	dbus-devel
 BuildRequires:	fcgi-devel
 BuildRequires:	ffcall
@@ -21,7 +25,6 @@ BuildRequires:	gettext-devel
 BuildRequires:	ghostscript
 BuildRequires:	groff
 BuildRequires:	gtk2-devel
-BuildRequires:	gzip
 BuildRequires:	libICE-devel
 BuildRequires:	libSM-devel
 BuildRequires:	libX11-devel
@@ -31,10 +34,11 @@ BuildRequires:	libXft-devel
 BuildRequires:	libXmu-devel
 BuildRequires:	libXrender-devel
 BuildRequires:	libXt-devel
+BuildRequires:	libdb4-devel
 BuildRequires:	libglade2-devel
 BuildRequires:	libsigsegv-devel
 BuildRequires:	libsvm-devel
-BuildRequires:	pari-devel
+#BuildRequires:	pari-devel
 BuildRequires:	pcre-devel
 BuildRequires:	postgresql-devel
 BuildRequires:	zlib-devel
@@ -42,6 +46,9 @@ BuildRequires:	zlib-devel
 # See Red Hat bug #238954
 ExcludeArch:	ppc64
 
+# clisp contains a copy of gnulib, which has been granted a bundling exception:
+# https://fedoraproject.org/wiki/Packaging:No_Bundled_Libraries#Packages_granted_exceptions
+Provides:	bundled(gnulib)
 
 %description
 ANSI Common Lisp is a high-level, general-purpose programming
@@ -79,6 +86,8 @@ Files necessary for linking CLISP programs.
 %setup -q
 %patch0
 %patch1
+%patch2
+%patch3
 
 # Convince CLisp to build against compat-readline5 instead of readline.
 # This is to avoid pulling the GPLv3 readline 6 into a GPLv2 CLisp binary.
@@ -125,7 +134,6 @@ ulimit -s unlimited
 	    --with-module=gdbm \
 	    --with-module=gtk2 \
 	    --with-module=libsvm \
-	    --with-module=pari \
 	    --with-module=pcre \
 	    --with-module=postgresql \
 	    --with-module=rawsock \
@@ -135,11 +143,11 @@ ulimit -s unlimited
 	    --cbc \
 	    build \
 %ifarch ppc ppc64
-	    CFLAGS="${RPM_OPT_FLAGS} -DNO_GENERATIONAL_GC -DNO_MULTIMAP_FILE -DNO_SINGLEMAP -I/usr/include/readline5 -I/usr/include/libsvm -Wa,--noexecstack -L%{_libdir}/readline5" \
+	    CFLAGS="${RPM_OPT_FLAGS} -DNO_GENERATIONAL_GC -DNO_MULTIMAP_FILE -DNO_SINGLEMAP -I/usr/include/readline5 -I/usr/include/libsvm -I/usr/include/libdb4 -Wa,--noexecstack -L%{_libdir}/readline5 -L%{_libdir}/libdb4" \
 %else
-	    CFLAGS="${RPM_OPT_FLAGS} -I/usr/include/readline5 -I/usr/include/libsvm -Wa,--noexecstack -L%{_libdir}/readline5" \
+	    CFLAGS="${RPM_OPT_FLAGS} -I/usr/include/readline5 -I/usr/include/libsvm -I/usr/include/libdb4 -Wa,--noexecstack -L%{_libdir}/readline5 -L%{_libdir}/libdb4" \
 %endif
-	    LDFLAGS="-L%{_libdir}/readline5 -Wl,-z,noexecstack"
+	    LDFLAGS="-L%{_libdir}/readline5 -L%{_libdir}/libdb4 -Wl,-z,noexecstack"
 
 %install
 make -C build DESTDIR=$RPM_BUILD_ROOT install
@@ -188,8 +196,8 @@ chmod a+x \
 %{_libdir}/clisp-%{version}/gtk2/*.fas
 %dir %{_libdir}/clisp-%{version}/libsvm/
 %{_libdir}/clisp-%{version}/libsvm/*.fas
-%dir %{_libdir}/clisp-%{version}/pari/
-%{_libdir}/clisp-%{version}/pari/*.fas
+#%%dir %%{_libdir}/clisp-%%{version}/pari/
+#%%{_libdir}/clisp-%%{version}/pari/*.fas
 %dir %{_libdir}/clisp-%{version}/pcre/
 %{_libdir}/clisp-%{version}/pcre/*.fas
 %dir %{_libdir}/clisp-%{version}/postgresql/
@@ -249,11 +257,11 @@ chmod a+x \
 %{_libdir}/clisp-%{version}/libsvm/*.o
 %{_libdir}/clisp-%{version}/libsvm/*.sh
 %{_libdir}/clisp-%{version}/linkkit/
-%{_libdir}/clisp-%{version}/pari/README
-%{_libdir}/clisp-%{version}/pari/Makefile
-%{_libdir}/clisp-%{version}/pari/*.lisp
-%{_libdir}/clisp-%{version}/pari/*.o
-%{_libdir}/clisp-%{version}/pari/*.sh
+#%%{_libdir}/clisp-%%{version}/pari/README
+#%%{_libdir}/clisp-%%{version}/pari/Makefile
+#%%{_libdir}/clisp-%%{version}/pari/*.lisp
+#%%{_libdir}/clisp-%%{version}/pari/*.o
+#%%{_libdir}/clisp-%%{version}/pari/*.sh
 %{_libdir}/clisp-%{version}/pcre/Makefile
 %{_libdir}/clisp-%{version}/pcre/*.lisp
 %{_libdir}/clisp-%{version}/pcre/*.o
@@ -282,6 +290,12 @@ chmod a+x \
 
 
 %changelog
+* Wed Jul 25 2012 Jerry James <loganjerry at gmail.com> - 2.49-8
+- Fix build for new libdb4-devel package.
+- Fix ARM assembly (bz 812928)
+- Add gnulib Provides (bz 821747)
+- Disable the pari module for now; it does not compile against pari 2.5
+
 * Wed Jul 18 2012 Fedora Release Engineering <rel-eng at lists.fedoraproject.org> - 2.49-7
 - Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild
 


More information about the scm-commits mailing list