Blame tests/align.c

Packit 679830
/* align.c -- test alignment (important for 16-bit systems)
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
#if 0
Packit 679830
#include "src/lzo_conf.h"
Packit 679830
#include "src/lzo_ptr.h"
Packit 679830
#endif
Packit 679830
#include "lzo/lzoconf.h"
Packit 679830
Packit 679830
/* utility layer */
Packit 679830
#define WANT_LZO_MALLOC 1
Packit 679830
#include "examples/portab.h"
Packit 679830
Packit 679830
Packit 679830
static int opt_verbose = 0;
Packit 679830
Packit 679830
Packit 679830
/*************************************************************************
Packit 679830
//
Packit 679830
**************************************************************************/
Packit 679830
Packit 679830
static unsigned long align_test(lzo_bytep block, lzo_uint len, lzo_uint step)
Packit 679830
{
Packit 679830
    lzo_bytep b1 = block;
Packit 679830
    lzo_bytep b2 = block;
Packit 679830
    lzo_bytep k1 = NULL;
Packit 679830
    lzo_bytep k2 = NULL;
Packit 679830
    lzo_bytep k;
Packit 679830
    lzo_bytep x;
Packit 679830
    lzo_uint offset = 0;
Packit 679830
    unsigned long i = 0;
Packit 679830
Packit 679830
    assert(step > 0);
Packit 679830
    assert(step <= 65536L);
Packit 679830
    assert((step & (step - 1)) == 0);
Packit 679830
Packit 679830
    for (offset = step; offset < len; offset += step)
Packit 679830
    {
Packit 679830
        k1 = LZO_PTR_ALIGN_UP(b1+1,step);
Packit 679830
        k2 = b2 + offset;
Packit 679830
        if (k1 != k2)
Packit 679830
        {
Packit 679830
            printf("error 1: i %lu step %ld offset %ld: "
Packit 679830
                   "%p (%ld) %p (%ld)\n",
Packit 679830
                   i, (long) step, (long) offset,
Packit 679830
                   k1, (long) (k1 - block),
Packit 679830
                   k2, (long) (k2 - block));
Packit 679830
            return 0;
Packit 679830
        }
Packit 679830
        if (k1 - step != b1)
Packit 679830
        {
Packit 679830
            printf("error 2: i %lu step %ld offset %ld: "
Packit 679830
                   "%p (%ld) %p (%ld)\n",
Packit 679830
                   i, (long) step, (long) offset,
Packit 679830
                   b1, (long) (b1 - block),
Packit 679830
                   k1, (long) (k1 - block));
Packit 679830
            return 0;
Packit 679830
        }
Packit 679830
Packit 679830
        assert(k1 > b1);
Packit 679830
        assert(k2 > b2);
Packit 679830
        assert((lzo_uint)(k2 - b2) == offset);
Packit 679830
        assert(k1 - offset == b2);
Packit 679830
#if defined(PTR_ALIGNED_4)
Packit 679830
        if (step == 4)
Packit 679830
        {
Packit 679830
            assert(PTR_ALIGNED_4(k1));
Packit 679830
            assert(PTR_ALIGNED_4(k2));
Packit 679830
            assert(PTR_ALIGNED2_4(k1,k2));
Packit 679830
        }
Packit 679830
#endif
Packit 679830
#if defined(PTR_ALIGNED_8)
Packit 679830
        if (step == 8)
Packit 679830
        {
Packit 679830
            assert(PTR_ALIGNED_8(k1));
Packit 679830
            assert(PTR_ALIGNED_8(k2));
Packit 679830
            assert(PTR_ALIGNED2_8(k1,k2));
Packit 679830
        }
Packit 679830
#endif
Packit 679830
#if defined(PTR_LINEAR)
Packit 679830
        assert((PTR_LINEAR(k1) & (step-1)) == 0);
Packit 679830
        assert((PTR_LINEAR(k2) & (step-1)) == 0);
Packit 679830
#endif
Packit 679830
Packit 679830
        for (k = b1 + 1; k <= k1; k++)
Packit 679830
        {
Packit 679830
            x = LZO_PTR_ALIGN_UP(k,step);
Packit 679830
            if (x != k1)
Packit 679830
            {
Packit 679830
                printf("error 3: base: %p %p %p  i %lu step %ld offset %ld: "
Packit 679830
                       "%p (%ld) %p (%ld) %p (%ld)\n",
Packit 679830
                       block, b1, b2,
Packit 679830
                       i, (long) step, (long) offset,
Packit 679830
                       k1, (long) (k1 - block),
Packit 679830
                       k, (long) (k - block),
Packit 679830
                       x, (long) (x - block));
Packit 679830
                return 0;
Packit 679830
            }
Packit 679830
        }
Packit 679830
Packit 679830
        b1 = k1;
Packit 679830
        i++;
Packit 679830
    }
Packit 679830
Packit 679830
    return i;
Packit 679830
}
Packit 679830
Packit 679830
Packit 679830
/*************************************************************************
Packit 679830
//
Packit 679830
**************************************************************************/
Packit 679830
Packit 679830
#define BLOCK_SIZE  (128*1024ul)
Packit 679830
Packit 679830
int main(int argc, char *argv[])
Packit 679830
{
Packit 679830
    lzo_bytep buf;
Packit 679830
    lzo_uint step;
Packit 679830
Packit 679830
    if (argc >= 2 && strcmp(argv[1],"-v") == 0)
Packit 679830
        opt_verbose = 1;
Packit 679830
Packit 679830
    if (lzo_init() != LZO_E_OK)
Packit 679830
    {
Packit 679830
        printf("lzo_init() failed !!!\n");
Packit 679830
        return 3;
Packit 679830
    }
Packit 679830
    buf = (lzo_bytep) lzo_malloc(2*BLOCK_SIZE + 256);
Packit 679830
    if (buf == NULL)
Packit 679830
    {
Packit 679830
        printf("out of memory\n");
Packit 679830
        return 2;
Packit 679830
    }
Packit 679830
Packit 679830
#if defined(lzo_uintptr_t)
Packit 679830
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) (lzo_uintptr_t) buf);
Packit 679830
#elif defined(__LZO_MMODEL_HUGE)
Packit 679830
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) buf);
Packit 679830
#else
Packit 679830
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) (size_t) buf);
Packit 679830
#endif
Packit 679830
Packit 679830
    for (step = 1; step <= 65536L; step *= 2)
Packit 679830
    {
Packit 679830
        lzo_bytep block = buf;
Packit 679830
        unsigned long n;
Packit 679830
        unsigned gap;
Packit 679830
Packit 679830
        gap = __lzo_align_gap(block, step);
Packit 679830
        block = LZO_PTR_ALIGN_UP(block, step);
Packit 679830
        if (opt_verbose >= 1)
Packit 679830
            printf("STEP %5lu: GAP: %5lu  %p %p %5lu\n",
Packit 679830
                   (unsigned long) step, (unsigned long) gap, buf, block,
Packit 679830
                   (unsigned long) (block - buf));
Packit 679830
        n = align_test(block, BLOCK_SIZE, step);
Packit 679830
        if (n == 0)
Packit 679830
            return 1;
Packit 679830
        if ((n + 1) * step != BLOCK_SIZE)
Packit 679830
        {
Packit 679830
            printf("error 4: %ld %lu\n", (long)step, n);
Packit 679830
            return 1;
Packit 679830
        }
Packit 679830
    }
Packit 679830
Packit 679830
    lzo_free(buf);
Packit 679830
    printf("Alignment test passed.\n");
Packit 679830
    return 0;
Packit 679830
}
Packit 679830
Packit 679830
Packit 679830
/* vim:set ts=4 sw=4 et: */