[PATCH] 2.4.x:include/asm-i386/checksum.h GCC 3.X warning fixes

From: Maksim Krasnyanskiy (maxk@qualcomm.com)
Date: Thu Feb 28 2002 - 16:26:22 EST


Marcelo,

Could you please apply patch below. It just fixes "multi line string"
warnings.
2.5.X already has that fix. Patch is against 2.4.19-pre1.

btw People were complaining that GCC 3.0 is slower than 2.X.
3.1 seems to be as fast as 2.96. Compiled kernel size is about the same.
And everything
works just fine on my dual Athlon box.

Patch URL (in case mailer messed up spaces)
         http://bluez.sf.net/checksum.h.patch.gz

Thanks
Max

--- include/asm-i386/checksum.h.orig Wed Feb 27 20:12:26 2002
+++ include/asm-i386/checksum.h Tue Feb 26 21:36:53 2002
@@ -69,25 +69,24 @@
                                           unsigned int ihl) {
         unsigned int sum;

- __asm__ __volatile__("
- movl (%1), %0
- subl $4, %2
- jbe 2f
- addl 4(%1), %0
- adcl 8(%1), %0
- adcl 12(%1), %0
-1: adcl 16(%1), %0
- lea 4(%1), %1
- decl %2
- jne 1b
- adcl $0, %0
- movl %0, %2
- shrl $16, %0
- addw %w2, %w0
- adcl $0, %0
- notl %0
-2:
- "
+ __asm__ __volatile__(
+ " movl (%1), %0 ;\n"
+ " subl $4, %2 ;\n"
+ " jbe 2f ;\n"
+ " addl 4(%1), %0 ;\n"
+ " adcl 8(%1), %0 ;\n"
+ " adcl 12(%1), %0 ;\n"
+ "1: adcl 16(%1), %0 ;\n"
+ " lea 4(%1), %1 ;\n"
+ " decl %2 ;\n"
+ " jne 1b ;\n"
+ " adcl $0, %0 ;\n"
+ " movl %0, %2 ;\n"
+ " shrl $16, %0 ;\n"
+ " addw %w2, %w0 ;\n"
+ " adcl $0, %0 ;\n"
+ " notl %0 ;\n"
+ "2: "
         /* Since the input registers which are loaded with iph and ipl
            are modified, we must also specify them as outputs, or gcc
            will assume they contain their original values. */
@@ -102,10 +101,9 @@

  static inline unsigned int csum_fold(unsigned int sum)
  {
- __asm__("
- addl %1, %0
- adcl $0xffff, %0
- "
+ __asm__(
+ "addl %1, %0;\n"
+ "adcl $0xffff, %0;\n"
                 : "=r" (sum)
                 : "r" (sum << 16), "0" (sum & 0xffff0000)
         );
@@ -118,14 +116,14 @@
                                                    unsigned short proto,
                                                    unsigned int sum)
  {
- __asm__("
- addl %1, %0
- adcl %2, %0
- adcl %3, %0
- adcl $0, %0
- "
- : "=r" (sum)
- : "g" (daddr), "g"(saddr), "g"((ntohs(len)<<16)+proto*256), "0"(sum));
+ __asm__(
+ "addl %1, %0;\n"
+ "adcl %2, %0;\n"
+ "adcl %3, %0;\n"
+ "adcl $0, %0;\n"
+ : "=r" (sum)
+ : "g" (daddr), "g"(saddr), "g"((ntohs(len)<<16)+proto*256),
+ "0"(sum));
      return sum;
  }

@@ -158,19 +156,18 @@
                                                      unsigned short proto,
                                                      unsigned int sum)
  {
- __asm__("
- addl 0(%1), %0
- adcl 4(%1), %0
- adcl 8(%1), %0
- adcl 12(%1), %0
- adcl 0(%2), %0
- adcl 4(%2), %0
- adcl 8(%2), %0
- adcl 12(%2), %0
- adcl %3, %0
- adcl %4, %0
- adcl $0, %0
- "
+ __asm__(
+ "addl 0(%1), %0;\n"
+ "adcl 4(%1), %0;\n"
+ "adcl 8(%1), %0;\n"
+ "adcl 12(%1), %0;\n"
+ "adcl 0(%2), %0;\n"
+ "adcl 4(%2), %0;\n"
+ "adcl 8(%2), %0;\n"
+ "adcl 12(%2), %0;\n"
+ "adcl %3, %0;\n"
+ "adcl %4, %0;\n"
+ "adcl $0, %0;\n"
                 : "=&r" (sum)
                 : "r" (saddr), "r" (daddr),
                   "r"(htonl(len)), "r"(htonl(proto)), "0"(sum));

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Thu Feb 28 2002 - 21:00:44 EST