|
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: */
|