Suggested attribution patch to lib/crc32.c

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Patch to include attribution for the faster CRC algorithm used in
lib/crc32.c . As I read it Richard Black implied a BSD style license as
long as the Copyright was included. The source was based on his code.
I think http://research.microsoft.com/users/rjblack/ may be the right
person if he should be contacted. I don't like the long line for the URL
- I guess you could lose the section part if preferred.
Source modified from 2.6.0-test4, untested as a comment change.

--- lib/crc32.c	Sat Aug 23 09:50:53 2003
+++ lib/crc32.c	Sun Oct 19 23:40:32 2003
@@ -1,6 +1,9 @@
 /* 
  * Oct 15, 2000 Matt Domsch <Matt_Domsch@dell.com>
  * Nicer crc32 functions/docs submitted by linux@horizon.com.  Thanks!
+ * CRC_?E_BITS == 8 forms based on Algorithm 4 from
+ * http://www.cl.cam.ac.uk/Research/SRG/bluebook/21/crc/node6.html#SECTION00064000000000000000
+ * which is Copyright 1993 Richard Black, All rights reserved.
  *
  * Oct 12, 2000 Matt Domsch <Matt_Domsch@dell.com>
  * Same crc32 function was used in 5 other places in the kernel.



Following are excerpts from the mailing lists showing the history of
the code.

Following includes first use of Algorithm 4
http://www.ussg.iu.edu/hypermail/linux/kernel/0211.2/1895.html
Re: [PATCH 2.5] crc32 static initialization
From: Brian Murphy (brian@murphy.dk)
Date: Fri Nov 22 2002 - 15:25:22 EST

Joakim Tjernlund wrote:

>Hi Brian
>
>Would you please also add the CRC32 patch I sent you earlier?
>It is much faster.
>
>
>
Can you test the attached patch - especially on a big endian system. It
should
do the required thing, i.e. what you want and what I want :-)
simultaneously.

/Brian 


Earlier Algorithm 4
http://www.ussg.iu.edu/hypermail/linux/kernel/0211.2/1525.html
Early crc32 initialization
From: Joakim Tjernlund (joakim.tjernlund@lumentis.se)
Date: Thu Nov 21 2002 - 05:16:48 EST
Brian Murphy posted this on 8-Oct with no response. Quoting:

Here is a patch to the crc32 library routine to allow explicit
initialization of the tables used by the routines.

I need this to be able to use the crc routines in the early
start up code for my platform which saves crc protected
information (clock speed, machine type) in an eeprom.

The option CONFIG_CRC32_EXPLICIT is defined for the platforms
which need it in the config.in file.

I have removed dynamic allocation of memory because the
memory subsystem is also not initialised at the stage where I
need the crc functions.

/Brian

Hi Matt and Brian

I have doen an optimiztion that improves scan time in JFFS2 with more that 25% for
my PPC custom board. This patch needs to use __cpu_to_be32()/__cpu_to_le32() on the
tables. That may cause problems if a static table is to be used. See below:

 Jocke 


Explicit reference to algorithm 4
http://lists.infradead.org/pipermail/linux-mtd/2002-November/006422.html
crc32() optimization
Joakim Tjernlund Joakim.Tjernlund at lumentis.se
Sun Nov 10 21:04:11 GMT 2002

    * Previous message: crc32() optimization
    * Next message: Building mkfs.jffs2
    * Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]

hmm , maybe. I tried 16, 8 & 4 also, but 6 was a little faster for me.
What would be great if someone that understands CRC better than me could
take a look at Algorithm 4 at http://www.cl.cam.ac.uk/Research/SRG/bluebook/21/crc/node6.html#SECTION00060000000000000000
and apply that on linux CRC32 code.  I tried but failed to get it correct.

        Jocke


-
: send the line "unsubscribe linux-net" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Netdev]     [Ethernet Bridging]     [Linux 802.1Q VLAN]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Git]     [Bugtraq]     [Yosemite News and Information]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux PCI]     [Linux Admin]     [Samba]

  Powered by Linux