Blame src/lzo_util.c

Packit 679830
/* lzo_util.c -- utilities for the LZO library
Packit 679830
Packit 679830
   This file is part of the LZO real-time data compression library.
Packit 679830
Packit 679830
   Copyright (C) 1996-2014 Markus Franz Xaver Johannes Oberhumer
Packit 679830
   All Rights Reserved.
Packit 679830
Packit 679830
   The LZO library is free software; you can redistribute it and/or
Packit 679830
   modify it under the terms of the GNU General Public License as
Packit 679830
   published by the Free Software Foundation; either version 2 of
Packit 679830
   the License, or (at your option) any later version.
Packit 679830
Packit 679830
   The LZO library is distributed in the hope that it will be useful,
Packit 679830
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 679830
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 679830
   GNU General Public License for more details.
Packit 679830
Packit 679830
   You should have received a copy of the GNU General Public License
Packit 679830
   along with the LZO library; see the file COPYING.
Packit 679830
   If not, write to the Free Software Foundation, Inc.,
Packit 679830
   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Packit 679830
Packit 679830
   Markus F.X.J. Oberhumer
Packit 679830
   <markus@oberhumer.com>
Packit 679830
   http://www.oberhumer.com/opensource/lzo/
Packit 679830
 */
Packit 679830
Packit 679830
Packit 679830
#include "lzo_conf.h"
Packit 679830
Packit 679830
Packit 679830
/***********************************************************************
Packit 679830
//
Packit 679830
************************************************************************/
Packit 679830
Packit 679830
/* If you use the LZO library in a product, I would appreciate that you
Packit 679830
 * keep this copyright string in the executable of your product.
Packit 679830
.*/
Packit 679830
Packit 679830
static const char __lzo_copyright[] =
Packit 679830
#if !defined(__LZO_IN_MINLZO)
Packit 679830
    /* save space as some people want a really small decompressor */
Packit 679830
    LZO_VERSION_STRING;
Packit 679830
#else
Packit 679830
    "\r\n\n"
Packit 679830
    "LZO data compression library.\n"
Packit 679830
    "$Copyright: LZO Copyright (C) 1996-2014 Markus Franz Xaver Johannes Oberhumer\n"
Packit 679830
    "<markus@oberhumer.com>\n"
Packit 679830
    "http://www.oberhumer.com $\n\n"
Packit 679830
    "$Id: LZO version: v" LZO_VERSION_STRING ", " LZO_VERSION_DATE " $\n"
Packit 679830
    "$Info: " LZO_INFO_STRING " $\n";
Packit 679830
#endif
Packit 679830
Packit 679830
Packit 679830
LZO_PUBLIC(const lzo_bytep)
Packit 679830
lzo_copyright(void)
Packit 679830
{
Packit 679830
    return (const lzo_bytep) __lzo_copyright;
Packit 679830
}
Packit 679830
Packit 679830
LZO_PUBLIC(unsigned)
Packit 679830
lzo_version(void)
Packit 679830
{
Packit 679830
    return LZO_VERSION;
Packit 679830
}
Packit 679830
Packit 679830
LZO_PUBLIC(const char *)
Packit 679830
lzo_version_string(void)
Packit 679830
{
Packit 679830
    return LZO_VERSION_STRING;
Packit 679830
}
Packit 679830
Packit 679830
LZO_PUBLIC(const char *)
Packit 679830
lzo_version_date(void)
Packit 679830
{
Packit 679830
    return LZO_VERSION_DATE;
Packit 679830
}
Packit 679830
Packit 679830
LZO_PUBLIC(const lzo_charp)
Packit 679830
_lzo_version_string(void)
Packit 679830
{
Packit 679830
    return LZO_VERSION_STRING;
Packit 679830
}
Packit 679830
Packit 679830
LZO_PUBLIC(const lzo_charp)
Packit 679830
_lzo_version_date(void)
Packit 679830
{
Packit 679830
    return LZO_VERSION_DATE;
Packit 679830
}
Packit 679830
Packit 679830
Packit 679830
/***********************************************************************
Packit 679830
// adler32 checksum
Packit 679830
// adapted from free code by Mark Adler <madler@alumni.caltech.edu>
Packit 679830
// see http://www.zlib.org/
Packit 679830
************************************************************************/
Packit 679830
Packit 679830
#define LZO_BASE 65521u /* largest prime smaller than 65536 */
Packit 679830
#define LZO_NMAX 5552
Packit 679830
/* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */
Packit 679830
Packit 679830
#define LZO_DO1(buf,i)  s1 += buf[i]; s2 += s1
Packit 679830
#define LZO_DO2(buf,i)  LZO_DO1(buf,i); LZO_DO1(buf,i+1)
Packit 679830
#define LZO_DO4(buf,i)  LZO_DO2(buf,i); LZO_DO2(buf,i+2)
Packit 679830
#define LZO_DO8(buf,i)  LZO_DO4(buf,i); LZO_DO4(buf,i+4)
Packit 679830
#define LZO_DO16(buf,i) LZO_DO8(buf,i); LZO_DO8(buf,i+8)
Packit 679830
Packit 679830
LZO_PUBLIC(lzo_uint32_t)
Packit 679830
lzo_adler32(lzo_uint32_t adler, const lzo_bytep buf, lzo_uint len)
Packit 679830
{
Packit 679830
    lzo_uint32_t s1 = adler & 0xffff;
Packit 679830
    lzo_uint32_t s2 = (adler >> 16) & 0xffff;
Packit 679830
    unsigned k;
Packit 679830
Packit 679830
    if (buf == NULL)
Packit 679830
        return 1;
Packit 679830
Packit 679830
    while (len > 0)
Packit 679830
    {
Packit 679830
        k = len < LZO_NMAX ? (unsigned) len : LZO_NMAX;
Packit 679830
        len -= k;
Packit 679830
        if (k >= 16) do
Packit 679830
        {
Packit 679830
            LZO_DO16(buf,0);
Packit 679830
            buf += 16;
Packit 679830
            k -= 16;
Packit 679830
        } while (k >= 16);
Packit 679830
        if (k != 0) do
Packit 679830
        {
Packit 679830
            s1 += *buf++;
Packit 679830
            s2 += s1;
Packit 679830
        } while (--k > 0);
Packit 679830
        s1 %= LZO_BASE;
Packit 679830
        s2 %= LZO_BASE;
Packit 679830
    }
Packit 679830
    return (s2 << 16) | s1;
Packit 679830
}
Packit 679830
Packit 679830
#undef LZO_DO1
Packit 679830
#undef LZO_DO2
Packit 679830
#undef LZO_DO4
Packit 679830
#undef LZO_DO8
Packit 679830
#undef LZO_DO16
Packit 679830
Packit 679830
Packit 679830
/*
Packit 679830
vi:ts=4:et
Packit 679830
*/