Blame tests/align.c

Packit Service 5195f2
/* align.c -- test alignment (important for 16-bit systems)
Packit Service 5195f2
Packit Service 5195f2
   This file is part of the LZO real-time data compression library.
Packit Service 5195f2
Packit Service 5195f2
   Copyright (C) 1996-2014 Markus Franz Xaver Johannes Oberhumer
Packit Service 5195f2
   All Rights Reserved.
Packit Service 5195f2
Packit Service 5195f2
   The LZO library is free software; you can redistribute it and/or
Packit Service 5195f2
   modify it under the terms of the GNU General Public License as
Packit Service 5195f2
   published by the Free Software Foundation; either version 2 of
Packit Service 5195f2
   the License, or (at your option) any later version.
Packit Service 5195f2
Packit Service 5195f2
   The LZO library is distributed in the hope that it will be useful,
Packit Service 5195f2
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 5195f2
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 5195f2
   GNU General Public License for more details.
Packit Service 5195f2
Packit Service 5195f2
   You should have received a copy of the GNU General Public License
Packit Service 5195f2
   along with the LZO library; see the file COPYING.
Packit Service 5195f2
   If not, write to the Free Software Foundation, Inc.,
Packit Service 5195f2
   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Packit Service 5195f2
Packit Service 5195f2
   Markus F.X.J. Oberhumer
Packit Service 5195f2
   <markus@oberhumer.com>
Packit Service 5195f2
   http://www.oberhumer.com/opensource/lzo/
Packit Service 5195f2
 */
Packit Service 5195f2
Packit Service 5195f2
Packit Service 5195f2
#if 0
Packit Service 5195f2
#include "src/lzo_conf.h"
Packit Service 5195f2
#include "src/lzo_ptr.h"
Packit Service 5195f2
#endif
Packit Service 5195f2
#include "lzo/lzoconf.h"
Packit Service 5195f2
Packit Service 5195f2
/* utility layer */
Packit Service 5195f2
#define WANT_LZO_MALLOC 1
Packit Service 5195f2
#include "examples/portab.h"
Packit Service 5195f2
Packit Service 5195f2
Packit Service 5195f2
static int opt_verbose = 0;
Packit Service 5195f2
Packit Service 5195f2
Packit Service 5195f2
/*************************************************************************
Packit Service 5195f2
//
Packit Service 5195f2
**************************************************************************/
Packit Service 5195f2
Packit Service 5195f2
static unsigned long align_test(lzo_bytep block, lzo_uint len, lzo_uint step)
Packit Service 5195f2
{
Packit Service 5195f2
    lzo_bytep b1 = block;
Packit Service 5195f2
    lzo_bytep b2 = block;
Packit Service 5195f2
    lzo_bytep k1 = NULL;
Packit Service 5195f2
    lzo_bytep k2 = NULL;
Packit Service 5195f2
    lzo_bytep k;
Packit Service 5195f2
    lzo_bytep x;
Packit Service 5195f2
    lzo_uint offset = 0;
Packit Service 5195f2
    unsigned long i = 0;
Packit Service 5195f2
Packit Service 5195f2
    assert(step > 0);
Packit Service 5195f2
    assert(step <= 65536L);
Packit Service 5195f2
    assert((step & (step - 1)) == 0);
Packit Service 5195f2
Packit Service 5195f2
    for (offset = step; offset < len; offset += step)
Packit Service 5195f2
    {
Packit Service 5195f2
        k1 = LZO_PTR_ALIGN_UP(b1+1,step);
Packit Service 5195f2
        k2 = b2 + offset;
Packit Service 5195f2
        if (k1 != k2)
Packit Service 5195f2
        {
Packit Service 5195f2
            printf("error 1: i %lu step %ld offset %ld: "
Packit Service 5195f2
                   "%p (%ld) %p (%ld)\n",
Packit Service 5195f2
                   i, (long) step, (long) offset,
Packit Service 5195f2
                   k1, (long) (k1 - block),
Packit Service 5195f2
                   k2, (long) (k2 - block));
Packit Service 5195f2
            return 0;
Packit Service 5195f2
        }
Packit Service 5195f2
        if (k1 - step != b1)
Packit Service 5195f2
        {
Packit Service 5195f2
            printf("error 2: i %lu step %ld offset %ld: "
Packit Service 5195f2
                   "%p (%ld) %p (%ld)\n",
Packit Service 5195f2
                   i, (long) step, (long) offset,
Packit Service 5195f2
                   b1, (long) (b1 - block),
Packit Service 5195f2
                   k1, (long) (k1 - block));
Packit Service 5195f2
            return 0;
Packit Service 5195f2
        }
Packit Service 5195f2
Packit Service 5195f2
        assert(k1 > b1);
Packit Service 5195f2
        assert(k2 > b2);
Packit Service 5195f2
        assert((lzo_uint)(k2 - b2) == offset);
Packit Service 5195f2
        assert(k1 - offset == b2);
Packit Service 5195f2
#if defined(PTR_ALIGNED_4)
Packit Service 5195f2
        if (step == 4)
Packit Service 5195f2
        {
Packit Service 5195f2
            assert(PTR_ALIGNED_4(k1));
Packit Service 5195f2
            assert(PTR_ALIGNED_4(k2));
Packit Service 5195f2
            assert(PTR_ALIGNED2_4(k1,k2));
Packit Service 5195f2
        }
Packit Service 5195f2
#endif
Packit Service 5195f2
#if defined(PTR_ALIGNED_8)
Packit Service 5195f2
        if (step == 8)
Packit Service 5195f2
        {
Packit Service 5195f2
            assert(PTR_ALIGNED_8(k1));
Packit Service 5195f2
            assert(PTR_ALIGNED_8(k2));
Packit Service 5195f2
            assert(PTR_ALIGNED2_8(k1,k2));
Packit Service 5195f2
        }
Packit Service 5195f2
#endif
Packit Service 5195f2
#if defined(PTR_LINEAR)
Packit Service 5195f2
        assert((PTR_LINEAR(k1) & (step-1)) == 0);
Packit Service 5195f2
        assert((PTR_LINEAR(k2) & (step-1)) == 0);
Packit Service 5195f2
#endif
Packit Service 5195f2
Packit Service 5195f2
        for (k = b1 + 1; k <= k1; k++)
Packit Service 5195f2
        {
Packit Service 5195f2
            x = LZO_PTR_ALIGN_UP(k,step);
Packit Service 5195f2
            if (x != k1)
Packit Service 5195f2
            {
Packit Service 5195f2
                printf("error 3: base: %p %p %p  i %lu step %ld offset %ld: "
Packit Service 5195f2
                       "%p (%ld) %p (%ld) %p (%ld)\n",
Packit Service 5195f2
                       block, b1, b2,
Packit Service 5195f2
                       i, (long) step, (long) offset,
Packit Service 5195f2
                       k1, (long) (k1 - block),
Packit Service 5195f2
                       k, (long) (k - block),
Packit Service 5195f2
                       x, (long) (x - block));
Packit Service 5195f2
                return 0;
Packit Service 5195f2
            }
Packit Service 5195f2
        }
Packit Service 5195f2
Packit Service 5195f2
        b1 = k1;
Packit Service 5195f2
        i++;
Packit Service 5195f2
    }
Packit Service 5195f2
Packit Service 5195f2
    return i;
Packit Service 5195f2
}
Packit Service 5195f2
Packit Service 5195f2
Packit Service 5195f2
/*************************************************************************
Packit Service 5195f2
//
Packit Service 5195f2
**************************************************************************/
Packit Service 5195f2
Packit Service 5195f2
#define BLOCK_SIZE  (128*1024ul)
Packit Service 5195f2
Packit Service 5195f2
int main(int argc, char *argv[])
Packit Service 5195f2
{
Packit Service 5195f2
    lzo_bytep buf;
Packit Service 5195f2
    lzo_uint step;
Packit Service 5195f2
Packit Service 5195f2
    if (argc >= 2 && strcmp(argv[1],"-v") == 0)
Packit Service 5195f2
        opt_verbose = 1;
Packit Service 5195f2
Packit Service 5195f2
    if (lzo_init() != LZO_E_OK)
Packit Service 5195f2
    {
Packit Service 5195f2
        printf("lzo_init() failed !!!\n");
Packit Service 5195f2
        return 3;
Packit Service 5195f2
    }
Packit Service 5195f2
    buf = (lzo_bytep) lzo_malloc(2*BLOCK_SIZE + 256);
Packit Service 5195f2
    if (buf == NULL)
Packit Service 5195f2
    {
Packit Service 5195f2
        printf("out of memory\n");
Packit Service 5195f2
        return 2;
Packit Service 5195f2
    }
Packit Service 5195f2
Packit Service 5195f2
#if defined(lzo_uintptr_t)
Packit Service 5195f2
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) (lzo_uintptr_t) buf);
Packit Service 5195f2
#elif defined(__LZO_MMODEL_HUGE)
Packit Service 5195f2
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) buf);
Packit Service 5195f2
#else
Packit Service 5195f2
    printf("Align init: %p ( 0x%lx )\n", buf, (unsigned long) (size_t) buf);
Packit Service 5195f2
#endif
Packit Service 5195f2
Packit Service 5195f2
    for (step = 1; step <= 65536L; step *= 2)
Packit Service 5195f2
    {
Packit Service 5195f2
        lzo_bytep block = buf;
Packit Service 5195f2
        unsigned long n;
Packit Service 5195f2
        unsigned gap;
Packit Service 5195f2
Packit Service 5195f2
        gap = __lzo_align_gap(block, step);
Packit Service 5195f2
        block = LZO_PTR_ALIGN_UP(block, step);
Packit Service 5195f2
        if (opt_verbose >= 1)
Packit Service 5195f2
            printf("STEP %5lu: GAP: %5lu  %p %p %5lu\n",
Packit Service 5195f2
                   (unsigned long) step, (unsigned long) gap, buf, block,
Packit Service 5195f2
                   (unsigned long) (block - buf));
Packit Service 5195f2
        n = align_test(block, BLOCK_SIZE, step);
Packit Service 5195f2
        if (n == 0)
Packit Service 5195f2
            return 1;
Packit Service 5195f2
        if ((n + 1) * step != BLOCK_SIZE)
Packit Service 5195f2
        {
Packit Service 5195f2
            printf("error 4: %ld %lu\n", (long)step, n);
Packit Service 5195f2
            return 1;
Packit Service 5195f2
        }
Packit Service 5195f2
    }
Packit Service 5195f2
Packit Service 5195f2
    lzo_free(buf);
Packit Service 5195f2
    printf("Alignment test passed.\n");
Packit Service 5195f2
    return 0;
Packit Service 5195f2
}
Packit Service 5195f2
Packit Service 5195f2
Packit Service 5195f2
/* vim:set ts=4 sw=4 et: */